Apollo代码学习(二)—车辆运动学模型

Apollo(阿波罗)是一个开放的、完整的、安全的自动驾驶平台,以灵活和高性能的技术架构,为全自动驾驶提供支持。

前言

要实现对车辆的控制,研究其运动学模型和动力学模型必不可少。上文对横纵向控制的构成及实现做了概述,本文将从车辆的运动学和动力学模型入手,研究如何控制车辆,以及为什么这样控制车辆。

本文的观点及图表多基于下述书籍及链接,并结合Apollo代码整理而来,由于本身并没有学过实车相关的知识,对力学的认知也不够深,如有理解偏颇或侵权之处,请指正删改。
【1】Rajamani R. Vehicle Dynamics and Control[M]. Springer Science, 2006.
【2】龚建伟, 姜岩, 徐威. 无人驾驶车辆模型预测控制[M]. 北京理工大学出版社, 2014.
【3】无人驾驶汽车系统入门(五)——运动学自行车模型和动力学自行车模型

提倡大家支持正版资源,本人提供文档仅限交流学习使用,侵删:
【1】Rajamani R. Vehicle Dynamics and Control[M]. Springer Science, 2006. | CSDN资源
【2】龚建伟, 姜岩, 徐威. 无人驾驶车辆模型预测控制[M]. 北京理工大学出版社, 2014. | CSDN资源

车辆模型

车辆运动学模型与动力学模型的建立是出于车辆运动的规划与控制考虑的。自动驾驶场景下,车辆大多按照规划轨迹行驶,控制模块的作用就是控制车辆尽可能精准的按照规划轨迹行驶。这就要求规划轨迹尽可能贴近实际情况,也就是说,轨迹规划过程中应尽可能考虑车辆运动学及动力学约束,使得运动跟踪控制的性能更好。

搭建车辆模型主要是为了更好的规划和控制,因此,在分析模型时尽量以应用时所需的输入、输出对对象进行建模分析。Apollo中,计算控制命令需要车辆的定位信息、底盘信息以及规划信息等,

Status xxxController::ComputeControlCommand(
    const localization::LocalizationEstimate *localization, //定位信息
    const canbus::Chassis *chassis,  //底盘信息
    const planning::ADCTrajectory *planning_published_trajectory, //规划信息
    ControlCommand *cmd //控制命令)

其中,
定位信息(localization.proto)包含

message LocalizationEstimate {
  optional apollo.common.Header header = 1;
  optional apollo.localization.Pose pose = 2;
  optional Uncertainty uncertainty = 3;

  // The time of pose measurement, seconds since the GPS epoch (Jan 6, 1980).
  optional double measurement_time = 4;  // In seconds.

  // Future trajectory acturally driven by the drivers
  repeated apollo.common.TrajectoryPoint trajectory_point = 5;
}

底盘信息(chassis.proto)包含

message Chassis {
  enum DrivingMode {
    COMPLETE_MANUAL = 0;  // human drive
    COMPLETE_AUTO_DRIVE = 1;
    AUTO_STEER_ONLY = 2;  // only steer
    AUTO_SPEED_ONLY = 3;  // include throttle and brake

    // security mode when manual intervention happens, only response status
    EMERGENCY_MODE = 4;
  }
  
  ...

  // Only available for Lincoln now
  optional ChassisGPS chassis_gps = 28;

  optional apollo.common.EngageAdvice engage_advice = 29;
}

规划信息(planning.proto)包含

message ADCTrajectoryPoint {
  optional double x = 1;  // in meters.
  optional double y = 2;  // in meters.
  optional double z = 3;  // height in meters.

  optional double speed = 6;  // speed, in meters / second
  optional double acceleration_s = 7;  // acceleration in s direction
  optional double curvature = 8;  // curvature (k = 1/r), unit: (1/meters)
  // change of curvature in unit s (dk/ds)
  optional double curvature_change_rate = 9;
  // in seconds (relative_time = time_of_this_state - timestamp_in_header)
  optional double relative_time = 10;
  optional double theta = 11;  // relative to absolute coordinate system
  // calculated from the first point in this trajectory
  optional double accumulated_s = 12;

  // in meters, reference to route SL-coordinate
  optional double s = 4 [deprecated = true];
  // in meters, reference to route SL-coordinate
  optional double l = 5 [deprecated = true];
}

对上述元素进行精简,我们需要关注的信息主要有:

  1. 时间(tt
  2. 位置(x,yx, y
  3. 速度(vv
  4. 加速度(aa
  5. 角速度(ω\omega
  6. 位移(ss
  7. 航向角(ψ\psi
  8. 曲率(kk
  9. 前轮转角(wheelwheel
  10. 方向盘转角(steersteer
  11. 刹车(brakebrake
  12. 油门(throttlethrottle
  13. 档位(geargear

其中,

  • 方向盘转角(steersteer
  • 刹车(brakebrake
  • 油门(throttlethrottle
  • 档位(geargear

为主要被控量。

单车模型(Bicycle Model)

建立模型时,应尽可能使模型简单易用,且能真实反映车辆特性,搭建车辆模型多基于(Bicycle Model)\color{Maroon}单车模型(Bicycle\ Model),使用单车模型需做如下假设[^1]:

  1. 不考虑车辆在Z轴方向的运动,只考虑XY水平面的运动,如图1所示;
  2. 左右侧车轮转角一致,这样可将左右侧轮胎合并为一个轮胎,以便于搭建单车模型,如图2所示;
  3. 车辆行驶速度变化缓慢,忽略前后轴载荷的转移;
  4. 车身及悬架系统是刚性的。
图1 车辆模型

(Bicycle Model)\color{Maroon}单车模型(Bicycle\ Model)将左/右前轮合并为一个点,位于A点;将左/右后轮合并为一个点,位于B点;点C为车辆质心点。

图2 单车模型

其中,OO为OA、OB的交点,是车辆的瞬时滚动中心,线段OA、OB分别垂直于两个滚动轮的方向;β\beta滑移角(Tire Slip Angle),指车辆行进方向和轮圈所指方向两者间所成的角度,ψ\psi航向角(Heading Angle),指车身与X轴的夹角。

符号 定义 符号 定义
AA 前轮中心 BB 后轮中心
CC 车辆质心 OO 转向圆心
VV 质心车速 RR 转向半径
r\ell_r 后悬长度 f\ell_f 前悬长度
β\beta 滑移角 ψ\psi 航向角
δr\delta_r 后轮偏角 δf\delta_f 前轮偏角

当车辆为(frontwheelonly)\color{Maroon}前轮驱动(front-wheel-only)时,可假设δr\delta_r恒为0。

车辆运动学模型

运动学是从几何学的角度研究物体的运动规律,包括物体在空间的位置、速度等随时间而产生的变化,因此,车辆运动学模型应该能反映车辆位置、速度、加速度等与时间的关系。在车辆轨迹规划过程中应用运动学模型,可以使规划出的轨迹更切合实际,满足行驶过程中的运动学几何约束,且基于运动学模型设计出的控制器也能具有更可靠的控制性能。

基于单车模型,如图2所示,搭建车辆运动学模型。由正弦法则:
(1.1)sin(δfβ)f=sin(π2δf)R\frac{\sin(\delta_f-\beta)}{\ell_f}=\frac{\sin(\frac{\pi}{2}-\delta_f)}{R} \tag{1.1}
(1.2)sin(βδr)r=sin(π2+δr)R\frac{\sin(\beta-\delta_r)}{\ell_r}=\frac{\sin(\frac{\pi}{2}+\delta_r)}{R} \tag{1.2}
展开公式(1.1)(1.2)(1.1)(1.2)可得:
(1.3)sinδfcosβsinβcosδff=cosδfR\frac{\sin\delta_f\cos\beta-\sin\beta\cos\delta_f}{\ell_f}=\frac{\cos\delta_f}{R} \tag{1.3}
(1.4)cosδrsinβcosβsinδrr=cosδrR\frac{\cos\delta_r\sin\beta-\cos\beta\sin\delta_r}{\ell_r}=\frac{\cos\delta_r}{R} \tag{1.4}
联立公式(1.3)(1.4)(1.3)(1.4)可得:
(1.5)(tanδftanδr)cosβ=f+rR(\tan\delta_f-\tan\delta_r)\cos\beta=\frac{\ell_f+\ell_r}{R} \tag{1.5}

低速环境下,车辆行驶路径的转弯半径变化缓慢,此时我们可以假设车辆的方向变化率等于车辆的角速度。则车辆的角速度为(1.6)ψ˙=VR\dot{\psi}=\frac{V}{R} \tag{1.6}
联立公式(1.5)(1.6)(1.5)(1.6)可得:
(1.7)ψ˙=Vcosβf+r(tanδftanδr)\dot{\psi}=\frac{V\cos\beta}{\ell_f+\ell_r}(\tan\delta_f-\tan\delta_r) \tag{1.7}
则在惯性坐标系XY下,可得车辆运动学模型:

(1.8){X˙=Vcos(ψ+β)Y˙=Vsin(ψ+β)ψ˙=Vcosβf+r(tanδftanδr)\begin{cases} \dot{X}=V\cos(\psi+\beta) \\ \dot{Y}=V\sin(\psi+\beta) \\ \dot{\psi}=\frac{V\cos\beta}{\ell_f+\ell_r}(\tan\delta_f-\tan\delta_r) \tag{1.8} \end{cases}

此模型中有三个输入:δf\delta_fδr\delta_rVV
滑移角β\beta可由公式(1.3)(1.4)(1.3)(1.4)求得:
(1.9)β=tan1(ftanδr+rtanδff+r)\beta=\tan^{-1}(\frac{\ell_f\tan\delta_r+\ell_r\tan\delta_f}{\ell_f+\ell_r}) \tag{1.9}

阿克曼转向几何(Ackerman turning geometry)

(Ackerman Turning Geometry)\color{Red}阿克曼转向几何(Ackerman\ Turning\ Geometry)是一种为了解决交通工具转弯时,内外转向轮路径指向的圆心不同的几何学。

在单车模型中,将转向时左/右前轮偏角假设为同一角度,虽然通常两个角度大致相等,但实际并不是,通常情况下,内侧轮胎转角更大。如下图所示,δo\delta_oδi\delta_i分别为外侧前轮和内侧前轮偏角,当车辆右转时,右前轮胎为内侧轮胎,其转角δi\delta_i较左前轮胎转角δo\delta_o更大。w\ell_w为轮距,LL为轴距,后轮两轮胎转角始终为0°\color{Maroon}0\degree
当以后轴中心为参考点时,转向半径RR为下图中线\color{Red}红线

图3 阿克曼转向几何

当滑移角β\beta很小时,且后轮偏角为0时,公式(1.7)(1.7)可表述为:
(1.10)ψ˙V1R=δL\frac{\dot{\psi}}{V}\approx\frac{1}{R}=\frac{\delta}{L} \tag{1.10}
由于内外侧轮胎的转向半径不同,因此有:
(1.11)δo=LR+w2\delta_o=\frac{L}{R+\frac{\ell_w}{2}} \tag{1.11}
(1.12)δi=LRw2\delta_i=\frac{L}{R-\frac{\ell_w}{2}} \tag{1.12}
则前轮平均转角
(1.13)δ=δo+δi2LR\delta=\frac{\delta_o+\delta_i}{2}\cong\frac{L}{R}\tag{1.13}
内外转角之差
(1.14)Δδ=δiδo=LR2w=δ2wL\Delta\delta=\delta_i-\delta_o=\frac{L}{R^2}\ell_w=\delta^2\frac{\ell_w}{L} \tag{1.14}
因此,两个前轮的转向角的差异Δδ\Delta\delta与平均转向角δ\delta的平方成正比。

依据阿克曼转向几何设计的车辆,沿着弯道转弯时,利用四连杆的相等曲柄使内侧轮的转向角比外侧轮大大约2~4度,使四个轮子路径的圆心大致上交会于后轴的延长线上瞬时转向中心,让车辆可以顺畅的转弯。

图4 梯形拉杆装置差动转向机构

小结

以后轴中心为参考点,以单车模型为基础建立车辆的运动学模型,(Xr,Yr)(X_r, Y_r)为后轴中心坐标,ψ\psi为航向角,vrv_r为车速,δf\delta_f为前轮转角,后轮转角δr\delta_r恒为0°0\degreeww为横摆角速度,滑移角β\beta极小,假设为0。

当状态量为ξ=[Xr,Yr,ψ]T\xi=[X_r, Y_r, \psi]^T,被控量为u=[vr,δf]Tu=[v_r, \delta_f]^T时,公式(1.8)(1.8)可转换为如下形式:
(1.15)[Xr˙Yr˙ψ˙]=[cosψsinψtanδf/l]vr \begin{bmatrix} \dot{X_r} \\ \dot{Y_r} \\ \dot\psi \end{bmatrix}= \begin{bmatrix} \cos\psi \\ \sin\psi \\ \tan{\delta_f}/l \end{bmatrix}v_r \tag{1.15}
但在无人车控制过程中,一般控制对象u=[vr,w]Tu=[v_r, w]^T,则式1.15可写为:
(1.16)[Xr˙Yr˙ψ˙]=[cosψsinψ0]vr+[001]w \begin{bmatrix} \dot{X_r} \\ \dot{Y_r} \\ \dot\psi \end{bmatrix}= \begin{bmatrix} \cos\psi \\ \sin\psi \\ 0 \end{bmatrix}v_r+ \begin{bmatrix} 0\\ 0 \\ 1 \end{bmatrix}w \tag{1.16}
速度vrv_r的控制主要通过刹车(brakebrake)、油门(throttlethrottle)、档位(geargear)等来控制,横摆角速度ww主要通过转动方向盘(steersteer)来控制。

Apollo中的运动学约束(control_gflags.cc)主要有:

DEFINE_int32(max_localization_miss_num, 20,
             "Max missing number of localization before entering estop mode");
DEFINE_int32(max_chassis_miss_num, 20,
             "Max missing number of chassis before entering estop mode");
DEFINE_int32(max_planning_miss_num, 20,
             "Max missing number of planning before entering estop mode");

DEFINE_double(max_acceleration_when_stopped, 0.01,
              "max acceleration can be observed when vehicle is stopped");
DEFINE_double(max_abs_speed_when_stopped, 0.01,
              "max absolute speed can be observed when vehicle is stopped");
DEFINE_double(steer_angle_rate, 100.0,
              "Steer angle change rate in percentage.");

车辆动力学模型请看下一篇博文:Apollo代码学习(三)—车辆动力学模型

展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 游动-白 设计师: 上身试试
应支付0元
点击重新获取
扫码支付

支付成功即可阅读