Apollo课程学习3——定位

  • 学习前言
  • 无人车自定位系统
    • 一、什么是无人车自定位
    • 二、系统的指标要求
    • 三、为什么无人车需要该系统
  • 三维几何变换
    • 一、旋转
    • 二、平移
    • 三、刚体的位置和朝向
    • 四、坐标系
      • 1、ECI地心惯性坐标系
      • 2、ECFF地心地固坐标系
      • 3、当地水平坐标系
      • 4、UTM坐标系
      • 5、车体坐标系
      • 6、IMU坐标系
      • 7、相机坐标系
      • 8、激光雷达坐标系
      • 9、无人车定位中涉及的坐标系
  • 定位方法
    • 一、定位方法概述
    • 二、GNSS定位技术
    • 三、载波定位技术
    • 四、激光定位
      • 1、激光定位原理
      • 2、迭代最近点(ICP)
      • 3、滤波算法
        • 3.1 直方图滤波算法
        • 3.2 卡尔曼滤波
      • 4、激光定位的优缺点
      • 5、百度的激光点云定位模块
    • 五、视觉定位
    • 六、惯性导航(IMU)
    • 七、多传感器融合定位
  • 百度无人车定位进化历程

学习前言

今天的学习内容是定位原理与方法。

无人车自定位系统

一、什么是无人车自定位

  • 坐标系可以是一个局部的坐标系,也可以是一个全局的坐标系(如全球坐标系)。
  • 位置对应X,Y,Z,即相当于某个坐标系,汽车的平移是多少。
  • 姿态是三个方向的一个旋转,一般用欧拉角来表示(本地坐标系的三个轴和相对坐标系的这三个轴之间的夹角)。包括横滚、俯仰和航向,分别相对于X,Y,Z三个坐标轴。



除去速度、加速度和角速度外,自定位系统还需要对位置和姿态加上一个置信度,表示这次输出的定位结果好不好。

二、系统的指标要求

  • 定位精度必须控制在10厘米以内,才能使行驶中的自动驾驶车辆避免出现碰撞/车道偏离的情况。
  • 鲁棒性也就是最大的误差不要超过30厘米。但是在有些时候,纵向误差稍微大一点点,只要没有偏离车道就没有太大影响。超过30厘米的误差对前后距离的控制会有很大风险。
  • 场景:L4和L5自动驾驶需要自定位系统在各种场景下面都能够工作。

三、为什么无人车需要该系统


三维几何变换

一、旋转




二、平移

三、刚体的位置和朝向

四、坐标系

1、ECI地心惯性坐标系

2、ECFF地心地固坐标系

3、当地水平坐标系

4、UTM坐标系

5、车体坐标系

6、IMU坐标系

7、相机坐标系

8、激光雷达坐标系

9、无人车定位中涉及的坐标系

定位方法

一、定位方法概述

二、GNSS定位技术

GNSS定位其实是单点定位,没有用到基站,它的精度一般是5到10米。它们的原理是测距,有三颗卫星就可以交会两点,舍弃外部的空间点就可以得到自己测绘这个点。但是一般情况下,由于钟差,一般需要四颗卫星去做误差剔除。


类似的系统还有中国的北斗定位、俄罗斯的格罗纳斯和欧洲的伽利略定位。



三、载波定位技术

载波定位技术具体分为两类,RTK技术和PPP技术。它们都是为了确定载波的整周数,然后消除噪声,达到更精准的定位。



RTK的工作原理如下:卫星把观测数据给基站,也给车端的移动站。基站根据多个卫星的钟差计算出误差项,然后把误差项传递给车端,车端用这个误差项消除观测误差,得到精准的位置。它的问题是硬件成本高,需要建基站,需要4G通信的链路,需要基站传数据。


PPP可以简单理解为一个很强的单点,它有很多种基础基站的建设。这些基站通过卫星数据,把这些误差都在基站做分离处理,再传递给卫星。卫星已经做了误差的消除,再去对车端进行定位,得到一个非常高精度的定位信息。

四、激光定位

1、激光定位原理

激光定位是预先制作一个地图(3D的Voxel地图或点云地图或2D的概率地图),然后拿实时的激光点云和这个地图去做匹配

如2D概率地图是把所有的这个点云数据铺到一块,压成了一个2D地图。2D地图分成很多小格子,每个格子里面存储了颜色信息,位置。另外还包括一些概率,概率和点云的数量以及分布相关。

如下图所示的搜索方式,选择了一个XY化的矩形,在每个小格子里面去匹配。每个里面会算一个匹配的概率,匹配可能会用实时点云里面的颜色值或者高度值的分部和2D地图去匹配,最后会得到一个概率图。根据该概率图,用加权平均会得到XY的位置。

2、迭代最近点(ICP)

对于一次扫描中的每个点,我们需要找到另一次扫描中最接近的匹配点,形成匹配点对。然后把每对点之间的距离误差相加,计算得平均距离误差,最后通过点云旋转和平移来最大限度地降低该平均距离误差。然后我们就可以在扫描数据和地图之间找到匹配,实现了将传感器扫描到的车辆位置转换为全球地图上的位置的操作,然后就可以计算在地图上的精确位置了。

3、滤波算法

滤波算法可消除冗余信息,并在地图上找到最可能的车辆位置。

3.1 直方图滤波算法

直方图滤波算法又称误差平均和算法(SSD)。首先将传感器扫描的点云滑过地图上的每个位置,同时计算每个扫描的点与高精度地图上对应点之间的误差,然后对误差的平均求和。误差平均和越小,表示扫描结果与地图之间的匹配度越高。 下图中,红色表示对齐较好的点,蓝色表示对齐较差的点,绿色表示中等对齐的点。

3.2 卡尔曼滤波

卡尔曼滤波使用了预测更新周期,我们可根据之前的状态以及对移动距离和方向的估计来预测新位置。这种运动估计并不完美,所以需要使用传感器测量位置来加以纠正。一旦用传感器测量了新位置,便可使用概率规则,将不完美的传感器测量结果与现有的位置预测结合起来。然后我们将永远遵循这个预测更新周期

4、激光定位的优缺点

  • 优点:稳健性。只要拥有高精度地图和有效的传感器,我们就能够一直定位。
  • 缺点:难以构建高精度地图并使其保持最新。事实上几乎不可能让地图完全保持最新,因为每个地图均包含瞬态元素(如汽车、行人、街道上的垃圾等),世界上的许多元素都在不断发生变化。

5、百度的激光点云定位模块




五、视觉定位







  • 优点

    • 图像数据比较容易获得
    • 对于一些具有明显Semantic意义的特征,如车道线、红绿灯的柱子、红绿灯、一些Traffic Sign等,视觉定位非常有用。
  • 缺点
    • 缺乏三维信息和对三维地图的依赖。
    • 对于视觉定位,如果环境变化越大,视觉所受到的影响就越大。所以基于这种特征点(如SIFT特征)的定位(如SLAM里面用的Relocalization)并不是很合适用于车的视觉定位。

六、惯性导航(IMU)

  • 三轴加速度计提供瞬时的加速度(车辆坐标系下)。
  • 三轴陀螺仪提供瞬时角速度。将车辆坐标系下的测量值转换为全局坐标系。如下图所示,三轴陀螺仪的三个外部平衡环一直在旋转,但其旋转轴始终固定在世界坐标系中。所以我们可以通过测量旋转轴和三个外部平衡环的相对位置来计算车辆在坐标系中的位置。

  • IMU的工作过程:首先是角速度通过积分后得到一个姿态,并把它应用到加速度上,对加速度积分得到速度,再得到最后的位置。



七、多传感器融合定位

多传感器融合定位的核心是中间的卡尔曼滤波器,这是一个状态误差的卡尔曼滤波器。该滤波器接收惯性导航输出的递推,作为它的时间更新,保证滤波器往前走和高频的输出。还接受GPS、激光点云定位,或者是视觉定位的输出去做低频的状态更新。





绿车是定位结果,蓝车是只有GPS和IMU的结果。

百度无人车定位进化历程

  • “探路者” 这套车的传感器配置非常贵,都用最好的惯导和最好激光雷达,目的是用于探索一些新的算法,一些复杂的场景、有挑战的场景,主要是为了给工程师提供一个较好的平台,用更好的数据去开发更好的算法。下图是探路者在雨天、林荫路上时的场景。

  • 无人驾驶微循环车是和厦门金融合作,叫阿波龙。它配备了一个很便宜的惯导。激光雷达用了16线,再加上一些双目摄像头。下图是阿波龙在海淀公园时的场景。

  • 无人驾驶物流车,是和新石器一起开发的,一般情况下可以用于小区的无人快递车或者是广场上面去卖饮料的无人车。下图是无人驾驶物流车在百度大厦(稍微封闭的环境)时的场景。

Apollo课程学习3——定位相关推荐

  1. Apollo学习笔记 进阶课程之三:定位技术②

    Apollo学习笔记 进阶课程之三:定位技术② 百度的无人驾驶定位方案 1).GNSS定位 GPS误差来源: 上图为单点定位,基于TOA 载波定位技术:(RPK技术,PPP技术) RPK:可以在五秒内 ...

  2. Apollo自动驾驶入门课程第③讲 — 定位

    目录 1. 定位的概述 2. 定位方法介绍 2.1 GNSS RTK 2.2 惯性导航 2.3 激光雷达定位 2.4 视觉定位 2.5 Apollo定位 本文转自微信公众号:Apollo开发者社区  ...

  3. Apollo学习之定位(一)——激光雷达定位

    在Apollo的多传感器定位文件夹里(/modules/localization/msf)的这些文件()记录了apollo进行激光雷达定位的方式(文件如下) 现在让我们来剖析这些文件 首先来看看loc ...

  4. Apollo星火计划学习笔记——第一讲 使用Apollo学习自动驾驶

    引言 如何学习自动驾驶? 自动驾驶是集车辆.计算机.电子电气.人工智能.通信等多学科应用为一体的的复杂系统.针对自身专业背景结合自动驾驶发展进行学习: 自动驾驶是通过智能系统来驾驶汽车从而取代了驾驶员 ...

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

    Apollo代码学习-车辆运动学模型 前言 车辆模型 单车模型(Bicycle Model) 车辆运动学模型 阿克曼转向几何(Ackerman turning geometry) 小结 Apollo( ...

  6. > 《物联网技术与应用》课程学习笔记

    <物联网技术与应用>课程学习笔记 文章目录 前言 第一次课 1.什么是物联网 2.物联网的特征 3.解释NB-IOT(窄带宽中束物联网)的含义 4.解释RFID有源.无源的含义 ~~5.物 ...

  7. 编程课程学习_如果您想学习数据科学,请从以下编程课程之一开始

    编程课程学习 by David Venturi 大卫·文图里(David Venturi) 如果您想学习数据科学,请从以下编程课程之一开始 (If you want to learn Data Sci ...

  8. 1 Robotics: Aerial Robotics 第3+4周 课程学习记录及课后习题解答

    Robotics: Aerial Robotics 第3+4周 WEEK - 3 Quiz Programming Assignment: 2-D Quadrotor Control WEEK - 4 ...

  9. cs224w(图机器学习)2021冬季课程学习笔记20 Advanced Topics on GNNs

    诸神缄默不语-个人CSDN博文目录 cs224w(图机器学习)2021冬季课程学习笔记集合 文章目录 1. Advanced Topics on GNNs 2. Limitations of Grap ...

最新文章

  1. CSS之布局(轮廓和圆角)
  2. 异常检测算( OneClassSVM、EllipticEnvelope、IsolationForest、LocalOutlierFactor)法比较,基于四个仿真数据集
  3. VC.NET扩展Windows磁盘清理工具的功能
  4. elasticsearch给IK分词器添加自定义词汇
  5. 系统间数据传输,产品经理视角的9千字总结:接口、otter、log4j、SFTP、MQ……...
  6. AWVS14.4.21安装时出现Internet server exception和扫描失败
  7. 一个空值_3秒快速、大批量删除或修改Excel中的空值 | 学术小课堂
  8. java中的object... args参数
  9. PHP图形图像的典型应用 --常用图像的应用(统计图)
  10. Tushare最好用的金融数据接口之一
  11. 网络规划设计师的参考资料和复习书籍
  12. Snagit 2019 for Mac如何合并图像+安装方法详解
  13. Aspose.Word 操作word表格的行 插入行 添加行
  14. error: Could not load host key: /etc/ssh/ssh_host_dsa_key
  15. C语言嵌入式数据结构之链表
  16. 人工神经网络具有的基本属性是什么?
  17. Java通过axis调用WebService
  18. 开源倾情奉献:基于.NET打造IP智能网络视频监控系统
  19. pandas金融数据处理
  20. 51单片机---一起来学习DS1302可调时钟(stc89c52芯片)

热门文章

  1. 问道无法显示服务器,问道今天 是不是维修服务器啊 ?怎么进不去
  2. V4L2系列 之 V4L2驱动框架
  3. 大数据盘点|手机品牌鏖战618,realme突围安卓榜
  4. Buffer缓冲区的相关操作
  5. 谷歌开源基于 ML 的手部跟踪算法
  6. 关于newspaper的使用
  7. 解决TypeError: Type 'list' cannot be serialized.
  8. 职场小故事分享(4)
  9. 内容必须匹配 (cache-ref|cache|resultMap*|parameterMap*|sql*|insert*|update*|delete*|selec
  10. 前端必备服务器知识!!!