ROS学习入门笔记(二)ROS核心概念

一、节点与节点管理器

1. 节点(Node)—— 执行单元

  1. 执行具体任务的进程、独立运行的可执行文件;
  2. 不同节点可使用 不同 的编程语言,可 分布式 运行在不同主机;
  3. 节点在系统中的名称必须是 唯一 的。

2. 节点管理器(ROS Master)—— 控制中心

  1. 为节点提供命名和注册服务;
  2. 跟踪和记录话题/服务通信,辅助 节点相互查找,建立连接;
  3. 提供参数服务器,节点使用此服务器存储和检索运行时的参数

在这里插入图片描述

二、ROS通讯方式

1. 话题通信 —— 异步通信机制

1.1 话题(Topic)—— 数据管道
  1. 节点间用来传输数据的重要总线;
  2. 使用 发布/订阅 模型,数据由发布者传输到订阅者,同一个话题的订阅者或发布者可以 不唯一
1.2 消息(Message)—— 话题数据
  1. 具有一定的类型和数据结构,包括ROS提供的标准类型和用户自定义类型;
  2. 使用与编程语言无关的 .msg 文件定义,编译过程中生成对应的代码文件。
    在这里插入图片描述
  • 发布者节点发布话题信息,订阅者即可接收到相关信息,但订阅者无法发送消息给发布者,所以发布/订阅是 单向 通信的模型。
  • 以下为发布者/订阅者模型示例:
    在这里插入图片描述
  • 如上图所示,数据管道称为话题(主题),内部详细的定义称为消息。

2. 服务通信 —— 同步通信机制

  1. 使用客户端/服务器(C/S)模型,客户端发送请求数据,服务器完成处理后返回应答数据;
  2. 使用与编程语言无关的 .srv 文件定义请求和应答数据结构,编译过程中生成对应的代码文件。

在这里插入图片描述

  • 客户端与服务器间可互通消息,所以客户端/服务器是 双向 通信模型。
  • 以下为C/S模型示例:
    在这里插入图片描述

3. 话题与服务的区别

话题服务
同步性异步同步
通信模型发布/订阅服务器/客户端
底层协议ROSTCP/ROSUDPROSTCP/ROSUDP
反馈机制
缓冲区
实时性
节点关系多对多一 (Server)对多 (Client)
适用场景数据传输逻辑处理
  • 为了避免数据错乱,在话题通信模式中尽量只有一个发布者。

三、参数(Parameter)全局共享字典

  1. 参数是可通过网络访问的共享、多变量的字典;
  2. 节点使用此服务器来存储和检索运行时的参数;
  3. 适合存储静态、非二进制的配置参数,不适合存储动态配置的数据。

在这里插入图片描述

四、文件系统

  • 功能包(Pakage)

    ROS软件中的基本单元,包含节点源码、配置文件和数据定义等,用于完成某一特定功能。
  • 功能包清单(Pakage manifest)

    记录功能包的基本信息,包含作者信息、许可信息、依赖选项和编译标志等。
  • 元功能包(Meta Pakage)

    组织多个用于同一目的的功能包。

在这里插入图片描述

  • 多个元功能包组成软件仓库,世界各地人们分享的开源软件仓库组成ROS社区。

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值