自动驾驶汽车面临的第一个问题:从哪里来,到哪里去?
运输是指某一物体 (人或者是货物)通过运输工具(或交通工具与运输路径),由甲地移动至乙地,完成某个经济目的的行为。
定位,获取当前的地理位置信息,通常要通过地图来记录和表示。
先有定位还是先有地图(鸡和蛋) ?
通过定位来绘制地图,而通过地图来表示车辆当前的位置
。
参考系:地理位置有多种表示方式,地理学上大致可以分为2种。
➢相对位置
——相对位置则是透过标示目标物与其他事物之间的关系,以表达事物位置的标示法。当沿着大部分主要公路行驶时,都有里程标志,指示到下一个城镇的距离。这些信息表示您相对于即将到来的地点的当前位置。
➢绝对位置
——绝对位置表达标记事物在空间中单一 、不会因观察者所在位置改变而更改的标示法。基于特定的地理坐标(例如经度和纬度)来引用地球表面上的某个位置。
定位模块除了需要告诉自动驾驶系统自动驾驶汽车当前的位置之外,还提供更多的信息,实际上定位模块还提供车辆当前的运动状态。
除了位置之外,定位模块还提供:车的航向,速度,加速度,角速度等状态信息。
GPS全球定位系统(Global Positioning System, GPS),是一种以人造地球 卫星为基础的高精度无线电导航的定位系统,它在全球任何地方以及近地空间都能够提供准确的地理位置、车辆行驶速度及精确的时间信息。GPS自问世以来,就以其高精度、全天候、全球覆盖、方便灵活吸引了众多用户。
全球四大导航系统:
➢美国全球定位系统
➢欧盟“伽利略”系统.
➢俄罗斯“格洛纳斯”系统
➢中国北斗卫星导航系统
全球定位系统由以下三个部分组成:空间部分(GPS卫星)、地面监控部分和用户部分。
GPS定位的基本原理是:至少测量出当前位置与4颗卫星的距离和对应时间,通过解方程即可求得当前位置在地球坐标系下的位置 ( x , y , z ) (x, y,z) (x,y,z)。
为什么是4颗呢?因为除了需要确定 ( x , y , z ) (x,y,z) (x,y,z)三个位置参数,还需要一个卫星提供相对零点时间从而消除时间误差。
RTK ( Real - time kinematic,实时动态)载波相位差分技术,是实时处理两个测量站载波相位观测量的差分方法,将基准站采集的载波相位发给用户接收机,进行求差解算坐标。
卫星定位是存在误差的,误差既来自系统的内部,也来自外部。例如卫星信号穿透电离层和对流层时产生的误差,还有卫星高速移动产生的多普勒效应引起的误差,以及多径效应误差、通道误差、卫星钟误差、星历误差、内部噪声误差等。这些误差,有些可以完全消除,有些无法消除或只能部分消除。它们影响了系统的准确性和可靠性。
利用先验信息进行定位。
惯性测量单元(英语: Inertial measurement unit,简称IMU )是测量物体三轴姿态角(或角速率)以及加速度的装置。
一般的,一个IMU内会装有三轴的陀螺仪和三个方向的加速度计,来测量物体在三维空间中的角速度和加速度,并以此解算出物体的姿态。为了提高可靠性,还可以为每个轴配备更多的传感器。一般而言IMU)要安装在被测物体的重心上。
参数指标:
陀螺仪
:角度偏差为 0.1 ° / s − 0.001 ° / h 0.1° /s - 0.001° /h 0.1°/s−0.001°/h。
加速度计
:加速度偏差为 100 m g − 10 μ g 100mg - 10μg 100mg−10μg。
由距离计算公式 s = 1 2 a t 2 s = \frac{{\rm{1}}}{{\rm{2}}}a{t^2} s=21at2可以得出, 100 m g 和 10 μ g 100mg和10μg 100mg和10μg偏差的加速度计在60s之后的测量误差分别是3528m和0.35m,差距非常大。
GPS + IMU组合导航
GPS | IMU | |
---|---|---|
更新频率 | 低( 1HZ ) | 高( 100HZ) |
累积误差 | 无 | 有 |
外部依赖 | 有 | 无 |
GPS+IMU的局限性:
GPS+IMU的组合极大的提高了定位的精度和鲁棒性,但还是有一些特殊场景,例如城市高楼,树荫以及比较长的隧道等场景下,定位精度会受到影响。
因此引入了新的方法:先验地图
通过离线的方式,事先建好当前区域的3维地图,也就是我们常说的高精度地图定位图层。
先验地图:一场寻宝游戏 。
以下是一段寻宝的过程“从岛的北面上岸,向前走,是一大片绿地,在上面可以看到一棵橡树和一棵松树,还有一个绞架,从绞架开始沿直线朝橡树走20步,宝藏就在那里。”
先验地图的核心就是拿当前观测到的特征和事先建好的地图做匹配。
先验地图的2大核心问题
。
1.特征提取和特征匹配( Feature matching )
2.重定位( Relocation )
特征提取和特征匹配
●ICP ( iterative closest point )
●NDT ( Normal Distributions Transform )
●基于优化的方法
重定位( Relocation )
●在环境中找到自己的初始坐标,例如
在停车场中启动的时候。
NDT ( Normal Distributions Transform )
NDT非常快速和准确,适合应用于大规模数据,但它对初始化也很敏感,需要足够准确的初始猜测,因此它通常用于从粗到细的对齐策略。可以节省计算量。
NDT三种特征类型
●球型特征
●线型特征
●面型特征
先验地图的好处非常明显,通过事先建立好地图,然后在线做匹配从而得到目标当前的位置。但环境会发生改变,如果周围的环境变化了,而地图没有更新,则会得到错误的定位信息。
有没有能够实时定位和建图的方法呢?
SL AM是Simultaneous localization and mapping缩写,意为“同步定位与建图”。根据类型划分分为:
视觉SL .AM算法
●ORB-SL AM
●LSD-SLAM
●VINS-Mono
激光SL AM算法
●Cartographer
●LOAM系列
目前的精度已经足够,鲁棒性有待加强,也可以用于大规模分布式实时建图。
RTK模块接受GPS和IMU的消息,发布定位消息和定位状态,给其它模块使用。
底层逻辑:
●可以看到RTK模块的核心在于GPS+IMU设备给出结果的精度,这些信息的解算由GPS和IMU设备提供,当然也可以直接拿到GPS和IMU的原始数据进行解算。
NDT模块接受GPS、IMU和激光雷达点云消息,通过和事先建好的NDT地图进行匹配,得到车辆当前的定位消息和定位状态,发布给其它模块使用。
底层逻辑:
准备工作:首先准备录制好的数据包,从包中解压出点云和点云当前的pose,对pose进行校正之后,保存在指定的文件夹。
NDT建图过程:
- 从文件中读取点云和pose
- 根据点云的位置选择对应的node
- 对点云强度信息采样并且放入对应的Node
MSF模块接受GPS、IMU和激光雷达点云消息,通过NDT输出的结果和组合导航输出的结果进行融合,得到车辆当前的定位消息和定位状态,发布给其它模块使用。
底层逻辑:
●MSF模块对GPS和NDT的结果进行融合,从而提高系统的鲁棒性。因此如何融合是MSF的关键。
MSF模块接受GPS、IMU和激光雷达点云消息,通过NDT输出的结果和组合导航输出的结果,通过卡尔曼滤波进行融合,输出最后的定位结果。
云实验
实验分为2个大的步骤:
制作NDT地图。根据解压事先录制好的record包,得到激光雷达点云信息和自动驾驶车辆姿态信息,然后校正激光点云姿态信息,最后调用NDT制图工具生成NDT地图。
启动NDT模块,查看结果。制作好NDT地图之后,接下来,我们就可以运行NDT定位模块,它会加载NDT地图,它的输出是融合之后的定位信息。
解压数据包,得到原始的激光雷达点云信息和车辆姿态信息,需要注意点云的cloud_topic信息,要根据自己系统中发布的点云topic进行匹配,如果不清楚,可以通过cyber_record info查看数据包中的topic信息,从而找到激光雷达的cloud_topic。
解压好数据包之后,通过imu的信息对车辆的位置进行插值,得到校正之后的车辆pose。
有了激光雷达点云信息和准确的pose之后,根据这些信息生成NDT地图,注意这里采用的是NDT的强度信息,因此如果点云中缺少强度信息,则实现不了定位。
ndt_map_creator --pcd_folders=/apollo/data/pcd --pose_files=/apollo/data/pcd/poses.txt --resolution_type=single --resolution=1 --zone_id=50 --map_folder=/apollo/modules/localization/map/ndt_map/local_map
首先我们需要根据车辆的情况修改以下配置
修改地图路径,我们的地图在“/apollo/modules/localization/map”中,修改“global_flagfile.txt”中的“–map_dir”为当前路径。
vi /apollo/modules/common/data/global_flagfile.txt
--map_dir=/apollo/modules/localization/map
修改zone_id和雷达外参,根据地图的UTM zone,修改zone id,例如北京的zone_id=50,修改激光雷达的外参文件,以及lidar的topic,要与数据包,或者实际发布的topic一致。
vi /apollo/modules/localization/conf/localization.conf
local_utm_zone_id = 50
lidar_extrinsics_file = apollo/modules/localization/msf/params/velodyne_params/velodyne64_novatel_extrinsics_example.yaml
lidar_topic = /apollo/sensor/hesai40/compensator/PointCloud2
上述配置完成之后,启动NDT模块
cyber_launch start /apollo/modules/localization/launch/ndt_localization.launch
接着播放数据包,模拟传感器发送消息
cyber_recorder play -f cyberecord_MKZ109_default_10_20220218103727_20220218103737.record -c /apollo/sensor/gnss/odometry /apollo/sensor/hesai40/compensator/PointCloud2 /apollo/sensor/gnss/ins_stat -l
最后通过cyber_monitor查看定位信息
cyber_monitor
本人所有文章仅作为自己的学习记录,若有侵权,联系立删。