cde4hkuthu 发表于 2022-10-26 16:06:23

复杂约束下自动驾驶车辆的运动规划解析

1.什么是Motion Planning


Motion Planning是在遵循道路交通规则的前提下,将自动驾驶车辆从当前位置导航到目的地的一种方法。

在实际开放道理场景下,自动驾驶要处理的场景非常繁杂:空旷的道路场景、与行人、障碍物共用道理的场景、空旷的十字路口、繁忙的十字路口、违反交通规则的行人/车辆、正常行驶的车辆/行人等等。场景虽然复杂,但都可以拆解为一系列简单行为(behavior)的组合:

https://p3-sign.toutiaoimg.com/pgc-image/b8e36de2767245a2a1ca2462b8689bb6~tplv-tt-large.image?x-expires=1982134551&x-signature=w4rG3xmwV%2BK45EtRmxT9aUtJdmc%3D

将这些简单的行为(behavior)组合起来,就可以完成复杂的驾驶行为。
2.Motion Planning的约束条件(constraints)


Motion Planning是一个复杂的问题,它的执行过程需要满足很多约束条件:
2.1 车辆运动学约束


车辆运动受到运动学约束,比如它不能实现瞬时侧向移动,前驱的车辆必须依赖前轮的转向才能实现变道、转向等操作,在弯道上不能速度过快等等。通常我们采用单车模型(Bicycle Model)对车辆运动进行建模。

https://p3-sign.toutiaoimg.com/pgc-image/1b1b16612c5e46939988d5194ba64b5c~tplv-tt-large.image?x-expires=1982134551&x-signature=EggkukYicYnYhjjQRswUZk3b%2FLk%3D

2.2 静态障碍物(Static Obstacle)约束


静态障碍物(Static Obstacle)是道路上静止的车辆、路面中间的石墩子等车辆不可行驶的区域。Motion Planning需要避开这些静态障碍物,避免与它们发生碰撞。解决碰撞的思路大概有两种:

1)将静态障碍物(Static Obstacle)在网格占位图中表示出来,然后检测规划路线是否与静态障碍物区域相交。

2)将车辆的轮廓扩大,比如扩展成一个圆形,然后检测障碍物是否与Circle发生碰撞。

https://p3-sign.toutiaoimg.com/pgc-image/63b963de234f45b0a9a7d76898b04125~tplv-tt-large.image?x-expires=1982134551&x-signature=OaLJ0q0sumfonXePM9ibZSqbGwc%3D

2.3 动态障碍物约束


Motion Planning要实时处理行人、车辆等各种运动的障碍物,避免与障碍物发生碰撞事故。

https://p3-sign.toutiaoimg.com/pgc-image/ebde4e2c2c154073a9227ca57f325e92~tplv-tt-large.image?x-expires=1982134551&x-signature=Pia2dGjVAXL7Z19572dCy0ExKXw%3D

2.4 道路交通规则约束


车辆在道路上行驶必须要遵守车道线约束规则(比如左转专用道只能左转、实线不能变道、路口必须遵守红绿灯的指示)和各种标志标牌的指示。

https://p3-sign.toutiaoimg.com/pgc-image/45a81d293e354d188b549bc82a26d605~tplv-tt-large.image?x-expires=1982134551&x-signature=8%2B5d8DW%2BZnOk4ae8OALsZHXTXSQ%3D

3.Motion Planning的优化目标


了解Motion Planning的约束条件之后,需要构造目标优化函数,然后最小化目标函数,从而获得在当前环境下的最优运动轨迹。目标函数的种类有很多,下面枚举一些常用的目标函数。

1)关注路径长度(Path Length),寻求到达目的地的最短路径。

2)关注通行时间(Travel Time),寻求到达目的地的最短时间。

3)惩罚偏离参考轨迹和参考速度的行为。

https://p3-sign.toutiaoimg.com/pgc-image/ed149e9bb31c4489903449fe64ebda91~tplv-tt-large.image?x-expires=1982134551&x-signature=3bcSbcHAA%2Fx7M1bcFPJTgyo45k0%3D

4)考虑轨迹平滑性(Smoothness)

5)考虑曲率约束(Curvature)

通过组合设计自己的目标优化函数,从而获得较好的Planning效果。
4.分级运动规划器(Hierarchical Motion Planning)


https://p3-sign.toutiaoimg.com/pgc-image/de079a59510c4acb808ecf7cf5029e89~tplv-tt-large.image?x-expires=1982134551&x-signature=LZV61Ivzj5EYNM8EIktZ4NvJRQw%3D

Motion Planning是一个异常复杂的问题,所以通常我们把它切分为一系列的子问题(Sub Problem)。比如Mission Planner、Behavior Planner、Local Planner、Vehicle Control等。

https://p3-sign.toutiaoimg.com/pgc-image/05ce14d7bbec4d7dac7bdcc7c0e3c258~tplv-tt-large.image?x-expires=1982134551&x-signature=FAMd0kmrTc3mJM%2FMSE4uMWdzu%2Bg%3D

4.1 Mission Planner


Mission Planner关注High-Level的地图级别的规划;通过Graph Based的图搜索算法实现自动驾驶路径的规划。

https://p3-sign.toutiaoimg.com/pgc-image/b347f142518f48d7b2c18cd2677c305b~tplv-tt-large.image?x-expires=1982134551&x-signature=ai0MGYCYMn2%2F26ACS8fYFkja6cA%3D

4.2 Behavior Planner


Behavior Planner主要关注交通规则、其它道路交通参与者(自行车、行人、社会车辆)等等,决定在在当前场景下应该采取何种操作(如停车让行、加速通过、避让行人等等)。

https://p3-sign.toutiaoimg.com/pgc-image/f10fa6e26da74b07a144d6188dce6d17~tplv-tt-large.image?x-expires=1982134551&x-signature=SKaGHDdliMA%2FlbE3ALkE7ED9K4Y%3D

Behavior Planner的实现方式比较常见的有几种:有限状态机(Finite State Machines)、规则匹配系统(Rule Based System)、强化学习系统(Reinforcement Learning)。

有限状态机中的State是各个行为决策,根据对外界环境的感知和交通规则的约束在各个状态之间转换。比如在路口红绿灯的场景,当路口交通灯为红色不可通行时,车辆会首先切换到Decelerate to Stop状态,然后在路口停止线完全停下来,进入Stop状态,并持续在Stop状态等待,直至交通灯变为绿色允许车辆通行,车辆进入Track Speed状态,继续前行。

https://p3-sign.toutiaoimg.com/pgc-image/596a917b5015443b90fbc45866046944~tplv-tt-large.image?x-expires=1982134551&x-signature=IygolswbSzA9yfAf%2F7hV1PA%2F0Lg%3D

Rule-Based System是通过一系列的分级的规则匹配来决定下一步的决策行为。比如交通灯绿色->通行;交通灯红色->停车等待。

https://p3-sign.toutiaoimg.com/pgc-image/0b0472f01651431b9945d1c625246902~tplv-tt-large.image?x-expires=1982134551&x-signature=4w%2FA%2BctntXSBaY7WFNgHhsu8a5Y%3D

基于强化学习的Behavior Planner系统如下:

https://p3-sign.toutiaoimg.com/pgc-image/3a88349e2fab4ddbae443cf1c4e26db9~tplv-tt-large.image?x-expires=1982134551&x-signature=B3BIgHmMMJXampvfKZxpCjWTcq8%3D

4.3 Local Planner


Local Planner关注如何生成舒适的、碰撞避免的行驶路径和舒适的运动速度,所以Local Planner又可以拆分为两个子问题:Path Planner和Velocity Profile Generation。Path Planner又分为Sampling-Based Planner、Variational Planner和Lattice Planner。

最经典的Sampling-Based Planner算法是Rapidly Exploring Random Tree,RRT算法。

https://p3-sign.toutiaoimg.com/pgc-image/5f759ea7d80846c1a0ffaec0d585a821~tplv-tt-large.image?x-expires=1982134551&x-signature=Mph8jv5xpqw80A3gdJKHE6bwuiA%3D

Variational Planner根据Cost Function进行优化调整,从而避开障碍物,生成安全的轨迹。

https://p3-sign.toutiaoimg.com/pgc-image/1aa130ae5e114dafb9817bf949269f0b~tplv-tt-large.image?x-expires=1982134551&x-signature=2VfeHvWzkMeSFNTqKvJrV4aSK7c%3D

Lattice Planner将空间搜索限制在对车辆可行的Action Space。

https://p3-sign.toutiaoimg.com/pgc-image/55d90185565b4c83997f0e8846b77e3d~tplv-tt-large.image?x-expires=1982134552&x-signature=tHChtXheqxcKb1CNPPGshn4d6QI%3D

Velocity Profile Generation要考虑到限速、速度的平滑性等。

https://p3-sign.toutiaoimg.com/pgc-image/a334f1b6a9104e4697434754eba69a59~tplv-tt-large.image?x-expires=1982134552&x-signature=oB%2BYWgrVCXdenkJS9p1l0aVJOpg%3D

Vehicle Control将Planner的规划结果转化为车辆的运动行为。

urk3bji8n4si78 发表于 2022-10-26 16:07:16

转发了
页: [1]
查看完整版本: 复杂约束下自动驾驶车辆的运动规划解析