本文介绍: ROS(Robot Operating System机器人操作系统)操作系统:任何其他软件都必须在操作系统支持下才能运行操作系统用户计算机接口,同时也是计算机硬件和其他软件接口操作系统功能包括管理计算机系统硬件软件数据资源控制程序运行,改善人机界面,为其它应用软件提供支持,让计算机系统所有资源最大限度地发挥作用,提供各种形式的用户界面使用户有一个好的工作环境,为其它软件开发提供必要的服务和相应的接口等。Ros和其他的操作系统最大区别进程之间通信

目录

1.概述

2.名词解释

2.1节点(Node)

2.2节点管理器(Master)

2.3消息(Message)

2.4话题(Topic)

2.5服务(Service)

2.6动作(Action)

2.7消息记录包(Bag)

2.8参数(Parameter)

2.9功能包(Package)和工作空间(workSpace)

2.10功能包清单(Package manifest)

2.11元功能包(Meta Package)

2.12 启动文件(roslaunch)

2.13通信机制

2.14举例理解

3.构架

3.1OS层

3.2中间层

3.3应用层

3.4总结

参考文献


 1.概述

机器人上跑ROS=PC上跑Windows=手机上安卓

ROS(Robot Operating System机器人操作系统)

操作系统:任何其他软件都必须在操作系统支持下才能运行操作系统用户计算机的接口,同时也是计算硬件和其他软件接口操作系统功能包括管理计算机系统硬件、软件及数据资源控制程序运行,改善人机界面,为其它应用软件提供支持,让计算系统所有资源最大限度地发挥作用,提供各种形式的用户界面使用户有一个好的工作环境,为其它软件的开发提供必要的服务和相应的接口等。

Ros和其他的操作系统最大的区别进程之间通信传统操作系统进程之间通信都是要系统调用的,会消耗大量的系统资源。而一个机器人一般由多个传感器相机雷达,等)组成,是通过模块相互沟通交流(自身的位置速度目标的位置,速度等)来完成指定任务。所以进程之间有效快速通信,是一个机器人必备的要求,ros就提供这样的功能

作用ros可以快速完成机器人各个模块之间的通信(分布式计算),可以不同节点中接受和发送信息

 

2.名词解释

2.1节点(Node

      节点就是执行具体任务的进程或独立运行可执行文件,通常一个系统由多个节点组成,节点之间可以通过ROS客户端库(如roscpprospy)相互通信。不同节点使用不同编程语言,可分布式运行在不同的主机。节点在系统中的名称必须是唯一的。节点之间是通过传送消息进行通讯的,一个节点可以多个话题;ROS中,通常来讲我们写的c++程序函数所在的程序称为一个节点;

2.2节点管理器(Master

      节点管理器在系统中主要起到了一个中介作用能够帮助节点相互找到彼此。节点管理器能够为节点提供命名注册服务,以及跟踪记录话题/服务通信。同时节点管理器还提供了一个参数服务器(Parameter Server),节点使用服务器存储检索运行时的参数。

2.3消息(Message

      消息本身是基于发布/订阅模型的话题通信机制而来的,具有一定的类型数据结构,既包含ROS提供的标准数据类型,也可由用户定义数据类型机器人中通常需要传感器,传感器采集到的信息,即这儿的message.(如:位置消息,温度、湿度等)

2.4话题(Topic

      话题通信采用的是一种异步通信机制。话题通信基于发布/订阅模型,数据发布者传输订阅者。其中节点既可以作为发布者发布消息,也可以作为订阅者订阅消息。同一个话题的发布者和订阅者可以唯一,另外一个节点也可以发布或订阅多个消息。一般来说,发布者和订阅者并不知道对方的存在发布者将信息发布在一个全局工作区内,当订阅者发现该信息是它所订阅的,就可以接收这个信息。通常用于数据传输node交换Messages命名总线异步通讯机制传输消息

2.5服务(Service

      服务通信采用的是一种同步通信机制服务通信基于客户端/服务器模型,客户端(Client)发送请求数据(Request),服务器(Server完成处理返回应答数据(Response)。与话题不同的是,ROS中只允许有一个节点提供指定命名服务。通常用于逻辑处理

2.6动作(Action

      动作是基于ROS消息机制实现的一种问答通信机制,基于客户端/服务器模型,服务器可以连续反馈数据客户端客户端可以在任务运行过程中中止运行动作Action的接口主要由goalcancelstatusfeedbackresult组成,客户端可以在任务启动前向服务器发布任务目标goal,也可以在任务过程中向服务器发送cancel请求取消任务服务器客户反馈服务器当前状态,或周期性反馈任务运行监控数据,而result任务运行过程中只发布一次,仅在服务器完成动作后反馈一个最终结果

2.7消息记录包(Bag

      消息记录包是一种用于保存回放ROS消息数据的文件格式。它使用.bag格式保存消息、主题服务和其他ROS数据信息,可以在事件发生后,通过使用可视化工具调用回放数据,检查在系统中到底发生了什么。记录包文件可以像实时会话一样在ROS中再现情景,在相同时间主题发送相同的数据。通常用于调试算法

2.8参数(Parameter

      参数服务器能够保存部分参数作为全局共享字典系统中的所有节点都可以通过网络访问这些共享字典存储检索参数的参数名或参数值,而字典中的数据类型包含int整型float浮点型、string字符串等。参数的存储检索采用的通信机制是更为底层的RPC,而不再是话题或服务。它更适合存储静态、非二进制配置参数,不适合存储动态配置的数据。

2.9功能包(Package)和工作空间workSpace)

      功能包是ROS软件中的基本单元包含节点源码配置文件、数据定义等。

      工作空间用来存放很多不同package的。

2.10功能清单(Package manifest

      功能清单记录了功能包的基本信息,包含作者信息、许可信息、依赖选项编译标志等。

2.11元功能包(Meta Package)

      元功能包是一种特殊的功能包,它只包含元功能包清单文件。它的作用是将多个具有相同功能的功能包整合成一个逻辑上独立的功能包,类似于功能包集合

2.12 启动文件roslaunch

      其目的是一次启动多个节点。

2.13通信机制

      三种通信机制是话题(Topic)通信机制、服务(Service)通信机制和参数(Parameter)管理机制。

2.14举例理解

假设,你和你导师发微信询问课题:

节点(Node):你和你导师,

节点管理器(Master:同时使用微信的人千千万,帮助准确定位你和你导师

话题(topic:课题的名称

消息(message:课题具体内容

消息记录包(Bag):把你和你和你导师聊的课内内容记录下来,方便你回忆

参数(Parameter简单理解,你和导师聊的课题内容,有一些是可以分享给别人(节点)的

发布器(publish:由于你是发信息的,所以你有一个publish发布器,

接收器subscribe:你导师要有有一个subscribe接收器,才能收到信息。

订阅器(subscribe: 但导师必须要订阅你的消息你才能发送成功,怎么算订阅呢?就是你发的topic和她收的topic名字一样。

3.构架

三层

3.1OS层

      ROS并非像Windows、Linux传统意义上的操作系统,无法直接运行在计算硬件上,因此它需要依赖于Linux系统。

3.2中间层

      Linux系统本身没有针对机器人开发中间件,因此ROS在中间层做了大量工作。首先是基于TCP/UDP网络,并在此之上进一步封装构建的TCPROS/UDPROS通信系统。另外ROS还提供了一种进程内的通信方法——Nodelet,为多进程通信提供了一种更为优化数据传输方式。在通信机制之上,ROS提供了大量机器人开发的库,以提供给应用层调用

3.3应用层

      应用层中ROS需要一个管理者——Master,负责管理整个系统正常运行,为节点间建立连接

3.4总结

底层:是操作系统层,

上层:是广大用户编写提供的各种功能不同的软件包比如定位导航,行动规划等等。

中间层(ROS):提供和重新封装底层硬件调用的API,这些重新封装的API称为客户端库,运用这些库可是实现硬件调用,以此实现各种不同的功能,如使用激光雷达扫描生成周围环境的2D地图。ROS框架基于集中拓扑图结构,它的进程(即节点,ROS以节点形式进行通信,以此实现功能)是分布式的,进程分布在各个功能不同的功能包里面
 

参考文献

1.ROS:ROS是什么-CSDN博客
2.从零入门激光SLAM(三)——什么是ROS-CSDN博客

原文地址:https://blog.csdn.net/weixin_48878618/article/details/134752251

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_49453.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注