极氪软件及电子中心王阳明
ROS是机器人操作系统(Robot Operating System)的英文缩写。ROS是用于编写机器人软件程序的一种具有高度灵活性的软件架构。ROS的原型源自斯坦福大学的STanford Artificial Intelligence Robot (STAIR) 和 Personal Robotics (PR)项目。
机器人的工业界和学术界在软件工具的使用上是有明显的分歧的。由于机器人的工业界并不像消费类电子这样出货量巨大,所以绝对高的技术壁垒和封闭的生态是十分常见的。为了提高自己的技术壁垒,这些公司往往会自己设计一整套封闭的软硬件,以达到让其他人(竞争对手或开发者)无法用自己的工具替换之的目的。而学术界,学生和老师们为了减少重复造轮子的工作,往往会拥抱开源社区,选择现有的工具进行开发和研究,最广为人知的便是ROS(Robot Operating System)
ROS是什么
ROS/ROS 2并不是一个软件,而是一系列软件的集合。一般我们称之为软件解决方案堆栈。包含如硬件驱动程序、网络模块、通信架构和机器人算法实现等等。ROS将所有这些功能包放在一个保护伞下,因此开发人员无需重新造轮子。
ROS并不是一个操作系统,而一般称之为元操作系统,即基于操作系统以上的类操作系统。
ROS并不是一个中间件,因为它实现了包括感知、导航、控制、运动规划和仿真等多种功能。
ROS1.0版本发布于2010年,基于PR2机器人开发了一系列机器人相关的基础软件包。随后ROS版本迭代频繁,ROS的版本一般会随着Ubuntu系统长期支持(LTS)版本而更新,其中ROS目前最新的版本都已经适配到Ubuntu 20.04 LTS。ROS仅在Ubuntu上进行CI测试,但是社区成员积极支持其他Linux版本、Mac OS X、Android、Windows,使得ROS可以兼容,但仅提供有限制性的功能支持。
ROS版本 |
发布时间 |
Ubuntu版本 |
ROS Noetic Ninjemys |
May 23rd, 2020 |
Ubuntu 20.04(Focal) |
ROS Melodic Morenia |
May 23rd, 2018 |
Ubuntu 18.04(Bionic) |
ROS Lunar Loggerhead |
May 23rd, 2017 |
Ubuntu 17.04(Zesty) |
ROS Kinetic Kame |
May 23rd, 2016 |
Ubuntu 16.04(Xenial) |
ROS Jade Turtle |
May 23rd, 2015 |
Ubuntu 15.04 (Vivid) |
ROS Indigo Igloo |
July 22nd, 2014 |
Ubuntu 14.04 (Trusty) |
ROS Hydro Medusa |
September 4th, 2013 |
Ubuntu 12.04 (Precise) |
ROS Groovy Galapagos |
December 31, 2012 |
Ubuntu 12.04(Precise) |
ROS Fuerte Turtle |
April 23, 2012 |
Ubuntu 10.04(Lucid) |
ROS Electric Emys |
August 30, 2011 |
Ubuntu 10.04(Lucid) |
ROS Diamondback |
March 2, 2011 |
Ubuntu 10.04(Lucid) |
ROS C Turtle |
August 2, 2010 |
Ubuntu 9.04(Lucid) |
ROS Box Turtle |
March 2, 2010 |
Ubuntu 8.04(Hardy) |
ROS为我们开发机器人带来了许多方便,然而它也确实存在一些问题:
优点 |
缺点 |
松散耦合的机制提供框架 |
通信实时性能有限 |
丰富的机器人功能库 |
系统稳定性尚不满足工业级要求 |
庞大的用户群体 |
安全性上没有防护措施 |
免费开源 |
仅支持Linux(Ubuntu) |
便利的数据记录、分析、仿真工具 |
核心机制的性能没有优化占用资源 |
ROS已经走过十个年头,伴随着机器人技术的大发展,ROS也得到了极大的推广和应用。尽管ROS还存在不少局限性,但无法掩盖ROS的锋芒,社区内的功能包还是呈指数级逐年上涨,为机器人开发带来了巨大的便利。不少开发者和研究机构还针对ROS的局限性进行了改良,但这些局部功能的改善往往很难带来整体性能的提升,在行业内也积累了大量成熟的应用:
机械臂控制器中领军企业KEBA,他们的控制器已经支持ROS
美国NASA基于ROS开发的Robonaut 2
百度apollo无人车的底层是基于ROS开发的
总体来说,ROS更适合科研和开源用户使用,如果在工业场景应用(例如无人驾驶)还需要做优化和定制,目前ROS已经停止更新,机器人开发者对新一代ROS的呼声越来越大,ROS2.0的消息也不绝于耳。
ROS无法真正进入产业界,也自然无法产品化。为了解决这一问题,社区提出了ROS 2。使得ROS具备产品化的特性,包括实时性、适应于全平台、适用于性能低的硬件(MCU+RTOS)、分布式、数据加密和现代编程语言的支持。
ROS 版本 |
发布时间 |
Ubuntu版本 |
Humble Hawksbill |
May 23rd, 2022 |
TBD |
Galactic Geochelone |
May 23rd, 2021 |
Ubuntu 20.04(Focal) |
Foxy Fitzroy |
June 5th, 2020 |
Ubuntu 20.04(Focal) |
Eloquent Elusor |
November 22nd, 2019 |
Ubuntu 18.04 (Bionic) |
Dashing Diademata |
May 31st, 2019 |
Ubuntu 18.04 (Bionic) |
Crystal Clemmys |
December 14th, 2018 |
Ubuntu 16.04 (Xenial) |
Bouncy Bolson |
July 2nd, 2018 |
Ubuntu 16.04 (Xenial) |
Ardent Apalone |
December 8th, 2017 |
Ubuntu 16.04 ( Xenial) |
为了解决消息间通讯的去中心化和实时性问题,ROS 2引入了Data Distribution Service(DDS),一种已经广泛应用于国防、民航、工业控制等领域,成为分布式实时系统中数据发布/订阅的标准解决方案。如下图所示,左边是ROS 1,右边是ROS 2。
在ROS 1中,用户的每个节点,无论是同一设备还是不同设备,必须已知Master节点的IP,并且全部依赖于Master节点进行通讯,一旦Master节点发生故障或该设备发生故障,则整个环境的所有节点功能尽失。无法恢复。也正因为这一点,ROS 1无法应用于正式的产品。
ROS 2引入了基于DDS的去中心化的数据通讯方式,不同节点可以通过未知IP的方式进行通讯,也进而有助于解决多机器人系统的问题。并且ROS 2也引入了 Quality of Service的机制,通过设定不同的服务质量来保障某些较差网络环境下也可以具备良好的通讯效果。
而对于实时性,由于DDS在诸多工业和产业有诸多应用,具有良好的生态,其性能毋庸置疑。如下图的测试结果:
测试设备为两台PowerEdge R330 e34s
OS: Ubuntu 18.04.2 LTS bionic
Architecture: x86_64
CPU(s): 8
Thread(s) per core: 2
Model name: Intel(R) Xeon(R) CPU E3-1230 v6 @ 3.50GHz
以Fast-RTPS为例,可以看到从延时上,在该双设备间通讯中可以稳定在100μs以下,而吞吐量的带宽也达到了750Mbit/s以上。详细的跑分数据可以参考Fast-RTPS vs Cyclone DDS vs OpenSplice DDS进行了解,且同设备内的通讯效率会远超该结果。
ROS 2在DDS的基础之上引入了SROS的概念,设计文档参考ROS 2 DDS-Security integration,即所有的ROS 2消息均可通过SROS进行加解密、鉴权、授权控制、Log和数据标记的权限控制等。基于ROS 2的原本设计逻辑,我们甚至可以将数据的密钥生成和存储放到ARM TEE OS中,以实现较高安全的数据保证
由于ROS 1的最初发行版在2007年,长期以来的支持和众多开发库的支持导致很多语言的新特性并不能良好地应用。比如对于Python,直至2020年发布的Noetic版本中才首次支持了Python 3,而Python 2在2020年1月便已经停止进行支持了。再如C++,ROS 1是基于C++ 03实现的,对于C++ 11的支持并不好,更不用谈C++ 14和C++ 17的支持。
ROS 2则完全支持Python 3,并基于现代C++编写。并基于其松耦合的方式,还支持Java和Rust等编程语言。如下图User Application下面那一行所示,只要开发者愿意,可以支持任何编程语言。
灵活的机制
ROS 2提供了一种基于生命周期的管理模式, 即每个节点的运行状态是完全可控的。参考设计文档Managed nodes的阐述。所有Managed节点都可以在运行时进行实时配置、管理、关闭和启动,并在出错时可以由管理节点进行唤醒和重置。这种方式保证了整个系统的稳定性和鲁棒性,也提高了系统出错后恢复到正常的能力。
ROS 2在运行时可以更换DDS中间件,也可以在不同DDS中间件的实现间进行通讯。
ROS 2在Ericsson的推动下,正在商讨5G的ROS 2通讯方案的制定和实现。
继承ROS 1广博的开源生态资源,ROS 2的发布激起了大家对于ROS产品化的热情,许多公司都向ROS 2贡献方案和代码,包括但不限于Intel、NVIDIA、Ericsson等。
除了贡献新的代码,ROS 1的优秀工具也都被完全继承到ROS 2里,如Moveit、Rviz和rosbag等。并且有些模块,如navigation(导航),在开发者的改进中升级为navigation2,改善了诸多问题,提高了使用的便利性。
ROS 2 Topic通讯节点和节点之间进行通讯的桥梁,节点可以同时发布和接收话题,节点和话题之间是多对多关系
Service(服务)是ROS图上节点通信的另一种方法,服务基于呼叫响应模型,而不是主题的发布者-订阅者模型。服务端和客户端之间,是一对一或一对多关系
Action是ROS 2中用于长时间运行任务的通信类型之一,它们由三部分组成:目标,结果和反馈
美军投资的Ghost Robotics,其四足机器人使用了Eloquent版本的ROS 2进行开发,DDS方案选用的是商用的Cyclone DDS
Mission Robotics的水下机器人(ROV),使用了Foxy版本的ROS 2进行开发
汽车产业真正的革命已经开始,软件定义汽车的时代已经到来。汽车正加速从从机械设备向高度数字化、信息化的智能终端转变,涉及领域庞大并且复杂。一辆自动驾驶的汽车,从某种意义上来说,也是一个自动驾驶的机器人,理所当然的可以是使用ROS 2进行开发,ROS 2提供了大量基础组件,大大便利了包括导航算法、自动驾驶算法和一些AI算法的部署。当然ROS 2仍然有很多缺陷,ROS 2的调度模型无法抢占,有时候优先级高的调度实例可能被低优先级的调度阻塞,还没有一家汽车行业公司利用ROS 2将产品落地。
面对这些挑战,极氪的软件及电子中心大胆尝试,基于ROS 2的通讯框架和平台架构,进行基于SOA架构的汽车操作系统的开发,并且取得不错的测试效果。极氪的软件及电子中心的在一直在前沿技术方面做深入探索,致力于打造ZEEKR OS整车操作系统,也欢迎各位有志之士加入我们,共同探索下一代汽车操作系统。