你好,我是辰chen,本文旨在准备考研复试或就业
本文内容是我为复试准备的第二个项目
欢迎大家的关注,我的博客主要关注于考研408以及AIoT的内容
预置知识:基本Python语法,基本linux命令行使用
以下的几个专栏是本人比较满意的专栏(大部分专栏仍在持续更新),欢迎大家的关注:
ACM-ICPC算法汇总【基础篇】
ACM-ICPC算法汇总【提高篇】
AIoT(人工智能+物联网)
考研
CSP认证考试历年题解
生活中的应用:
工业应用:
ROS元老机器人 – PR2:
NASA 将机器人部署到空间站:
智驾成为汽车核心卖点之一:
轮式机器人:
• 传感器:机器人的感官,决定了能获取到哪些外部信息。类比人的视觉、触觉、听觉等。
• 算法和逻辑:内部的数据处理。比如用深度学习算法识别物体、传感器融合定位、业务逻辑等。
• 执行器:机器人向外的输出,决定了能完成哪些任务。类比人的手、脚、语言、动作等。
• 机器人是复杂系统,包含一系列协同工作的软件硬件。各个传感器、算法、业务逻辑、执行器之间,有复杂的依赖关系。
机器人开发的难题
ROS的作用-提高软件复用
点对点的设计:
• 分布式的节点单元
• RPC + TCP/UDP 通信系统
• 支持多机器协同(分布式系统)
• 各个节点独立编译、启动
远程过程调用(英语:Remote Procedure Call,RPC)是一个计算机通信协议。该协议允许运行于一台计算机的程序调用另一个地址空间(通常为一个开放网络的一台计算机)的子程序,而程序员就像调用本地程序一样,无需额外地为这个交互作用编程(无需关注细节)。
点对点的设计是ROS中最重要的一个概念,其中关键在于节点。一个系统可能由多个节点构成,我们可以理解成每一个程序都是一个节点,或者说每一个主函数都是一个节点,节点之间是相互独立的,节点和节点之间,不一定运行在同一个物理机器上,它可以是一个分布式的系统,对于分布式系统而言,通信就是重中之重。如上图所示,有三大块,代表着不同的设备:用户电脑,服务器,机器人;其中每一个椭圆都代表着一个节点,他们是可以跑在不同的电脑上的。
比如我给出一个导航任务,简单说明其部分运作流程:在我们的用户电脑上运行一个节点,这个节点用来获取用户的输入,比如输入一个坐标,这就是这个节点的作用,当我们获得了这个输入之后,我们可以把该坐标传递给下一个节点,也就是进行节点间的通信,如上图所示,下一个节点为路径规划算法,它拿到了坐标之后还不够,还需要地图,地图服务器也就另一个节点,这两个节点就不是运行在用户电脑上了,而是运行在服务器上,它们之间就是网络通信,所以即便不在一个机器上,我们也可以通过网络来进行协同的工作,也就是运行在一个分布式系统中。
简而言之,可以理解成为各自都有一个主函数,各自是独立运行的,它们都会去遵循同一个通讯协议,所以说它们之间能够传递信息。这就是ROS的点对点设计。
多语言支持:
• 支持 Python,C++,Java等语言
• 提供语言无关的数据接口定义
所谓语言无关,如上图所示,它是一个Image(图像)的数据格式,我们知道,在cpp中,如果要存储一个图像,可以用数组或者vector来存,但这些东西在Python中是没有的,所谓语言无关的数据定义接口,就是更为抽象的一层,就是用它来标识我这个图像里面有何种信息。
比如上图中有图像的高度、图像的宽度…并且也说明了信息是哪种数据类型,如 uint32, string, uint8...
,但这些数据类型并不是具体的某一种语言里面的数据类型,而是ROS提供的一种语言无关的数据类型,在之后编译中会根据不同的语言转换成为对应语言的相应数据类型,ROS帮我们实现了其中的数据转换
丰富的工具包:
• 3D数据可视化:Rviz
• 物理环境仿真:Gazebo
• Qt可视化工具箱:rqt_*
ROS机制-计算图
• 节点:软件模块,可以订阅/发布 Topic,调用/创建 Service
• ROS Master:控制中心,整个系统有且只有一个。负责链接各个节点、管理参数等
• Topic:异步通信,传输消息
• Service:同步通信,类似函数调用
我们说过,最重要的就是点对点通信,这是如何实现的呢?下作介绍:
先来补充一个概念:计算图,上面提到的图:
也可以看做成一个计算图。
下面我们拿下图举例:
该图中的每一个椭圆都是ROS rqt_*的工具箱自动生成的,一些节点之间的通信关系可以自动的生成这样的图来给我们查看,每个椭圆都是一个节点,一个箭头就代表着他们之间有一个消息的通信。
已经讲过,每一个椭圆都代表着一个节点,每一个节点都可以订阅或者发布一个 Topic,也可以调用或者创建一个 Service,下面分别介绍 Topic 与 Service:
Topic 和 Service 都是节点之间的通讯方式
• Topic:
是一种传输信息的异步通信
Publisher就是Topic的发布者,如上图所示,Topic的名字(example),它会有一个数据类型(String),这里就是语言无关的数据类型,它会有一些 Subscriber 也就是接收者(可以有多个接收者),这些接收者只需要订阅了名字为 example 的这个 Topic,它就与 Publisher 建立连接了,此后 Publisher 每次发送消息,Subscriber 都会收到,即其实是一个单向的连接,该连接是异步的,也就是 Publisher 发出去就发出去了,至于 Subscriber 收到与否,处理速度的快慢,有没有及时收到,都不会给 Publisher 进行反馈,类似一种广播。
• Service:
类似函数调用,是一种同步通信
和我们请求服务器一样,它有一个 Service Server,有一个 Service Client,Client 发送请求,然后 Server 再返回请求,是一个同步的通信模式。
ROS机制-Topic
• 指定名称和数据类型
• 创建流程
• 一个 Topic 可以有多个发布者,也可以有多个订阅者。如多个节点都可以向“警告” Topic 发布信息;定位节点和路径规划节点同时订阅“地图”Topic
• 同一个 Topic 的所有发布和订阅,都要用同一种数据类型
继续介绍一下建立一次 Topic 的通信流程:
首先,我们要指定这个 Topic 的名称和数据类型,这两个是必须要定义的,假设有一个 Talker 一个 Listener,其实就是上述中的 Publisher 和 Subscriber,它们会向 ROS Master 进行注册,也就是上述的全局唯一的控制节点,Talker 会告诉 Master,现在想要接收一个 Topic 并且告诉这个 Topic 叫什么以及数据类型是什么,Master 会记住这些信息,当它收到 Listener 向它发布的请求,即想要获得哪个 Topic 的时候,如果 Topic 已经存在,如已有一各 Talker 发布了,Master 会把 Talker 的信息发送给 Listener,此时 Listener 就知道了 Talker 的信息,如知道了 Talker 的 IP 地址,端口号是什么,Listener 就可以主动地去联系 Talker,告诉我要订阅你发布的 Topic,同时 Talker 也会记下来 Listener,这样下一次 Talker 发布数据的时候就会直接把数据传递给 Listener。对于同一个 Topic,所有的发布和订阅都必须用同一种数据类型,不然的话就会报错:Master 会告诉你,这个 Topic 不是这个类型的,并拒绝你的请求。
每个 Topic 可以有多个发布者 Talker(Publisher),也可以有多个订阅者 Listener(Subscriber),多个订阅者是比较常见的,举一个多个发布者的例子:系统中可能有一个 Topic 叫警告,触发警告可能有多种:温度过高,速度过快…,有的节点是用来测量温度的,有的节点是用来测量速度的,那么这些节点都可以向警告这个 Topic 发布信息。
多个订阅者的例子:比如 地图Topic,它可以同时被定位和路径规划的节点所订阅。
ROS机制-Service
• 指定名称和 Service 类型,Service 类型中指定了调用数据类型和返回数据类型
• 调用流程
首先也是要指定,指定名称和 Service 类型,注意 Service 类型,因为它是有来有回的,一次调用就是一个过程,不像 Topic,只要建立了连接,每一次talker有新的数据,都会发送给 Listener(Topic :假如 talker 是一个摄像头,帧率是三十帧每秒,那么一旦有了一个 Listener,就会以每秒 30次的速率向 Listener 发送信息;Service :只是一次调用过程)
一个调用的数据类型就类似于函数的一个参数,与此还会有一个返回数据类型即返回值,这两个一起组成了一个 Service 类型
调用流程与 Topic 类似,首先是注册,Talker 也就是 Service Server,Listener 也就是 Service Client,它们在创建的时候都需要向 Master 注册,Master 就会记住,谁定义了哪个 Service,谁要请求哪个 Service,当有请求的时候,Master 会向 Listener 发送 Talker 的信息,Listener 就知道了 Talker 的信息,就可以直接和 Talker 建立通信,来完成一次请求。
可以把 Service 类比为函数调用,一次调用就是传入一次参数,返回一次数据。Service 主要作用并不是传递数据,而是触发/调用某些逻辑之类的作用
话题 Topic | 服务 Service | |
---|---|---|
同步性 | 异步 | 同步 |
通信模型 | 发布/订阅 | 服务器/客户端 |
底层协议 | ROSTCP/ROSUDP | ROSTCP/ROSUDP |
反馈机制 | 无 | 有 |
缓冲区 | 有 | 无 |
实时性 | 弱 | 强 |
节点关系 | 多对多 | 一对多(一个 Service Server) |
适用场景 | 数据传输 | 逻辑处理 |
ROS机制-参数
ROS机制-文件系统
•xxx_ws:工作空间根目录,项目的基本单位
•xxx_ws/src:各种代码存放位置,我们只需要修改src中的文件
• xxx_ws/build 和 xxx_ws/devel:编译生成的文件夹,存放目标文件、依赖项等,开发时一般不用管
• src中每个功能包:
命令 | 作用 |
---|---|
catkin_create_pkg | 创建功能包 |
rospack | 获取功能包的信息 |
catkin_make | 编译工作空间的功能包 |
rosdep | 自动安装功能包依赖的其他包 |
roscd | 功能包目录跳转 |
roscp | 拷贝功能包中的文件 |
rosed | 编译功能包中的文件 |
rosrun | 运行功能包中的可执行文件 |
roslaunch | 运行启动文件 |
加 -h 参数查看帮助,如 rosrun -h
上述所有内容出处如下,博主在此基础上仅为添加个人理解:
本项目为北大团队出品【项目三:深度学习&仿真机器人 - 丘丘老师】原创(部分代码为开源代码)。课程团队:B站ID【M学长的考研top帮】UID【3546580235848566】复试项目班QQ大群:885884619,负责人QQ:674799975