0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

智能汽车中机器人操作系统的解析

智能汽车电子与软件 来源:焉知智能汽车 作者:一骥绝尘 2022-10-28 15:39 次阅读

ROS智能驾驶

ROS全称Robot Operating System,直接翻译就是机器人操作系统。虽然名字里含有“操作系统”的字眼,但ROS与Windows和Linux等操作系统不一样,它实际上是一套软件库和工具,可以帮助用户快速建立机器人应用程序。在软件层面上,ROS是一种中间件。什么是中间件?中间是相对的,有“上”和有“下”的时候就有“中间”。这感觉就像是“中产阶级”,没有严格界限。所以在有上层软件和底层软件的语境下,这中间的软件就是“中间件”。ROS就是介于底层操作系统(如Linux)和上层业务应用软件(如OpenCV)之间的中间件。

那么ROS能出现在焉知智能汽车的公众号里,它跟智能汽车又有什么关系呢? 实际上智能汽车就是一种机器人。举个例子,您有没有觉得家里的扫地机器人和智能驾驶汽车非常像?近年来,智能驾驶无疑是汽车工业的当红炸子鸡,而汽车的智能驾驶化实质上也是汽车的机器人化。我们常说的“感知”、“决策”和“规控”等,其实也是来自于机器人领域。智能网联汽车的功能域控制器划分,电子电气架构的演变都能或多或少看到机器人的影子。甚至有些公司就是借用机器人传统术语来作为传统车企智能化改革的口号和产品蓝图。

机器人是多专业知识交叉的学科,通常涉及传感器、驱动程序、多机通信机械结构、算法等,为了更高效地进行机器人的研究和开发,选择一个通用的开发框架非常必要。而ROS就是最流行的框架之一。当机器人和智能驾驶汽车一相逢,ROS顺理成章的成了很多团队开发智能驾驶的选择,很多智能驾驶的算法应用都是基于ROS来开发的。中国智能驾驶界大名鼎鼎的“Apollo”就是基于ROS二次开发改进的。而从另一个角度来看,近年来ROS也成为了智能网联工程师岗位招聘要求的高频词。熟练掌握ROS的汽车工程师毫无疑问是人才市场上的“香饽饽”。

02 ROS历史简介

首先提一下,ROS有ROS1和ROS2两个大分支。没有特别说明时,一般ROS都指ROS1。简单来说ROS由来已久,进化过程中发现已有架构必须革新才能满足更多需求,于是就开辟了ROS2,并把之前的版本统称ROS1。

展开来看,ROS系统最早起源于2007年斯坦福大学人工智能实验室的STAIR项目与机器人技术公司Willow Garage的个人机器人项目(Personal Robotics Program)之间的合作,2008年之后由Willow Garage公司推动其发展。几番测试后于2010年推出了正式发行版本:ROS Box Turtle。比较有趣的是,ROS各版本均以龟作为发行代号,至今已设计出十多种造型奇特的“ROS龟”。而每一次ROS发布新版都会按照字母顺序改一个名字。例如ROS Box Turtle后是ROS C Turtle,再是Diamondback……2020年5月发布的ROS Noetic Ninjemys则到了字母“N”,也是ROS1的最后一个版本。

图2:4个ROS版本及其ROS龟海报

从2008年至2013年,ROS主要由Willow Garage公司管理维护,但这并不意味着ROS是封闭的系统。相反,ROS由众多学校及科研机构联合开发及维护的,这种联合开发模式也为ROS系统生态的构建与壮大带来有力的促进。2013年,Willow Garage公司被Suitable Technologies公司收购,此前几个月,ROS的开发和维护管理工作被移交给了新成立的开源基金会Open Source Robotics Foundation。而随着ROS的优化和丰富,对ROS的要求也越来越多,一些原始架构和设计已经不能够满足,于是催生了ROS2。经历几个测试版后,2017年ROS2正式发布了Ardent Apalone版本,之后每版升级同样是迭代一个字母和ROS龟海报。最新一版ROS2是今年5月份刚发布的Humble Hawksbill。

03 为什么智能汽车选择ROS

上文提到,智能驾驶汽车就是一种机器人。但是当智能汽车选择开发框架的时候,为什么会这么多人选择ROS呢?肯定不是因为它的名字里有“Robot”这么简单。而结合上文提到的ROS1和ROS2时间线,这个关于智能驾驶的选择肯定在ROS1上开始的。究其原因,有这3个重要因素:

1.已有的开源代码丰富。

许多智能驾驶需要用到的算法,都能在ROS生态中找到已经成熟的代码。例如建立地图的算法,使用激光雷达或GPS定位算法,沿着地图规划路径算法,避开障碍物的算法,摄像头视觉处理算法等等。..。..这些轮式机器人导航所需的算法在ROS上是现成的,几乎都可以直接适用于智能驾驶汽车。

2.具备配套的可视化工具。

ROS自带一套图形工具,可以方便地记录和可视化传感器捕获的数据,并以全面的方式表示车辆的状态。此外,它还提供了一种简单的方法来实现定制化的可视化需求。这在开发控制软件和调试代码时非常有用。如果您曾经在电脑前看过智能驾驶汽车传感器的原始数据,做过调试,相信您会深刻理解一个靠谱的数据可视化工具是有多么重要。

图3:利用ROS RVIZ三维可视化点云数据

3.简单好上手。

在开展一个新领域的时候,没有什么比把东西先做出来更重要了。基于ROS来开发一个智能驾驶汽车项目是比较简单的。例如从一个简单的轮式机器人开始,配备一对轮子、一个摄像头、一个激光扫描仪和ROS导航软件栈,开发者可以在几个小时内就可以完成设置,让小车自主行进避障。这种快速上手也可以帮助新手快速理解整个运作基础和框架,然后再转向更专业更深入的研究。某宝上就有很多基于ROS的智能小车,很多机构也是基于这些套件开展智能驾驶培训的。

04 ROS1在汽车应用上的弱点

当然,ROS并不是完美的,尤其是ROS1应用在智能汽车上存在不少局限性。早年间ROS1应用于智能驾驶研发时,正是由于这些局限性,各大公司都需要在ROS上进行二次开发,以满足智能汽车要求。那ROS1究竟有哪些弱点呢?

1.单点失效。

如下图所示,ROS1的通讯机制是存在主从结构的。也就是节点之间的通讯都依赖于一个Master。在这种集中式通讯方式下,如果Master失效了,那么系统就会崩溃。这在汽车行业功能安全的要求下,无疑是太脆弱了。

图4:ROS1通讯机制示意图

2.实时性差。

ROS1就是基于Linux操作系统之上的。Linux原生不是实时操作系统,ROS1自然也没有实时性的设计考虑。ROS1设计之初更多地从实现最高性能的角度出发,在任务调度和线程切换等机制设计上并没有保证实时性所要求的“确定时间”。例如汽车动力底盘域常见的轮速信号就很容易在原生ROS1中失真。

3.缺乏网络安全机制。

ROS1并没有实现任何安全机制来防止第三方进入ROS1网络并读取节点之间的通信。这意味着任何能够进入汽车网络的人都可以进入ROS1的信息传递并劫持汽车。这在汽车网络安全法规日益严格的背景下,也无疑是力不从心的。

05 ROS1与ROS2

早年间,各大公司都针对ROS1弱点做了很多优化,以让其适用于汽车。而这些研究和改进当然也反馈到ROS组织本身,所以也就有了上文提到的ROS2。那么ROS1和ROS2有什么差别呢?ROS2对这些弱点有改进吗?话不多说,我们先来看看两者的系统架构框图对比。

图5:ROS1和ROS2的系统架构框图对比

由下往上看,在操作系统层,ROS2比ROS1支持的底层操作系统更多,也支持实时操作系统(RTOS)了。这就让ROS2可以支持更多样化的嵌入式硬件,例如汽车应用中一些轻量化的ECU。

在中间层,ROS1更多地依赖TCP和UDP协议,而在ROS2中则引入了DDS。DDS全称是Data Distribution Service 数据分发服务,是一种分布式实时通信中间件协议,也是一个被很多公司实现的工业标准。DDS采用发布/订阅体系架构,强调以数据为中心,提供丰富的服务质量(QoS)策略,以保障数据进行实时、高效、灵活地分发。

正是基于DDS的通讯机制,ROS的应用层就不再需要Master节点。节点之间采用自发现机制,找到彼此,进而建立稳定的通信连接。这对于满足功能安全需求,有很大帮助。当然,ROS1和ROS2的应用层软件接口是匹配的,让ROS1上开发的应用软件能快速复用部署到ROS2上,也是ROS2的设计目标。

由此可见,上文提到的ROS1在汽车应用上的弱点,在ROS2上都得到了针对性甚至是根本性的改善。

06 ROS与AUTOSAR Adaptive

在汽车领域谈软件,自然是离不开AUTOSAR的。这些年汽车硬件和软件的发展本身也是日新月异。AUTOSAR也是在这背景下不断优化和自我革新,AUTOSAR Adaptive就是针对多核动态操作系统的高资源环境在奋起直追,希望站稳汽车软件架构老大的地位。ROS2和AUTOSAR Adaptive都是中间件,那它们在不断升级进化的过程中,有没有朝着某个共同的方向,进而出现交汇点?答案是有的。最明显的就是DDS的通讯机制。

图6:DDS在AUTOSAR Adaptive通讯中的位置

如上图所示,AUTOSAR Adaptive中的通讯管理模块就加入了DDS的部分,并对DDS相应的功能安全和网络安全都作了定义和描述。通过ara::com可以统一CAN PDU、SOME/IP和DDS的通讯。而DDS就是ROS2中最核心的部分。所以聚焦于这个汇合点,可以结合ROS2和AUTOSAR,取两者之所长。

事实上这个关键点已经被很多公司企业抓住,并开发出了不少商用的产品。例如下图就是Apex.AI公司的产品示意图。Apex.AI将Apex.OS节点(匹配ROS节点)与AUTOSAR Adaptive和AUTOSAR Classic平台连接起来。AUTOSAR arxml(包含数据类型和接口的描述)可以直接作为配置输入。这使得设置可以灵活应对服务定义的变化。ROS Topic的数据最终可以在AUTOSAR ara::com或RTE中使用。

图7:Apex.AI公司统一ROS和AUTOSAR的产品示意图(来源:Apex.AI)

07 写在最后

智能汽车的发展是个复杂而又漫长的过程,期间需要不断的技术迭代和功能创新。对于个体开发人员来说,站在巨人的肩膀上来迎接这过程中的挑战十分重要。ROS(尤其ROS2)就是其中一个巨人肩膀。希望本文能为之前没接触ROS的同仁提供一个初步印象,有所帮助。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 机器人
    +关注

    关注

    211

    文章

    28390

    浏览量

    206957
  • 操作系统
    +关注

    关注

    37

    文章

    6808

    浏览量

    123291
  • 智能汽车
    +关注

    关注

    30

    文章

    2844

    浏览量

    107258

原文标题:简介汽车上的机器人操作系统(ROS)

文章出处:【微信号:智能汽车电子与软件,微信公众号:智能汽车电子与软件】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    【「具身智能机器人系统」阅读体验】+初品的体验

    《具身智能机器人系统》 一书由甘一鸣、俞波、万梓燊、刘少山老师共同编写,其封面如图1所示。 本书共由5部分组成,其结构和内容如图2所示。 该书可作为高校和科研机构的教材,为学生和研究人员提供
    发表于 12-20 19:17

    《具身智能机器人系统》第1-6章阅读心得之具身智能机器人系统背景知识与基础模块

    、谷歌的RT系列等前沿产品展露锋芒。这些突破性成果标志着AI正从虚拟世界迈向物理世界的深度交互。 而研读《具身智能机器人系统》前六章,我对具身智能
    发表于 12-19 22:26

    【书籍评测活动NO.51】具身智能机器人系统 | 了解AI的下一个浪潮!

    。 这些技术的综合应用使具身智能系统能够进行复杂的环境感知、决策制定和物理操作。例如,通过多模态感知技术,智能体能够综合视觉、 听觉和触觉数据,更全面地理解和响应其所处的环境。 具身
    发表于 11-11 10:20

    什么是嵌入式操作系统?

    什么是嵌入式操作系统? 想象一下,如果一个智能设备,比如你口袋里的智能手机,是一个有头脑的机器人,那么嵌入式操作系统(Embedded Op
    发表于 11-08 15:07

    开启全新AI时代 智能嵌入式系统快速发展——“第六届国产嵌入式操作系统技术与产业发展论坛”圆满结束

    嵌入式系统是电子信息产业的基础,是智能系统的核心。大模型催生AI走入千家万户、唤醒端侧AI的需求爆发。以机器人、无人驾驶和智能制造为代表的
    发表于 08-30 17:24

    第六届国产嵌入式操作系统技术与产业发展论坛议程发布

    每年一度的国产嵌入式操作系统论坛即将在杭州滨江举办,今年是第六届了,又是中国嵌入式系统新朋老友相聚的时刻。大模型催生AI走人千家万户、唤醒端侧AI的需求爆发。以机器人、无人驾驶和智能
    发表于 07-26 10:54

    ROS让机器人开发更便捷,基于RK3568J+Debian系统发布!

    本帖最后由 Tronlong创龙科技 于 2024-7-19 17:18 编辑 ROS系统是什么 ROS(Robot Operating System)是一个适用于机器人的开源的元操作系统。它
    发表于 07-09 11:38

    编码器在机器人系统的应用

    随着科技的飞速发展,机器人技术已广泛应用于工业、医疗、服务等多个领域。在机器人系统,编码器作为核心的位置和速度检测装置,发挥着至关重要的作用。本文将从编码器的原理、分类及其在
    的头像 发表于 06-13 14:51 815次阅读

    基于FPGA EtherCAT的六自由度机器人视觉伺服控制设计

    和增强系统处理图像的实时性,本文提出了一种伊瑟特的六自由度机器人视觉伺服控制系统,将摄像头集成到基于 Zynq的伊瑟特主站上,提高了视觉伺服的实时性.经测试,该平台能够对视觉检测目标的变化做出及时的反应
    发表于 05-29 16:17

    基于飞凌嵌入式RK3568J核心板的工业机器人控制器应用方案

    的主要作用是完成多轴运动的计算与控制,因此机器人控制器的主控就需要拥有高性能的CPU、内置实时操作系统、支持EtherCAT工业总线以及丰富的功能接口。 机器人控制器 基于以上需求,飞凌嵌入式
    发表于 05-11 09:40

    其利天下技术·搭载无刷电机的扫地机器人的前景如何?

    重要因素,如何提高电池效能和减少充电时间,是行业亟待解决的问题,此外还有噪音、智能控制等问题也需要重视。 在客户体验方面,扫地机器人还存在一些主要问题。例如,部分机器人在清洁过程可能
    发表于 05-05 15:03

    基于鸿道(Intewell®)操作系统研发的农业机器人操作系统

    江苏大学与科东软件联合研发“农业机器人操作系统”,并成立“农业机器人操作系统”联合实验室,奋力推进农业智能化,推动农业科技创新。“农业
    的头像 发表于 04-30 11:09 423次阅读

    工业控制:鸿道(Intewell)操作系统工业机器人控制解决方案

    鸿道(Intewell)操作系统作为核心基础软件,构建机器人控制系统的底层技术平台。系统支持Linux/Windows的实时扩展,设备上可同时运行单个非实时
    的头像 发表于 03-14 10:19 533次阅读
    工业控制:鸿道(Intewell)<b class='flag-5'>操作系统</b>工业<b class='flag-5'>机器人</b>控制解决方案

    具身智能移动操作机器人发展与研究

    多模态感知技术能够使具身智能移动操作机器人实现更高的自主性、高效性、通用性,增强对周围环境的局部感知能力,并为机器人提供丰富、稳定、准确的环境数据。
    发表于 03-12 11:38 687次阅读
    具身<b class='flag-5'>智能</b>移动<b class='flag-5'>操作</b><b class='flag-5'>机器人</b>发展与研究

    人形机器人第一股优必选科技成功登陆香港主板

    自2012年成立以来,优必选已成为全球人形机器人产业的领先者,专注于人形机器人的研发和应用。在此过程,优必选掌握了包括机器人技术和人工智能
    的头像 发表于 01-02 14:59 742次阅读