URDF修改及组合

背景

机器人仿真,有时需要将不同的urdf模型组合到一起使用,重新装配后整体导出的工作量比较大,也容易出问题,可以通过修改、组合urdf文件的方式实现;

思路

  1. urdf文件为描述性文本文件,可直接修改;
  2. urdf关节间为相对位置关系,不同的模块组合仅需要对第一级(一般为base_link)进行修改组合;

实现举例:将红色夹爪TEST2添加到灰色机械臂TEST1末端

在这里插入图片描述

前提:各urdf文件中没有相同的link、joint名

urdf文件夹包含以下内容
urdf文件组成
1. config文件夹→joint_names_XXX.yaml
joint_names_TEST1.yaml:

controller_joint_names: ['', 'J1', 'J2', ]

joint_names_TEST2.yaml:

controller_joint_names: ['', 'JL', 'JR', ]

合并后joint_names_TEST1.yaml:

controller_joint_names: ['', 'J1', 'J2','HJ','JL', 'JR' ,]

其中HJ为将夹爪与机械臂连接而添加的关节类型,可以为fixed,也可以为其他关节类型;
2. meshes文件夹
将TEST2文件夹→meshes文件夹中内容复制到TEST1文件夹→meshes文件夹即可;
3. urdf文件夹→XXX.urdf
a.将TEST2.urdf文件内容复制到TEST1.urdf末尾,参考原格式,并更改各link索引地址;

将上述xxx由夹爪修改为目标urdf的名称
在这里插入图片描述
b.在夹爪的base_link(此处为hand_link)下增加joint(此处为HJ),用于连接夹爪和机械臂末端;
c.夹爪相对机械臂的末端相对位置在此处修改
在这里插入图片描述
保存以上即可。

关于坐标系转换

  1. sw2urdf时设置的各link的坐标系为link输出的mesh文件(stl)的坐标系(坐标系1),在urdf文件中未直接体现;
  2. link坐标系(坐标系2)是该link重心在stl文件坐标系(坐标系1)的坐标,link的转动惯量属性为以重心为原点,对齐到(坐标系1)的转动惯量;
  3. joint坐标系(坐标系3)是chlid link坐标系1相对parent link坐标系1的偏移;
  4. child link的位姿,受到坐标系1、3综合影响,parent link坐标系1为一切转换的基准;joint坐标系3为child link坐标系1相对于parent link坐标系1的偏移;child link坐标系1决定了child link自身的位姿;
  5. joint位置通过link坐标系确定,在sw2urdf时随坐标系1确定,需通过坐标系1原点,并通过rpy确定位姿;
  6. link的visual坐标系和

其他

  1. urdf文件夹下有test.csv文件,等同于urdf,有的软件不需要使用这个文件,按需修改;
  2. 其他常规urdf修改项文中未提及,请参考其他文章。
我的机器人模型:<!-- 组合小车底盘与传感器 --> <robot name="my_car_camera" xmlns:xacro="http://wiki.ros.org/xacro"> <xacro:include filename="my_head.urdf.xacro" /> <xacro:include filename="my_base.urdf.xacro" /> <xacro:include filename="my_laser.urdf.xacro" /> <xacro:include filename="move.urdf.xacro" /> <!-- 雷达仿真的 xacro 文件 --> <xacro:include filename="my_sensors_laser.urdf.xacro" /> </robot> 请帮我修改my_sensors_laser.urdf.xacro:<robot name="my_sensors" xmlns:xacro="http://wiki.ros.org/xacro"> <!-- 雷达(VLP-16) --> <gazebo reference="laser"> <sensor type="gpu_ray" name="vlp16"> <pose>0 0 0 0 0 0</pose> <visualize>true</visualize> <update_rate>10</update_rate> <ray> <scan> <horizontal> <samples>2000</samples> <resolution>0.18</resolution> <min_angle>-3.1415926535</min_angle> <max_angle>3.1415926535</max_angle> </horizontal> <vertical> <samples>16</samples> <resolution>0.2</resolution> <min_angle>-0.261799</min_angle> <max_angle>0.261799</max_angle> </vertical> </scan> <range> <min>0.10</min> <max>100.0</max> <resolution>0.03</resolution> </range> <noise> <type>gaussian</type> <mean>0.0</mean> <stddev>0.03</stddev> </noise> </ray> <plugin name="gazebo_vlp16" filename="libgazebo_ros_gpu_laser.so"> <topicName>/velodyne_points</topicName> <frameName>laser</frameName> <min_range>0.10</min_range> <max_range>100.0</max_range> <hmin>-3.1415926535</hmin> <hmax>3.1415926535</hmax> <vmin>-0.261799</vmin> <vmax>0.261799</vmax> <samples>2000</samples> <resolution>1.0</resolution> <gpu>true</gpu> </plugin> </sensor> </gazebo> </robot>让rostopic info /velodyne_points Type: sensor_msgs/LaserScan 输出的类型为Pointcloud2
最新发布
04-02
为了让你的 Gazebo 模拟器发布 `/velodyne_points` 话题的数据类型从 `sensor_msgs/LaserScan` 改为 `sensor_msgs/PointCloud2`,你需要对当前的 `my_sensors_laser.urdf.xacro` 文件做一些关键性的更改。 以下是修改后的文件内容及其解释: --- ### 修改后的 `my_sensors_laser.urdf.xacro` ```xml <robot name="my_sensors" xmlns:xacro="http://wiki.ros.org/xacro"> <!-- 定义雷达链路 --> <link name="laser"> <visual> <geometry> <box size="0.1 0.1 0.1"/> </geometry> </visual> <collision> <geometry> <box size="0.1 0.1 0.1"/> </geometry> </collision> </link> <!-- 雷达(VLP-16)仿真配置 --> <gazebo reference="laser"> <sensor type="gpu_ray" name="vlp16"> <pose>0 0 0 0 0 0</pose> <visualize>true</visualize> <update_rate>10</update_rate> <!-- 设置扫描参数 --> <ray> <scan> <horizontal> <samples>2000</samples> <resolution>0.18</resolution> <min_angle>-3.1415926535</min_angle> <max_angle>3.1415926535</max_angle> </horizontal> <vertical> <samples>16</samples> <resolution>0.2</resolution> <min_angle>-0.261799</min_angle> <max_angle>0.261799</max_angle> </vertical> </scan> <!-- 范围参数 --> <range> <min>0.10</min> <max>100.0</max> <resolution>0.03</resolution> </range> <!-- 添加噪声模拟 --> <noise> <type>gaussian</type> <mean>0.0</mean> <stddev>0.03</stddev> </noise> </ray> <!-- 替换插件为 PointCloud2 类型 --> <plugin name="gazebo_ros_vlp16" filename="libgazebo_ros_velodyne_lidar.so"> <frameName>laser</frameName> <topicName>/velodyne_points</topicName> <minRange>0.10</minRange> <maxRange>100.0</maxRange> <updateRate>10.0</updateRate> <numLaserBeams>16</numLaserBeams> <rpm>300.0</rpm> <pointCloudFormat>VLP_16</pointCloudFormat> </plugin> </sensor> </gazebo> </robot> ``` --- ### 关键点解析 1. **插件更换** 将原来的 `libgazebo_ros_gpu_laser.so` 插件替换为专门用于 Velodyne LiDAR 的插件 `libgazebo_ros_velodyne_lidar.so`。这个插件会直接发布 `sensor_msgs/PointCloud2` 类型的消息。 2. **参数调整** - 新增了 `<numLaserBeams>` 参数,表示激光束的数量(对于 VLP-16 来说就是 16 束)。 - 使用 `<pointCloudFormat>` 明确指定了输出格式为 "VLP_16"。 3. **话题名称保持一致** 确保发布的消息仍然在 `/velodyne_points` 上,以便下游节点能够无缝对接。 4. **可视化支持** 在 Gazebo 中启用 `<visualize>true</visualize>`,可以直观地查看雷达的行为和范围。 --- ### 测试结果 当你运行完整系统后,输入以下命令检查主题信息: ```bash rostopic info /velodyne_points ``` 此时应显示: ``` Type: sensor_msgs/PointCloud2 ``` 此外,还可以使用 RViz 查看点云数据是否正确呈现出来。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值