ROS_Gazebo仿真

ROS  indigo 默认安装了Gazebo2可以用( locate 文件名 查看 )

/opt/ros/indigo/share/gazebo_ros/launch

1、在终端中启动Gazebo:

gazebo

如图为启动后的窗口界面:

ROS_Gazebo仿真_第1张图片

 

2、Gazebo简单认识

使用ros命令打开的一个empty world 的gazebo 和我直接用gazebo命令打开的软件是没有区别的,因为都是空的内容里面。

但是实际使用是有区别的,使用roslaunch命令 打开的gazebo实际上是包含了一个ros通讯节点,这样就可以使用其他的ros指令将gazebo和你自己编写的文件联系起来。

着急学习的朋友建议直接上官网,里面有详细教程。

a)界面认识

ROS_Gazebo仿真_第2张图片

 

这个空的世界中,只有一个大地模型和光源效果。

b)添加一些东西上去

ROS_Gazebo仿真_第3张图片
如图,添加了两个球体和一个圆柱以及一个正方体。

 

c)基本工具介绍

移动工具

ROS_Gazebo仿真_第4张图片

 

旋转工具

ROS_Gazebo仿真_第5张图片
缩放工具

 ROS_Gazebo仿真_第6张图片

 


或者使用ctrl+B来进行地图编辑

ROS_Gazebo仿真_第7张图片

 

3、接下来按照ROS的教程走

a)写一个urdf的模型文件

使用终端,建立并编辑urdf文件,我推荐gedit方便

gedit object.urdf


写入代码:

   
     
       
         
         
         
       

       
         
         
           
         

       

       
         
         
           
         

       

     
     
        Gazebo/Blue
     

   

保存关闭文本编辑器。

其中:

原文解释在这:

Here the origins of the inertial center, visual and collision geometry centers are offset in +x by 2m relative to the model origin. The box geometry primitive is used here for visual and collision geometry, and has sizes 1m wide, 1m deep and 2m tall. Note that visual and collision geometries do not always have to be the same, sometimes you want to use a simpler collision geometry to save collision detection time when running a dynamic simulation. The box inertia is defined as 1kg mass and principal moments of inertia ixx=izz=1 kg*m2 and iyy=100 kg*m2.

大意就是表达上面的urdf文件,构建了一个长1m宽1m高2m的盒子对应box size = 1 1 2,并且最后给予了惯性要求,对应ixx = 1 iyy = 100,其他的标签意思有空再去查一下,看翻译虽然有个大概理解,但是具体的区别大家自己尝试一下吧,但注意一下,gezebo reference = my_box 这个标签,对应的是导入gazebo中的模型名称。

接下来我们打开终端,使用命令行将这个文件导入到gazebo。


首先使用终端打开gazebo,这次使用roslaunch命令打开,因为要开一个节点:

roslaunch gazebo_ros empty_world.launch


接下来使用rosrun命令将前面写的urdf文件放进去(记得先用终端cd到你放置urdf文件的路径下):

rosrun gazebo_ros spawn_model -file `pwd`/object.urdf -urdf -z 1 -model my_object  


运行结束之后,会发现你的gazebo多了一个蓝色的物体,如图:

ROS_Gazebo仿真_第8张图片
一、使用ROS命令将新的对象加入到Gazebo模拟器中。

 

1)首先我们打开终端,roscore核心记得运行起来。

roscore


2)再开一个新的终端,使用roslaunch命令打开一个空的gazebo(注意这是重新开始了,如果你是直接从上篇看过来的,请直接进入到4)小节)

ros wiki上是用的是以下命令

roslaunch gazebo_worlds empty_world.launch

原因是因为官方在此处用的并不是ros indigo版本,可能是jade也可能是hydro,具体的我也不清楚,这里给大家推荐一个方法,如何确定gazebo_后面的参数,一般来说,ros会安装在/opt路径下,那么我们进入到/opt/ros/xxx(你的版本,我的是indigo)/share/ , 在这个文件夹下,可以找到你的gazebo_xxx,你可以看到你的后续应该跟的文件名称,是worlds 还是ros就在这里看。

如果你是indigo版本,使用以下命令

roslaunch gazebo_ros empty_world.launch

打开了一个新的Gazebo界面。

3)将上次写的蓝色盒子的urdf文件导入进去,如果你不明白这里的话,请看我上一篇博客。

rosrun gazebo_ros spawn_model -file `pwd`/object.urdf -urdf -z 1 -model my_object


4)使用roslaunch命令为模拟器中添加一张桌子
打开终端,输入以下命令

roslaunch gazebo_ros table.launch

有的朋友说,我没有找到gazebo_ros 的launch文件夹下有这个table.launch文件,当然没有,这个是要自己写的,官方知识让你看看,具体的要自己动手。

首先,使用终端,进入到gazebo_ros文件夹下。

cd /opt/ros/indigo/share/gazebo_ros


建立一个objects文件夹,这里主要用来储存后续的模型文件

sudo mkdir objects


然后,使用终端,进入到gazebo_ros下launch文件夹下。

cd /opt/ros/indigo/share/gazebo_ros/launch


你会发现这里有一些launch文件,比如你最开始是用的empty_worlds.launch文件就在这里。

接着,我们使用命令,创建一个table.launch文件

sudo gedit table.launch


将以下代码复制进去(这段代码是官方提供的,Indigo版本不适用,后面我会讲到如何改过来)


 
 

 
 


保存并关闭文件。
使用roslaunch命令运行我们的launch文件

rosluanch gazebo_ros table.launch


终端会提示错误,一大堆,使用indigo版本的人到这里其实是有三处错误,使用其他版本的也许只有一处,这里以indigo版本为例。
a)首先,你缺少了一个模型文件,即table的模型文件,我们使用的launch文件只是添加模型,但模型的具体文件不存在,需要我们手动建立。
我们进入到前面建立的objects文件夹下,建立一个名为table.urdf.xacro格式的文件

cd /opt/ros/indigo/share/gazebo_ros/objects

sudo gedit table.urdf.xacro

将以下代码填入这个文件中:

   
               xmlns:xi="http://www.w3.org/2001/XInclude"
           xmlns:gazebo="http://playerstage.sourceforge.net/gazebo/xmlschema/#gz"
           xmlns:model="http://playerstage.sourceforge.net/gazebo/xmlschema/#model"
           xmlns:sensor="http://playerstage.sourceforge.net/gazebo/xmlschema/#sensor"
           xmlns:body="http://playerstage.sourceforge.net/gazebo/xmlschema/#body"
           xmlns:geom="http://playerstage.sourceforge.net/gazebo/xmlschema/#geom"
           xmlns:joint="http://playerstage.sourceforge.net/gazebo/xmlschema/#joint"
           xmlns:interface="http://playerstage.sourceforge.net/gazebo/xmlschema/#interface"
           xmlns:rendering="http://playerstage.sourceforge.net/gazebo/xmlschema/#rendering"
           xmlns:renderable="http://playerstage.sourceforge.net/gazebo/xmlschema/#renderable"
           xmlns:controller="http://playerstage.sourceforge.net/gazebo/xmlschema/#controller"
           xmlns:physics="http://playerstage.sourceforge.net/gazebo/xmlschema/#physics">
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
       
         
         
                             iyy="1" iyz="0"
                   izz="1" />
       

       
         
         
           
         

       

       
         
         
           
         

       

     
     
        Gazebo/Wood
        50.0
        50.0
        1000000.0
        1.0
     

     
     
       
       
       
     

     
       
         
         
                             iyy="0.1" iyz="0"
                   izz="0.01" />
       

       
         
         
           
         

       

       
         
         
           
         

       

     
     
        Gazebo/Red
        1000.0
        1000.0
        10000000.0
        1.0
        true
     

     
     
       
       
       
     

     
       
         
         
                             iyy="0.1" iyz="0"
                   izz="0.01" />
       

       
         
         
           
         

       

       
         
         
           
         

       

     
     
        Gazebo/Red
        1000.0
        1000.0
        10000000.0
        1.0
        true
     

     
     
       
       
       
     

     
       
         
         
                             iyy="0.1" iyz="0"
                   izz="0.01" />
       

       
         
         
           
         

       

       
         
         
           
         

       

     
     
        Gazebo/Red
        1000.0
        1000.0
        10000000.0
        1.0
        true
     

     
     
       
       
       
     

     
       
         
         
                             iyy="0.1" iyz="0"
                   izz="0.01" />
       

       
         
         
           
         

       

       
         
         
           
         

       

     
     
        Gazebo/Red
        1000.0
        1000.0
        10000000.0
        1.0
        true
     

     
        true
        table_top_link
     

     
     
   

保存并关闭文件。

官方wiki一样ros版本的朋友你可以直接允许roslaunch table.launch命令了,然后跳过b)、c)两个小节,indigo版本的继续往下看
indigo版本运行roslaunch gazebo_ros table.launch文件你会发现出现这样的错误

那就对了,我们继续向下看。

b)修改table.launch文件
将table.launch的代码中的这句

替换为

原因是因为我们使用的indigo版本对应的文件夹名称为gazebo_ros而非gazebo_worlds

保存退出,然后你发现运行roslaunch gazebo_ros table.launch
你会发现出现这样的错误:

ROS_Gazebo仿真_第9张图片

 

关键错误出来了,ERROR:cannot launch node of type [gazebo/spawn_model]: gazebo
原来是在已经运行的节点名称不对,找不到这个gazebo名字啊
熟悉ros的朋友这会估计已经可以自己解决了,跳过c)也能自己正常做到了
好的,我们根据这个,找到我们前面打开的empty_worlds.launch这个文件
发现其中尾部有一句关键句为:

      args="$(arg command_arg1) $(arg command_arg2) $(arg command_arg3) -e $(arg physics) $(arg extra_gazebo_args) $(arg world_name)" />

我们可以看到,pkg=“gazebo_ros”
而table.launch文件对应的为:

 

发现不同,原来这里pkg="gazebo"

c)将pkg改正过来
我们再次编辑table.launch文件,将这段代码:

 

替换为:

 

然后保存关闭。

那么ros indigo 版本下,正确的table.launch文件代码全文如下:


 
 

 
 


终端中运行正确的launch文件

roslaunch gazebo_ros table.launch


你会发现没有报错,如果这个时候还报错,你就从头看一下,是否是哪个步骤没做好?
然后你会看到你的gazebo模拟器中,出现了如图所示的一张桌子:

ROS_Gazebo仿真_第10张图片

 

恭喜你,你已经学会了如何通过roslaunch命令导入相关的模型了。

5)使用launch文件导入多个模型
为了方便,我们把这两个物体写到一个launch文件中,一次性运行可以导入两个;
首先,把最开始写的object.urdf复制到/opt/ros/indigo/share/gazebo_ros/objects路径下,然后到launch文件夹下建立all.launch文件

sudo gedit all.launch


将以下代码复制:


 
 
 

 
 
 

保存并关闭

运行all.launch文件

roslaunch gazebo_ros all.launch

你就会看到你的两个物体先后生成到模拟器中,但要注意,如果你的模拟器中已经存在了这两个物体,那么不会重新添加,因为节点信息已经存在了。

你可能感兴趣的:(Ros,Ros)