美文网首页
3. ROS通信架构

3. ROS通信架构

作者: Janeshurmin | 来源:发表于2019-08-25 21:50 被阅读0次

3.1 master & node

3.1.1 master

功能

  • 每个node启动时向master注册

  • 管理node之间的通信

启动master

roscore

同时启动master(节点管理器)、rosout(日志输出)、parameter server(参数服务器)

3.1.2 node

功能

  • ros进程

  • pkg的可执行文件运行的实例

启动node

rosrun [pkg_name][node_name]

rosnode

常用命令:
rosnode list #列出当前运行的node信息
rosnode info [node_name] #显示某个node的详细信息
rosnode kill [node_name] #结束某个node

roslaunch

roslaunch [pak_name][file_name.launch] #启动master和多个node

3.2 通信方式 —— Topic

包括: Topic、Service、Parameter Service、Actionlib

Topic:ros中的异步通信方式,调用publish()方法立即返回;node间通过publisher-subscribe机制通信,可以有多个publisher和subscribe;

nodeA —— >Topic ——> node B

Topic相当于一个频道,node A向其发送信息,node B向其订阅消息,代码中Topic是字符串,一个Topic可以被多个Node订阅或发送;

Message:topic内容的数据类型/格式标准(相当于类,每次发布的内容就是对象);定义在*.msg文件中


rostopic

rostopic list #列出当前所有topic
rostopic info /topic_name #显示某个topic的属性信息
rostopic echo /topic_name #显示某个topic内容
rostopic pub /topic_name #向某个topic发布内容

rosmsg

rosmsg list #列出系统上所有msg
rosmsg show /msg_name #显示某个msg内容

3.3 通信方式 —— Service

Service:ros中的同步通信方式;node间可以通过request-reply方式通信


srv:Service通信的数据格式;定义在*.srv文件中

文件放在srv路径下,短线上是请求服务的格式,下是服务应答返回的格式,e.g.,检测,后回传数组,可能一次发现很多人,HumanPose必须是msg,定义在msg文件夹下,srv只能嵌套msg,不能再嵌套srv,msg可以再次嵌套msg。


定义完msg和srv后,需要修改package.xml和CMakeList.txt这两个文件,红色字体是需要添加的条目,指定了srv和msg在编译和运行时需要的依赖。


rosservice

rosservice list #列出当前所有活跃的service
rosservice info service_name #显示某个service的属性信息
rosservice call service_name agrs #调用某个service

rossrv

rossrv list #列出系统上所有srv
rossrv show srv_name #显示某个srv内容

3.4 Parameter Server 参数服务器

  • 存储各种参数的字典
  • 维护很灵活,可用命令行,launch文件和node读写

相对于topic和service更加静态,把不常改变的参数和配置放在parameter server中

rosparam

rosparam list #列出当前所有参数
rosparam get param_key #显示某个参数的值
rosparam set param_key param_value #设置某个参数的值
rosparam dump file_name #保存参数到文件
rosparam load file_name #从文件读取参数,yaml格式
rosparam delete param_key #删除参数

3.5 Action

  • 类似service,带有状态反馈的通信方式
  • 通常用在长时间、可抢占的任务中(e.g.,小车导航)

client给service发送请求,执行完请求返回结果,如果执行时间很长,无法使用service,client发布请求后要等待很久才返回结果,client不知道此时在执行还是死机,so需要状态反馈,action可以认为是升级版的service,配有状态反馈

action:action通信的数据格式;定义在*.action文件中

action文件 —— Action通信
srv —— service
msg —— topic

相关文章

  • 3. ROS通信架构

    3.1 master & node 3.1.1 master 功能 每个node启动时向master注册 管理no...

  • ROS通信架构(上)

    Node&Master 在ROS的世界里,最小的进程单元就是节点(node)。一个软件包里可以有多个可执行文件,可...

  • ROS通信架构(下)

    队长与爱人相互七十年不能共舞,蚁人与女儿分隔五年未能相见,钢铁侠邂逅父亲期盼新生,雷神遇见母亲不忍分别。时间会给爱...

  • ROS-Vicon-Crazypony通信

    ROS-Serial-Crazypony通信 从第二次开始学ros到成功进行串口通信,读取vicon数据,再将高度...

  • ros 通信

    在我看来,ROS最牛逼的地方就是它的通信机制了,不仅仅是进程间通信方便,就连不同设备间通信也很方便,只需添加几行代...

  • 通信架构

    . 通信架构通信架构图

  • Android与Ros通信详解-1.概述

    Ros官方支持C++和Python,而为了更好做出显示效果,会用到Android+Ros这种技术架构;Androi...

  • ROS新手指导 1

    1. 安装并配置ROS环境,安装好后,source环境变量 2. 创建ROS的工作环境 3. ROS导航文件系统 ...

  • Ros 系统架构

    系统架构 os层:操作系统。ros是元操作系统,需要依托真正意义的操作系统。目前兼容较好的是Linux的Ubunt...

  • 2.ROS基础-ROS通信编程

    需要一个人有强大的上进心、克制力、自律。克制自己的欲望,希望自己能做到"精进"。 话题编程 创建发布者 创建订阅者...

网友评论

      本文标题:3. ROS通信架构

      本文链接:https://www.haomeiwen.com/subject/cegkectx.html