環境模型構建可以通過向其中添加模型實現,待之後補充,比較有趣的是建築物模型,
可以編輯多層樓層和房間,加入樓梯,窗戶和牆壁等,具體可以參考附錄,等有空再補充。
起伏地形環境構建可以參考之前內容:在Gazebo中使用DEM構建起伏地形環境
附錄:官方文檔
This tutorial describes the process of creating a world with both static and dynamic objects.
true
element in SDF), are objects which only have collision geometry. All objects which are not meant to move should be marked as static, which is a performance enhancement.
element or setting false in SDF), are objects which have both inertia and a collision geometry.Make sure Gazebo is installed.
Create a working directory for this tutorial:
$ mkdir ~/build_world_tutorial; cd ~/build_world_tutorial
Start up gazebo, and you should see a world with just a ground plane.
$ gazebo
Gazebo provides two mechanisms for adding objects to Gazebo.
Insert
tab in the upper left corner.Boxes, spheres, and cylinders may be added to the world by clicking on the appropriate icon above the render window. Each shape is of unit size:
Select the box icon, and then move your mouse onto the render window. You will see a box that moves with your mouse. Left click when you are happy with the position of the box.
Repeat the same procedure for the sphere and cylinder. You should end with a world similar to this:
Gazebo's model database is a repository of all types of models including robots, tables, and building.
Select the Insert
tab in the upper left hand corner to access the model database.
The list of models are divided into sections according to there current location. Each section is labeled with a path or URI. Selecting an object located on a remote server will cause the model to be downloaded and stored in
~/.gazebo/models
.
Try adding various models to the world. Be patient when downloading models, as some may be large.
You should end up with something similar to the following, depending on the models you decided to add:
The pose of each model may be altered through the translate and rotate tools:
The translate tools allows you to move the object along the x, y, and z axes. Select this tool now and click on the object you want to move. A three axes visual marker will appear over the object, which allows you to move the object in x, y, and z directions.
You can also just click on the object itself and drag it to move on the x-y plane. You may control which axis the object moves along by pressing and holding the x, y, or z key while dragging the object.
Try moving the objects around now into a different configuration.
The rotate tool allows you to orient a model around the x, y, and z axes. Select this tool now and click on the object you want to move. Three ring-shaped visual marker will appear over the object, which allows you to rotate the object around the x, y, and z axes.
Try rotating the objects into a different configuration.
The scale tool allows you to resize a model in the x, y, and z directions. Currently the scale tool only works with simple shapes, i.e. box, cylinder and sphere. Select this tool now and click on a simple shape. A three axes visual marker will appear over the object, which allows you to scale the x, y, and z dimensions of the object.
Try scaling the simple shapes into different sizes.
Model may also be deleted by selecting them and the hitting the Delete
key, or by right-clicking on a model and selecting Delete
.
Try deleting a few models.
Once you are happy with a world it can be save through the File
menu.
Select the File
menu now, and choose Save As
.
A pop-up will appear asking you to enter a new filename. Enter my_world.sdf
and click okay.
A saved world may be loaded on the command line:
gazebo my_world.sdf
The filename must be in the current working directory, or you must specify the complete path.
Next: Modifying a world tutorial
This tutorial describes how to modify global properties including scene and physics properties.
Start gazebo:
$ gazebo
In the World
tab, select the scene
item. A list of scene properties will be displayed in the list box below. Click the triangle to expand the properties.
These properties allow you to change the ambient light. Note: The background color will not change if the Sky is enabled.
In the World
tab, select the physics
item. A list of physics properties will be displayed in the list box below.
enable physics
check-box can be used to disable physics while allowing plugins and sensors to continue running.real time update rate
parameter specifies in Hz the number of physics updates that will be attempted per second. If this number is set to zero, it will run as fast as it can. Note that the product of real time update rate
and max step size
represents the target real time factor
, or ratio of simulation time to real-time.max step size
specifies the time duration in seconds of each physics update step.In the gravity block:
x
, y
and z
parameters set the global gravity vector components in m/s^2.In the solver block:
iterations
parameter specifies the number of iterations to use for iterative LCP solvers (used by ODE and bullet).SOR
parameter stands for successive over-relaxation, which can be used to try to speed the convergence of the iterative method.The constraints block contains several parameters related to solving constraints:
CFM
and ERP
parameters stands for Constraint Force Mixing and Error Reduction Parameter and are used by ODE and bullet. The CFM and ERP parameters can be related to linear stiffness and damping coefficients. The max velocity
and surface layer
parameters are used to resolve contacts with a split impulse method. Any contacts with that penetrate deeper than a depth specified by surface layer
and have a normal velocity less than max velocity
will not bounce.See the sdf physics documentation for a description of these parameters.
Next: How to use DEMs in Gazebo
A Digital Elevation Model (DEM) is a 3D representation of a terrain's surface that does not include any objects like buildings or vegetation. DEMs are frequently created by using a combination of sensors, such as LIDAR, radar, or cameras. The terrain elevations for ground positions are sampled at regularly-spaced horizontal intervals. Wikipedia is a good resource for getting more details about DEMs.
The term DEM is just a generic denomination, not a specific format. In fact, the DEMs can be represented as a grid of elevations (raster) or as a vector-based triangular irregular network (TIN). Currently, Gazebo only supports raster data in the supported formats available in GDAL.
The main motivation to support DEMs in Gazebo is to be able to simulate a realistic terrain. Rescue or agriculture applications might be interested in testing their robot behaviors using a simulated terrain that matches the real world.
In order to work with DEM files you should install GDAL libraries.
$ sudo apt-get install gdal-bin libgdal-dev libgdal1h python-gdal
There are several organizations that provide elevation data. As an example,let's download a DEM file of Mount St. Helensbeforeorafterits eruption back in the '80s. These files are in public domain and aredistributed by USGS.
Unzip the file and rename it mtsthelens.dem
as follows:
cd ~/Downloads
wget https://bitbucket.org/osrf/gazebo_tutorials/raw/default/dem/files/mtsthelens_before.zip
unzip ~/Downloads/mtsthelens_before.zip -d /tmp
mv /tmp/30.1.1.1282760.dem /tmp/mtsthelens.dem
Usually, DEM files have big resolutions and Gazebo cannot handle it, so it's a good idea to adjust the resolution of your DEM. The next command will scale the terrain to 129x129 and will copy into the Gazebo media/dem/
directory.
$ mkdir -p /tmp/media/dem/
$ gdalwarp -ts 129 129 /tmp/mtsthelens.dem /tmp/media/dem/mtsthelens_129.dem
A DEM file in Gazebo is loaded in the same way that you load a heightmap image. Gazebo automatically detects if the file is a plain image or a DEM file. Create the file volcano.world
and copy the next content. Save the file anywhere you want, for example, in /tmp
.
model://sun
true
file://media/dem/mtsthelens_129.dem
150 150 50
0 0 0
file://media/materials/textures/dirt_diffusespecular.png
file://media/materials/textures/flat_normal.png
1
file://media/materials/textures/grass_diffusespecular.png
file://media/materials/textures/flat_normal.png
1
file://media/materials/textures/fungus_diffusespecular.png
file://media/materials/textures/flat_normal.png
1
2
5
4
5
file://media/dem/mtsthelens_129.dem
150 150 50
0 0 0
The
element in the code above tells Gazebo whether to load the DEM with the original dimensions (when
is not present) or to scale it (when
is present). In case you prefer to scale the DEM, the
element tells Gazebo the size in meters that the terrain will have in the simulation. If you want to maintain the correct aspect ratio, be sure to properly calculate the width, height and elevation (which is the third number in
). In our example, the DEM will be scaled to a square of 150 x 150 meters and a max elevation of 50 meters.
Launch Gazebo with the world containing your DEM file and you should see the volcano. In our case, the file is in the /tmp directory.
# Be sure of sourcing gazebo setup.sh in your own installation path
$ source /usr/share/gazebo/setup.sh
$ GAZEBO_RESOURCE_PATH="$GAZEBO_RESOURCE_PATH:/tmp" gazebo /tmp/volcano.world
Next, we are going to describe one method for obtaining a DEM file of a specific region of interest.
Global Land Cover Facility maintains a high-resolution digital topographic database of Earth. Go to its Search and Preview tool and you will see something similar to the image below. Every terrain patch has a unique path and row that you should know before using the tool. We'll use QGIS to discover the path/row of our region of interest.
QGIS is a cross-platform open source geographic information system program that provides data viewing, editing, and analysis capabilities. Download QGIS following the instructions detailed on the QGIS website.
Open up QGIS, click on the left column icon labeled WMS/WMTS layer
, click on Add default servers
, select Lizardtech server
, and then, press the connect
button. Select the MODIS
value and press Add
. Close the pop-up window. The next step is to add another layer with all the different patches available. Download this shapefile and decompress it in any folder. Go back to QGIS and press Add Vector Layer
(left column icon). Press Browse
, and select your previously uncompressed wrs2descending.shp file. Press Open
in the window that opens. Now, you'll see both layers on the main window. Let's change the transparency of the wrs2descending layer to be able to see both layers at the same time. Double click on wrs2_descending layer, and then, modify its transparency value to something around 85%.
Use the scroll and left button to navigate to your region of interest. Then click on the icon labeled Identify Features
on the top bar. Click on your region of interest and all the terrain patches around the area will be highlighted. A new pop up window will show the path/row values for each highlighted patch. In the image below you can see the path and row of the DEM patch containing Las Palmas, one of the heavenly places of the Canary Islands, Spain.
Go back to your browser with the GLCF search tool and write the path/row values in the columns labeled Start Path
and Start Row
. Then click in Submit Query
; press Preview and Download
to see your results. Choose your terrain file and press Download
. Finally, select your file with extension .gz, and decompress it in your favorite folder. Global Land Cover Facility files are in GeoTiff format, one of the most common format of DEM files available.
DEM data is usually created at very high resolution. Use gdalwarp to reduce the resolution of the terrain to a more manageable size before using it in Gazebo.
$ gdalwarp -ts
DEM data often contain "holes" or "void" areas. These sections correspond to areas where data could not be collected while the DEM was created. In the case of a data "hole", the hole will be assigned the minimum or maximum value of the data type that is used in that DEM.
Always try to download "finished" versions of DEM data sets, where the holes have been filled. If your DEM terrain contains holes (also known as NODATA values), try to manually repair it using gdal tools, such as gdal_fillnodata.py.
Although Gazebo does not directly support multiple DEMs, GDAL has a set of utilities for merging a set of DEMs into a single one. The first step is to download the set of DEMs that you want to merge. Note that the patches can even overlap with one another; GDAL will merge them seamlessly. Assuming that your current directory contains a set of Geotiff files ready to be merged, run the next command.
$ gdal_merge.py *.tif -o dem_merged.tif
Now, you can just use dem_merged.tif
in your world file and Gazebo will load the terrain with all the patches merged. In the next screenshot you can see the result of merging four terrain patches surrounding the Canary Islands.
This tutorial demonstrates how you can create a population of models byusing the SDF
tag. A population consists of a collectionof identical models.
Adding a population of models is a matter of specifying the followingparameters:
Model (e.g.: table
, coke_can
).
Number of objects to be part of the population.
Shape and dimensions of the container within which the objects will bearranged (e.g.: box
, cylinder
).
The position and orientation of the population's container.
Distribution of the objects within the container (e.g.: random
, grid
).
For reference, check theSDF specificationfor a complete specification of the
tag and its parameters.
Let's start by creating a directory for this tutorial:
mkdir ~/tutorial_model_population
cd ~/tutorial_model_population
Download this file:can_population.world
into the current directory. You can use this command:
wget http://bitbucket.org/osrf/gazebo_tutorials/raw/default/model_population/files/can_population.world
You should get this world file:
model://sun
model://ground_plane
true
model://coke_can
0 0 0 0 0 0
2 2 0.01
10
random
Start gazebo:
gazebo can_population.world
You should see a population of soda cans randomly located around theworld's origin. The cans are arranged within a box container of size2 x 2 x 0.01 meters.
Let's go further and understand the different elements of the can_population.world
.
true
model://coke_can
In this snippet we can see how to specify a population element by using the
tag. Every population should have a unique name, and this isspecified by the name
attribute. Within the population
tag, you can seehow to select a model by using the
tag. Each element of the populationwill be inserted into the simulation with a unique name that will be created byappending to the model name the suffix _clone_i
, where i
is the ith elementof the population. You can see the list of models spawned in the Gazebo scenehere:
The most common type of population consists of inanimate objectssuch as trees, rocks, and buildings. We recommend you use the
tagfor static models, and exclude mobile entities, such as robots, which oftenrequire more precise placement and are fewer in number.
0 0 0 0 0 0
2 2 0.01
The above block of code specifies the region in which the objects will beplaced. In this case, all the objects are spawned within a 3D bounding box withsides 2 x 2 x 0.01 m
, centered at (0, 0, 0) with orientation (0, 0, 0). As analternative to
, a
region is also allowed by specifying itsradius and length. (Check out theSDF specificationfor a full description of the
parameters.) The
elementsets the reference frame of the population's region.
10
Above you can see how the number of models in the population is determined. Anypositive number is allowed, but take into consideration that the higher thenumber, the more impacted the performance may be.
random
The
element sets how the objects are placed within the region.
random
: Models placed at random. Note that the objects might collide withone another.
uniform
: Models placed in a pseudo-2D grid pattern. We use K-Means toapproximate the solution and locate the number of specified objects inside theregion.
grid
: Models evenly placed in a 2D grid pattern. This distribution alsorequires that you specify the number of rows, columns, and distance betweeneach element. Note that the element
is ignored in thisdistribution. The number of objects inserted into the simulation will be equalto the number of rows multiplied by the number of columns.
linear-x
: Models evenly placed in a row along the global x-axis.
linear-y
: Models evenly placed in a row along the global y-axis.
linear-z
: Models evenly placed in a row along the global z-axis.
For a more advanced example you can check thepopulation.worldworld file deployed with Gazebo.
And of course, you can test it by typing:
gazebo worlds/population.world
This tutorial describes the process of creating a building using the Building Editor.
Make sure Gazebo is installed.
Start up gazebo.
$ gazebo
On the Edit
menu, go to Building Editor
, or hit Ctrl+B
to open the editor.
The editor is composed of the following 3 areas:
The Palette, where you can choose features and materials for your building.
The 2D View, where you can import a floor plan to trace over (optional) and insert walls, windows, doors and stairs.
The 3D View, where you can see a preview of your building. It is also where you can assign colors and textures to different parts of your building.
You may create a scene from scratch, or use an existing image as a template to trace over. This image can be, for example, a 2D laser scan of a building.
Click here to get an example floor plan, then proceed as follows:
Click on the Import
button. The Import Image
dialog will come up.
Step 1: Choose the image you previously saved on your computer and click Next
.
Step 2: To make sure the walls you trace over the image come up in the correct scale, you must set the image's resolution in pixels per meter (px/m
). If we knew the resolution, we could directly type it in the dialog and click Ok
. In this example we don't know the resolution, but we know the real-world distance between two points in the image (for example, the top wall of 7.5 m), so we can use that to calculate the resolution:
a. Click/release on one end of the wall. As you move the mouse, an orange line will appear as shown below.
b. Click/release at the end of the wall to complete the line.
c. Now type the distance in meters in the dialog (7.5 m in this case). The resolution will be automatically calculated for you based on the line you drew.
d. You can then click Ok
.
The image will appear on the 2D View properly scaled.
Tip: Once you've added more levels, you can import a floor plan for each by repeating the same process.
Trace all walls on the floor plan as follows. Keep in mind that we will attach windows and doors to the walls later, so here you can draw the walls over them. Don't worry too much if the walls are not perfect, we will edit them later.
On the Palette, click on Wall
.
On the 2D View, click/release anywhere to start the wall. As you move the mouse, the wall's length is displayed.
Click again to end the current wall and start an adjacent wall.
Double-click to finish a wall without starting a new one.
Tip: You can right-click or press
Esc
to cancel drawing the current wall segment.Tip: By default, walls snap to 15° and 0.25 m increments and also to the end points of existing walls. To override this, hold
Shift
while drawing.
Note: Currently, windows and doors are simple holes in the wall.
Let's insert windows and doors at the locations shown on the floor plan.
On the Palette, click on Window
or Door
.
As you move the mouse in the 2D view, the feature to be inserted moves with it, as does its counterpart in the 3D View.
Tip: Windows and doors automatically snap to walls as you hover over them. The distances to the ends of the wall are displayed as you move.
Click on the desired position to place the feature.
Tip: It might be difficult to see where the features are on your floor plan after the walls have been drawn on top of it. To make it easier, at the top of the 2D View, you can choose to view or hide the floor plan or features for the current level. You can also use hotkeys to toggle visibility,
F
for floor plan andG
for features.
There are no staircases on this floor plan, but we will insert one anyways.
On the Palette, click on Stairs
.
As you move the mouse in the 2D view, the staircase to be inserted moves with it, as does its counterpart in the 3D View.
Choose a position for your staircase and click to place it.
We're pretty much done with Level 1. Let's add another level to our building so our staircase ends up somewhere.
At the top of the 2D View, click on +
to add a level. Alternatively, right-click the 2D View and choose Add a level
.
When a new level is added, a floor is automatically inserted. If there are stairs on the level below, a hole above the stairs will be cut out from the floor when the building is saved.
Note: Currently, all floors are rectangular.
Tip: Before adding a level, make sure you have walls on the current level to build on top of.
Tip: Currently, all the walls from the level below are copied to the new level, with default materials. No other features are copied. You can manually delete the walls you don't want.
Note: Be careful when editing your building; the editor currently has no option to undo your actions.
Tip: All measurements are in meters.
Since we added a level, we were brought to the new level in the 2D view. You can go back to Level 1 by choosing it from the drop-down list at the top of the 2D View.
Tip: The level currently selected in the 2D View will appear as semi-transparent in the 3D View and all levels below it will appear opaque. Levels above will be hidden - but keep in mind they are still part of your building!
We can also edit some level configurations if we want.
Open Level Inspector
.You may have added levels that you don't want, or perhaps made a mess in the current level and would like to start it over.
To delete the current level, either press the -
button at the top of the 2D View, or right-click and choose Delete Level
.
We drew a lot of walls earlier, but maybe they didn't turn out exactly the way we wanted.
In the 2D View, click on the wall to be edited.
a. Translate the wall by dragging it to a new position.
b. Resize or rotate the wall by dragging one of its end points.
Tip: By default, walls snap to 15° and 0.25 m increments. To override this, hold
Shift
while drawing.
Double-click a wall in the 2D View to open an inspector with configuration options. Alternatively, right-click and choose Open Wall Inspector
. Edit some fields and press Apply
to preview the changes.
To delete a wall, either press the Delete
key while it is selected, or right-click the wall in the 2D View and choose Delete
.
Tip: Editing a wall takes attached walls into account.
Tip: Deleting a wall deletes all doors and windows attached to it.
Now let's play around with windows and doors. As we did for the walls, we can manipulate windows and doors more precisely in a few different ways.
In the 2D View, click on the feature to be edited.
a. Translate the feature by dragging it to a new position. Remember that windows and doors automatically snap to walls and it doesn't make much sense to have them detached from any walls, as they represent holes in a wall.
b. Rotate the feature by dragging its rotation handle. Currently, as long as they are attached to a wall, their orientation doesn't make a difference.
c. Resize the feature's width by dragging one of the end points.
Double-click a feature in the 2D View to open an inspector with configuration options. Alternatively, right-click and choose Open Window/Door Inspector
.
To delete a feature, either press the Delete
key while it is selected, or right-click it in the 2D View and choose Delete
.
Finally, let's edit the staircase we inserted earlier. Since it is not on the floor plan, we can get creative and resize it as we want.
In the 2D View, click on the staircase to select it.
a. Translate the staircase by dragging it to a new position.
b. Rotate the staircase in multiples of 90° by dragging its rotation handle.
c. Resize the staircase by dragging one of the end nodes.
Double-click the staircase in the 2D View to open an inspector with configuration options. Alternatively, right-click and choose Open Stairs Inspector
.
To delete the staircase, either press the Delete
key while it is selected, or right-click and choose Delete
.
Tip: In the 2D View, staircases are visible on both the start and end levels.
Now that everything is properly placed and sized, you can assign colors and textures to walls, floors and staircases. Remember that windows and doors are only holes on the wall and therefore cannot have materials.
Tip: The default color is white and the default texture is none.
There are two ways to add colors and textures to your building:
You can add color and texture to walls, stairs and floors from the Wall Inspector
, Stairs Inspector
and Level Inspector
respectively. Simply open the inspector, select your materials and press Apply
.
Colors and textures can be chosen from the Palette and assigned to items on your building by clicking on them in the 3D View.
Click on a color or texture in the Palette.
As you move your mouse in the 3D View, hovered features will be highlighted displaying a preview of the selected material.
Clicking on the highlighted feature assigns the selected material to it. You can click on as many features as you'd like.
When you're done with the selected material, either right-click the 3D view, or click outside any features to leave the material mode.
New in Gazebo 5.1: To choose a custom color, click on
More
on the Palette. A dialog opens where you can specify custom colors.
Tip: Each feature can have only one color and one texture. The same material is assigned to all faces of the feature.
Note: Currently, it is not possible to assign custom textures on the Building Editor.
Saving will create a directory, SDF and config files for your building.
Before saving, give your building a name on the Palette.
On the top menu, choose File
, then Save As
(or hit Ctrl+S
). A dialog will come up where you can choose the location for your model.
Tip: Under
Advanced Options
you can set some meta-data for your building.
Note: Once you exit the Building Editor, your building will no longer be editable.
When you're done creating your building and you've saved it, go to File
and then Exit Building Editor
.
Your building will show up in the main window. In the future, you can find the building in your Insert
tab.