原文链接:进阶课程㉒丨Apollo规划技术详解——Motion Planning with Autonomous Driving

自动驾驶车辆的规划决策模块负责生成车辆的行驶行为,是体现车辆智慧水平的关键。规划决策模块中的运动规划环节负责生成车辆的局部运动轨迹,是决定车辆行驶质量的直接因素。

在大多数情况下,运动规划问题的精确解决方案在计算上是难以处理的。 因此,数值近似方法通常在实践中使用。在最流行的数值方法中,变分方法将问题视为函数空间中的非线性优化,图形搜索方法构建车辆状态空间的图形离散化并使用图形搜索测量方法搜索最短路径,此外基于树的增量方法,从车辆的初始状态逐步构造可到达状态的树,然后选择这种树的最佳分支。

上周阿波君为大家详细介绍了「进阶课程㉑Apollo规划技术详解——Basic Motion Planning and Overview」。

通过介绍了基本的运动规划概述,其中详细的介绍了如何构建汽车的运动规划问题,其中包括路径查找问题路径优化,可以通过A-Star算法、D-Star算法对路径搜索进行优化,通过曲线平滑的方式来优化折线。除此之外,还简单的介绍了无人驾驶的硬件系统和系统软件。

本周阿波君将与大家分享Apollo规划技术详解——Motion Planning with Autonomous Driving。下面,我们一起进入进阶课程第22期。


目录

1 - 运动规划基本方法

2 - 运动规划框架

2-1 RRT(基于快速扩展随机树算法)

2 - 2 Lattice网格方法

2 - 3 Polynomial方法

2 - 4 Functional Optimization方法


1 - 运动规划基本方法

本节主要介绍运动规划的一些基本方法,重点从robotics的角度阐释。这些方法主要有RRTLatticeSpiraPolynomialFunctional Optimization等,如下图所示。

运动规划方法

前面讲到决策规划问题,都是从质点模型出发考虑。质点模型将运动轨迹当成一个点,这个点和无人车是不一样的。假设把一个无人车看成一个点,这个点和另一个点不相撞,在数学定义上是点和点没有交集,但是在实际生活中一个车和一个车可是会相撞。下面介绍解决这些问题的一些方法:Configuration Space (构造空间),也就是说能够控制什么变量。对于刚体而言,不仅是XY坐标,还要有heading信息才能研究跟障碍物之间的关系。对于无人车来说有更多的变量。其复杂性主要体现在两个方面,一个是Space Dimensionality(空间维度),另一个Geometric Complexity(几何复杂性)。例如bounding box跟bounding box之间怎么相交,一个多面体跟一个多面体之间怎么检测出路径,以避免跟另一个障碍物相交。

                                                                                                ​​​​​​​        构造空间方法

规划问题中涉及到一些约束条件,Constraints(约束)大概分为三类:一个是Local Constraint,例如避免和障碍物碰撞。第二是Differential Constraint,比如边界曲率。最后是Global Constraint。比如最短路径。


2 - 运动规划框架

运动规划是在连续空间的一种优化,对于连续空间过程的优化往往比较难。因此,通常先将连续空间问题离散化表示,然后寻找对应的解决方案。如下图所示,可以使用图搜索的方法对离散空间问题进行求解。

那么,如何去离散化连续空间呢?有种方法叫做Roadmap,这个方法使用简单的连通图表示配置空间,类似于城市如何用地铁图表示。其中Visibility Graph是一种常用的Roadmap方法,如下图所示。Visibility Graph将起始节点,所有障碍物的顶点和目标节点相互连接来构建路线图。我们会发现,从红点到绿点的最短路径一定会通过靠近障碍物边界的折线。

                                                                                                        图搜索方法

除了Roadmap之外,还有Cell decomposition(网格分解方法)Potential field(势场法)等路径规划方法。Cell decomposition将整个空间分割成一个个cell,通过cell的连接图表示自由空间的连接属性。Potential field就是直接用微分方法处理。

                                                                                                        路径规划方法

一种常用的抽象连续空间的方法叫做PRM。它在整个配置空间随机采样一些点,如果点在障碍物上则去掉,然后将这些点连接起来,如下图所示的紫色点。从点s到g的最短路径就可以利用A-Star算法进行求解。但是该方法要求是对全局感知,而无人车是一个部分感知的应用场景,因此有RRT的改进方法。

                                                                                                        PRM 方法


2-1 RRT(基于快速扩展随机树算法)

如下图所示,它构造一个根结点为起始点的配置空间树,通过随机采样增加叶子节点的方式,生成一个随机扩展树,当随机树中的叶子节点包含了目标点或进入了目标区域,便可以在随机树中找到一条由从初始点到目标点的路径。如果叶子节点和目标节点之间的连接被障碍物阻挡,则需要重新采样。

                                                                                                        基于快速扩展随机树算法

通过这种方式离散化的线是不适合无人车行驶的,因为这些线的curvature不连续,甚至curvature都没有。针对这一问题MIT提出使用平滑曲线进行连接的方法,如下图所示。但是该方法得到的路径可能还是不够平滑,另外对动态障碍物的处理也存在问题。

                                                                                                        平滑曲线进行连接的方法


2 - 2 Lattice网格方法

针对上述问题,就有人提出了Lattice网格方法

                                                                                                        Lattice网络方法

如上图所示,最原始的Lattice网格方法非常简单,它在XY世界坐标系中,以1米为单位进行网格划分,然后用无人车可以行进的、曲率连续的曲线将起始点和目标点连接起来。但是这种方法还是不能满足需求。对于道路来说,这种抽象方式并不合适。Lattice Sampling撒点不能在规则化坐标系下去撒点,因为道路并不是一个完全XY的坐标系。因此提出了在sl坐标系下进行离散的方法Lattice in Frenet Frame


2 - 3 Polynomial方法

当抽象出这些点之后,如何使用平化曲线连接呢? 有一种使用螺旋曲线的方法,即Splines方法。此外,还可以使用路径-速度迭代优化的方法对Lattice方法进行优化,也就是Polynomial方法。它将问题降维,分成了path 和 speed两个维度逐渐优化,这是一种iterative的处理方式。

                                                                                                        Polynomial方法


2 - 4 Functional Optimization方法

还可以用Functional Optimization方法对运动规划进行处理,对整个问题建模,设计相应的代价函数。二次规划就是其中一种常用的方法。

                                                                                                        Functional Optimization方法​​​​​​​

Apollo进阶课程㉒丨Apollo规划技术详解——Motion Planning with Autonomous Driving相关推荐

  1. Apollo进阶课程㉓丨Apollo规划技术详解——Motion Planning with Environment

    原文链接:进阶课程㉓丨Apollo规划技术详解--Motion Planning with Environment 当行为层决定要在当前环境中执行的驾驶行为时,其可以是例如巡航-车道,改变车道或右转, ...

  2. Apollo进阶课程㉔丨Apollo 规划技术详解——Motion Planning Environment

    原文链接:进阶课程㉔丨Apollo 规划技术详解--Motion Planning Environment 自动驾驶汽车核心技术包括环境感知.行为决策.运动规划与控制等方面.其中,行为决策系统.运动规 ...

  3. Apollo进阶课程㉕丨Apollo规划技术详解——Optimization Inside Motion Planning

    原文链接:进阶课程㉕丨Apollo规划技术详解--Optimization Inside Motion Planning 在自动驾驶软件的开发中,运动规划是最核心的模块之一.它将综合感知.定位和地图等 ...

  4. Apollo进阶课程㉖丨Apollo规划技术详解——Understand More on the MP Difficulty

    原文链接:进阶课程㉖丨Apollo规划技术详解--Understand More on the MP Difficulty EM是一个在已知部分相关变量的情况下,估计未知变量的迭代技术,EM的算法流程 ...

  5. Apollo进阶课程㉑丨Apollo规划技术详解——Basic Motion Planning and Overview

    原文链接:进阶课程㉑丨Apollo规划技术详解--Basic Motion Planning and Overview 运动规划(Motion Planning)就是在给定的位置A与位置B之间为机器人 ...

  6. Apollo进阶课程 ⑮丨Apollo自动定位技术详解—百度无人车定位技术

    目录 1.百度无人车定位进化历程 2.百度自动驾驶应用的定位技术 2.1GNSS定位技术 2.2载波定位技术 2.3激光点云定位技术 2.4视觉定位技术 原文链接:进阶课程 ⑮丨Apollo自动定位技 ...

  7. Apollo进阶课程㉗丨Apollo控制技术详解——控制理论

    原文链接:进阶课程㉗丨Apollo控制技术详解--控制理论 控制模块根据预测的轨迹和估计的车辆状态向油门.刹车或转向扭矩发送适当的命令.控制模块使汽车尽可能接近计划的轨迹.控制器参数可以通过最小化理想 ...

  8. Apollo进阶课程㉙丨Apollo控制技术详解——控制器的类型

    原文链接:进阶课程㉙丨Apollo控制技术详解--控制器的类型 控制主要是为了弥补数学模型和物理世界执行之间的不一致性.对于自动驾驶而言,规划的轨迹和车辆的实际运行轨迹并不完全一致,控制器按照规划轨迹 ...

  9. Apollo进阶课程㊸丨Apollo实战——障碍物感知和路径规划能力实战

    原文链接;进阶课程㊸丨Apollo实战--障碍物感知和路径规划能力实战 环境感知在自动驾驶汽车应用中占据了核心地位.一辆车要实现自动驾驶,障碍物感知是最基础也是最核心的功能. 上周阿波君为大家详细介绍 ...

最新文章

  1. VS不显示最近打开的项目
  2. 关于在html中正常,在aspx中乱码的问题
  3. AtCoder AGC038D Unique Path (图论)
  4. 常见算法的python实现(Github标星75.5k+)
  5. C++中max,min函数,以及vector字符未定义问题(未声明的标志符)
  6. 在Windows系统中构建还原ASP.NET Core 源码
  7. python中列表的常用操作
  8. 大学物理光学思维导图_头晕/眩晕问诊最全思维导图,赶紧收藏!
  9. Spring MVC学习总结(3)——Spring3 MVC详解
  10. centos7 查看ip地址
  11. 自考计算机应用技术题,全国自考计算机应用技术试题及答案解析-20210522014558.docx-原创力文档...
  12. css 下划线_css学习
  13. 【福利】BAT架构师分享最全Java架构师学习技能图谱:包含Java编程+网络+设计模式+数据库+分布式等
  14. linux下载百度网盘文件
  15. 利用anaconda 下载python所依赖的文件包
  16. VOA special English 下载 py
  17. 联想服务器win7系统安装教程,一键安装联想win7系统步骤指南
  18. LCD点阵液晶多级菜单设计
  19. 网络计算机amd,AMD多屏显示设置指南_计算机硬件和网络_IT /计算机_信息
  20. 企业微信的消息如何在个人微信上读取?

热门文章

  1. oracle控制文件全备失败,Oracle数据库案例整理-恢复数据库失败-主备机控制文件所在目录不同...
  2. linux查询内存条个数,linux下查看内存条数及每根内存大小的实现方法(推荐)
  3. wordpress functions.php 在哪,在functions.php中定义变量并在WordPress中的函数钩子中访问它们...
  4. OpenCv学习笔记(二)—cv Mat学习
  5. java 继承调用_【JAVA学习】继承中函数调用机制
  6. AlarmManager使用
  7. python怎么创建变量_python怎么创建变量
  8. mysql ab复制延时_Mysql的AB复制
  9. termcap-1.3.1的configure.in文件逐行分析
  10. java第七章jdbc课后简答题_Java周测题08.13