Pure Pursuit 纯追踪法

适用场景:低速场景(速度过高易产生转弯内切以及超调)

1. 几何学自行车模型

自行车模型
此模型在于简化前轮转向角和后轴将遵循的曲率之间的关系。
t a n δ = L R \Large tan\delta =\frac{L}{R} tanδ=RL
该公式能在较低速度的场景下对车辆运动做估计。

2. 纯追踪算法理论分析

从自行车模型出发,纯追踪算法以车后轴为切点,车辆纵向车身为切线。通过控制前轮转角,使车辆可以沿着一条经过目标路点(Gx,Gy)圆弧行驶。
在这里插入图片描述
(Gx,Gy)是下一个需要追踪的路点,位于已经规划好的全局路径上,现在需要控制车辆的后轴经过该路点。

  • L d L_{d} Ld: 车辆后轴中心(Cx,Cy)到目标路点(Gx,Gy)的距离,即预瞄距离
  • α \alpha α: 目前车身姿态和目标路点的夹角
  • R R R: 跟踪的曲率半径
  • δ δ δ: 前轮转角
    由正弦定理得:
    L d s i n 2 α = R s i n ( π 2 − α ) \Large\frac{L_{d}}{sin2\alpha } =\frac{R}{sin(\frac{\pi }{2} -\alpha ){\large }} sin2αLd=sin(2πα)R

继续往下推得 L d 2 s i n α c o s α = R c o s α \large\frac{L_{d}}{2sin\alpha cos\alpha } =\frac{R}{cos\alpha } 2sinαcosαLd=cosαR => 2 R = L d s i n α \large2R=\frac{L_{d}}{sin\alpha } 2R=sinαLd

圆弧的曲率: k a p p a = 1 R = 2 s i n α L d \large kappa =\frac{1}{R} =\frac{2sin\alpha}{Ld } kappa=R1=Ld2sinα

前轮转角 δ = a r c t a n ( L R ) = a r c t a n ( k a p p a ∗ L ) {\large \delta =arctan(\frac{L}{R} )=arctan(kappa*L){\large } } δ=arctan(RL)=arctan(kappaL)

纯追踪算法的最终表达式: δ ( t ) = a r c t a n ( 2 L s i n α ( t ) L d ) {\Large {\delta (t)=arctan(\frac{2Lsin\alpha (t)}{Ld} )} } δ(t)=arctan(Ld2Lsinα(t))

3. 纯追踪控制器

定义一个新的量e — 车辆当前姿态和目标路点在横向上的误差
在这里插入图片描述
s i n α = e L d {\large sin\alpha = \frac{e}{L_{d}}{\large }} sinα=Lde

k a p p a = 1 R = 2 s i n α L d = 2 e L d 2 \large kappa =\frac{1}{R} =\frac{2sin\alpha}{L_{d}}=\frac{2e}{L_{d} ^2} kappa=R1=Ld2sinα=Ld22e

=>纯追踪控制器其实是一个横向误差的P控制器 K p = 2 L d 2 K_{p} = \frac{2}{Ld ^2} Kp=Ld22
这个P控制器受 L d L_{d} Ld影响很大,调节预瞄距离成为纯追踪算法的关键

4. 调节预瞄距离 L d L_{d} Ld

预瞄距离类似驾驶员开车时的视觉跟踪点。直道行驶,驾驶员会选择相对快的速度,视觉跟踪点一般也比较远;弯道行驶时,驾驶员会选择相对慢的速度,视觉跟踪点习惯选择近的位置作为跟踪参考点。
预瞄距离 L d L_{d} Ld的计算与当前车辆速度v,曲率kappa存在下面的函数关系:

L d = f ( v , k a p p a ) L_{d} =f(v,kappa) Ld=f(v,kappa)

  1. 速度越快,预瞄距离越远,可以认为,预瞄距离与速度成正比。
  2. 如果前方跟踪曲率较大说明为弯道,需要减少预瞄距离满足弯道行驶的跟踪精度;曲率较小,可以增加预瞄距离保证行驶的平稳性。

所以预瞄距离 L d L_{d} Ld与速度 v v v和曲率 k a p p a kappa kappa的关系: L d ∝ v k a p p a L_{d}\propto \frac{v}{kappa} Ldkappav

4.1 预瞄距离 L d L_{d} Ld的确定

参考文章:基于Pure Pursuit算法的智能车路径跟踪

对于下一时刻将要跟踪的路径中,轨迹曲率K需要进行量化计算。选择一段距离内的轨迹离散化成关键点,进行评估。考虑选择合适长度的距离D内进行计算估计曲折程度。D的计算与车速成正相关。
预瞄距离 L d L_{d} Ld与车速 V V V的数学关系:
在这里插入图片描述
V V V:车辆行驶速度
第一项: 车辆制动距离
A = 1 2 a m a x A = \frac{1}{2a_{max}} A=2amax1
第二项: 车辆遇到异常情况进行反应的车辆行驶距离
第三项: 车辆最小转弯半径

预瞄距离与车速的函数关系图
预瞄距离与车速的函数关系图
上述 L d L_{d} Ld的计算规则,作为D的计算公式。通过计算轨迹D距离内,描述kappa。kappa的计算可以由离散路径点的曲率均值或者方差来表示。

确定预瞄距离 L d L_{d} Ld后,根据Pure Pursuit算法继续计算出控制参数( V , W V,W V,W)。
前轮转角 δ \delta δ对应角速度 W W W: W = V / R = k ∗ V W = V/R=k*V W=V/R=kV

为了保证车辆在转弯时能过平稳跟踪,需要防止车辆侧翻,根据车辆自身参数对车辆运动过程中的侧向加速度进行限制。

车辆所能承受的最大侧向加速度:
A c c m a x = V m a x 2 R m i n Acc_{max}=\frac{V_{max}^2}{R_{min}} Accmax=RminVmax2
当前控制参数的侧向加速度为: A c c = W ∗ V Acc = W*V Acc=WV

如果当前控制参数的侧向加速度大于设置的阈值,那么此时的侧向加速度为阈值,并根据侧向加速度和角速度计算出此时的线速度 V V V,以保证车辆在转弯过程中的平稳性和舒适性。通常情况下, A c c m a x Acc_{max} Accmax的阈值可以设置较小一点,这样在弯道时速度较低,跟踪的精度会更好一些。

同时,为了保证控制参数平稳,Autoware还加入了低通滤波,防止控制参数突变造成车辆状态变化过快。

4.2 计算流程

纯追踪法的计算流程如下
在这里插入图片描述
设置固定的前视距离和路径曲率肯定无法适应不同的路径,因此就需要对于前视距离的计算方法进行研究改进。

本文详细阐述了几何自行车模型、纯追踪算法的理论推导、以及预瞄距离(有些地方叫前视距离)的确定,希望各位读者批评指正,共同学习进步。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐