gazebo教程---ros_control

2023-05-16

一. ros_control和Gazebo的数据流向
在Gazebo中模拟机器人的控制器是可以通过使用ros_control和一个简单的Gazebo插件适配器来完成。下面是仿真,硬件,控制器和传动之间关系的概览:
在这里插入图片描述
二. 使用
(1)向URDF中添加传动元素
为了使用ros_control,需要给URDF中添加一些其它元素,比如< transmission>,它是为了链接执行器和关节。而在< transmission>标签中一些重要子标签有:

  • < joint name=" ">:name对应URDF中的joint的name
  • < type>:传动的类型,目前只有"transmission_interface/SimpleTransmission" 实现
  • < hardwareInterface>:此标签存在于< actuator>和< joint>标签,它会告诉gazebo_ros_control插件要加载的硬件接口是什么(position,velocity or effort interfaces),目前只实现effort interfaces。

一些可用的硬件接口:

  • Joint Command Interface - Hardware interface to support commanding an array of joints. Note that these commands can have any semantic meaning as long as they each can be represented by a single double, they are not necessarily effort commands. To specify a meaning to this command, see the derived classes:
    Effort Joint Interface - for commanding effort-based joints.
    Velocity Joint Interface - for commanding velocity-based joints.
    Position Joint Interface - for commanding position-based joints.
  • Joint State Interfaces - Hardware interface to support reading the state of an array of named joints, each of which has some position, velocity, and effort (force or torque).
  • Actuator State Interfaces - Hardware interface to support reading the state of an array of named actuators, each of which has some position, velocity, and effort (force or torque).
  • Actuator Command Interfaces:
    Effort Actuator Interface
    Velocity Actuator Interface
    Position Actuator Interface
  • Force-torque sensor Interface
  • IMU sensor Interface

(2)添加gazebo_ros_control插件
除了transmission标签,也需要向你的URDF中添加Gazebo插件,它会自动解析transmission标签,装载合适的硬件接口和controller manager。一般默认的gazebo_ros_control插件是很简单的,但是它也是可以通过插件架构在ros_control和gazebo之间来扩展自定义的机器人硬件接口。
一般添加到URDF的默认插件形如:

<gazebo>
  <plugin name="gazebo_ros_control" filename="libgazebo_ros_control.so">
    <robotNamespace>/MYROBOT</robotNamespace>
  </plugin>
</gazebo>

这个 gazebo_ros_control的< plugin>标签有如下可选的子标签:

  • < robotNamespace>: 插件实例所使用的ROS命名空间,默认为URDF中robot的name
  • < controlPeriod>: 控制器的更新时钟,默认为gazebo的时钟
  • < robotParam>: 参数服务器中robot_description的位置,默认为’/robot_description’
  • < robotSimType>:所使用自定义机器人仿真接口的插件名字,默认为’DefaultRobotHWSim’

自定义gazebo_ros_control仿真插件:
这个gazebo_ros_controlGazebo插件为仿真更加复杂机理提供了基于插件的接口来实现自定义Gazebo和ros_control之间的接口。这些插件必须继承gazebo_ros_control::RobotHWSim,它实现一个模拟的ros_control的hardware_interface::RobotHW。RobotHWSim为对Gazebo仿真器的读取和控制关节属性提供API级别的访问。
相应的RobotHWSim子类在URDF模型中指定,并且在机器人模型装载时装载。例如,下面的XML会装载默认插件:

<gazebo>
  <plugin name="gazebo_ros_control" filename="libgazebo_ros_control.so">
    <robotNamespace>/MYROBOT</robotNamespace>
    <robotSimType>gazebo_ros_control/DefaultRobotHWSim</robotSimType>
  </plugin>
</gazebo>

三. 例子
(1)首先在rrbot.xacro中添加< transmission>标签,同时< hardwareInterface>必须包含在< joint>和< actuator>标签中,内容如下:

  <transmission name="tran1">
    <type>transmission_interface/SimpleTransmission</type>
    <joint name="joint1">
      <hardwareInterface>EffortJointInterface</hardwareInterface>
    </joint>
    <actuator name="motor1">
      <hardwareInterface>EffortJointInterface</hardwareInterface>
      <mechanicalReduction>1</mechanicalReduction>
    </actuator>
  </transmission>

  <transmission name="tran2">
    <type>transmission_interface/SimpleTransmission</type>
    <joint name="joint2">
      <hardwareInterface>EffortJointInterface</hardwareInterface>
    </joint>
    <actuator name="motor2">
      <hardwareInterface>EffortJointInterface</hardwareInterface>
      <mechanicalReduction>1</mechanicalReduction>
    </actuator>
  </transmission>

(2)在rrbot.gazebo中添加ros_control插件
内容如下:

  <!-- ros_control plugin -->
  <gazebo>
    <plugin name="gazebo_ros_control" filename="libgazebo_ros_control.so">
      <robotNamespace>/rrbot</robotNamespace>
      <robotSimType>gazebo_ros_control/DefaultRobotHWSim</robotSimType>
    </plugin>
  </gazebo>

(3)创建.yaml配置文件

cd ~/catkin_ws/src
catkin_create_pkg rrbot_control controller_manager joint_state_controller robot_state_publisher
cd rrbot_control
mkdir config
mkdir launch

在config文件下创建一个文件rrbot_control.yaml,内容如下:

rrbot:
  # Publish all joint states -----------------------------------
  joint_state_controller:
    type: joint_state_controller/JointStateController
    publish_rate: 50  

  # Position Controllers ---------------------------------------
  joint1_position_controller:
    type: effort_controllers/JointPositionController
    joint: joint1
    pid: {p: 100.0, i: 0.01, d: 10.0}
  joint2_position_controller:
    type: effort_controllers/JointPositionController
    joint: joint2
    pid: {p: 100.0, i: 0.01, d: 10.0}

保存在yaml的PID增益和控制器设置可以通过launch文件加载到参数服务器中,因此在launch文件夹创建一个rrbot_control.launch文件,内容如下:

<launch>

  <!-- Load joint controller configurations from YAML file to parameter server -->
  <rosparam file="$(find rrbot_control)/config/rrbot_control.yaml" command="load"/>

  <!-- load the controllers -->
  <node name="controller_spawner" pkg="controller_manager" type="spawner" respawn="false"
    output="screen" ns="/rrbot" args="joint1_position_controller joint2_position_controller joint_state_controller"/>

  <!-- convert joint states to TF transforms for rviz, etc -->
  <node name="robot_state_publisher" pkg="robot_state_publisher" type="robot_state_publisher"
    respawn="false" output="screen">
    <remap from="/joint_states" to="/rrbot/joint_states" />
  </node>

</launch>

< rosparam>加载控制器配置文件到参数服务器中;节点controller_spawner通过运行一个python脚本为rrbot启动两个关节位置控制器,这个python脚本会向ros_control控制器管理者(controller manager)请求服务调用,这个服务调用会告诉controller manager你想要的是哪个控制器。同时,这个节点也加载了第三个控制器joint_state_controller,用来发布所有关节的关节状态,相应话题为“/joint_states“。
最后是启动robot_state_publisher节点,接收来自joint_state_controller的话题是"/joint_states",发布的话题是“/tf"。
(4)使用roslaunch启动控制器
首先启动rrbot仿真:

roslaunch rrbot_gazebo rrbot_world.launch

然后给两个关节加载控制器:

roslaunch rrbot_control rrbot_control.launch
  • 手动给控制器发布命令
rostopic pub -1 /rrbot/joint1_position_controller/command std_msgs/Float64 "data: 1.5"
rostopic pub -1 /rrbot/joint2_position_controller/command std_msgs/Float64 "data: 1.0"
  • 使用RQT发送命令
rosrun rqt_gui rqt_gui

在RQT的菜单栏中“Plugins”中点击"Topics->Message Publisher"插件,然后从Topic的下拉框中选择你想要给控制器发布的话题,比如/rrbot/joint1_position_controller/command,设置结果如下(其中i是RQT的时间变量):
在这里插入图片描述
此时Gazebo中的rrbot开始做周期运动:
在这里插入图片描述
在RQT的菜单栏中Plugins->Visualization点击“Plot”,订阅话题“/rrbot/joint1_position_controller/command/data”可以显示发给控制器/rrbot/joint1_position_controller的数据,添加订阅另一个话题“/rrbot/joint1_position_controller/state/process_value”可以显示实际关节运动的状态值,效果如下图:
在这里插入图片描述
通过调节PID参数可以减小关节跟踪误差,而调节PID参数可以通过Plugins->Configuration中的Dynamic Reconfigure插件,如下图:
在这里插入图片描述
(4)利用Riz显示

rosrun rviz rviz

刚打开rviz时会报错,如下图:
在这里插入图片描述
解决方法:将Global Options的Fixed Frame修改为world,就可以在rviz中显示Gazebo里的模型运动状态。
在这里插入图片描述
节点图如下:
在这里插入图片描述
参考:
http://gazebosim.org/tutorials/?tut=ros_control

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

gazebo教程---ros_control 的相关文章

  • 第四章 Opencv图像色彩空间与通道

    文章目录 1 色彩空间1 1 RGB BGR色彩空间1 2 GRAY色彩空间1 3 HSV色彩空间 2 通道2 1 拆分通道 xff1a 96 split 96 方法1 拆BGR色彩空间图像的通道2 拆HSV色彩空间图像的通道 2 2 合并

随机推荐

  • 第五章 Opencv图像的几何变换

    目录 1 缩放图像1 1 resize 方法 2 翻转图像2 1 flip 方法 3 仿射变换图像3 1 warpAffine 方法3 2 平移3 3 旋转3 4 倾斜 4 透视图像4 1 warpPerspective 方法 几何变换是指
  • pip、conda查看镜像源及更换镜像源

    1 查看已经安装过的镜像源 xff1a conda config show channels 查看配置项channels 2 删除镜像源 xff08 清华镜像源 xff09 xff1a conda config remove channel
  • 生成环境下的所有包

    pip freeze span class token operator gt span requirements span class token punctuation span txt 问题 xff1a 将虚拟环境的安装包导出 xff
  • java核心技术卷I

    第三章 xff1a java的基本程序设计结构 文章目录 第三章 xff1a java的基本程序设计结构3 2 注释3 3 数据类型3 4变量3 4 1初始化变量3 4 2常量 3 5运算符3 5 1数学函数与常量3 5 2数值类型之间的转
  • MOT学习笔记 — 行人检测及行人跟踪数据集总结

    1 行人红外数据集总结 xff08 1 xff09 OSU Thermal Pedestrian Database 下载链接 xff1a http vcipl okstate org pbvs bench Data 01 download
  • 使用k-近邻算法识别手写数字

    本文摘自 机器学习实战 案例 xff0c 对其进行了代码更新与注释 实战介绍 使用k 近邻分类器构造手写识别系统 xff0c 为了简单起见 xff0c 系统只识别0 9 xff0c 需要识别的数字已经使用图形处理软件 xff0c 处理成具有
  • ubuntu16.04下安装并使用小觅双目MYNT EYE 1.x SDK

    1 下载MYNT EYE 1 x SDK压缩包 首先 xff0c 点击进入github官网 xff0c 在右上角的搜索栏中输入mynt xff0c 进入如下界面 xff1a 点击第四个slightech MYNT EYE SDK进入 xff
  • UART通用异步收发传输器

    UART 全称Universal Asynchronous Receiver Transmitter xff0c 通用异步收发传输器 xff0c 是一种串行异步收发协议 又称为串口 xff09 功能是将并行的数据转变为串行的数据发送或者将接
  • C语言如何实现输入特定字符串(单词)作为终止符

    本文章以一个例题来进行讲解 xff08 新手第一次写 xff0c 目的仅是分享自己写代码中想到的一些方法和技巧 xff0c 仍存在很多不足 xff0c 希望能对大家有用 xff09 题目要求 xff1a 有一篇文章 xff0c 共有多行文字
  • kubernetes 教程 笔记

    K8s 安装kub ectl 下载kubectl curl LO 34 https dl k8s io release curl L s https dl k8s io release stable txt bin linux amd64
  • ros uwb2world坐标转换python示例

    ros uwb2world坐标转换python示例 span class token comment coding 61 utf 8 span span class token comment usr bin env python span
  • ARUCO marker的解释

    markers for ARUCO 一种汉明 海明 码的格子图 如图 百度百科解释汉明码规则概要 使用奇偶校验 具有一位纠错能力 校验位在2的次幂位置1 2 4 8 16 32 具体参看 https baike baidu com item
  • 使用ros_control ros_controllers 的牛刀真实驱动舵机手臂的源码

    现场 rqt graph 在一个陌生的框架下写代码 xff0c 免不了有很多疑问与槽点 不了解框架结构 xff0c 千头万续 xff0c 无从下手 xff0c 说不清 xff0c 理还乱 资料少没有文档 xff0c 要读懂程序猿的心 xff
  • 经典的pid公式,好脑子不如烂笔头。

    这个算法涉及昨天 xff0c 今天 xff0c 明天 思路就是以史为鉴 xff0c 预测明天 xff0c 改革当前
  • c++对8位灰度图进行二值化处理

    对灰度图进行位二值化 xff0c 输入图像像素部分的宽度和高度以及存储灰度像素值 得一维数组 xff0c 对灰度值进行直方图统计 xff0c 通过OSTU大律法公式 xff0c 确定自动灰度 图的阈值 xff0c 进而进行二值化处理 xff
  • vue 数组常用方法(总结)

    vue 数组常用方法 操作原数组push item pop shift unshift item n splice startIndex endIndex sort reverse 返回新数组slice startIndex endInde
  • 【亲测可用】kali linux 2020.1 设置为中文方法

    目录 0x00 提示0x01 更换更新源0x02 默认语言选择0x03 安装中文字体0x04 重启 xff0c 完成0x05 参考文章 kali 2020 1可用 进入我们的正题 xff0c 修改为中文的步骤 0x00 提示 由于kali
  • QT的TCP应用-传输图片

    1 server h span class token macro property span class token directive hash span span class token directive keyword ifnde
  • gazebo教程---使用roslaunch来启动gazebo,加载models

    1 使用roslaunch加载一个世界模型 roslaunch gazebo ros willowgarage world span class token punctuation span launch 运行效果如图 xff1a 下面看一
  • gazebo教程---ros_control

    一 ros control和Gazebo的数据流向 在Gazebo中模拟机器人的控制器是可以通过使用ros control和一个简单的Gazebo插件适配器来完成 下面是仿真 xff0c 硬件 xff0c 控制器和传动之间关系的概览 xff