自动驾驶系列:激光雷达建图和定位(NDT)

发布时间:2025-01-04 23:59

雷达和激光雷达技术在自动驾驶中发挥关键作用。 #生活知识# #科技生活# #科技改变生活# #未来科技产品#

点击上方“3D视觉工坊”,选择“星标”

干货第一时间送达

作者:LitoNeo

来源:https://zhuanlan.zhihu.com/p/77623762

编辑:点云PCL

前言

定位模块是自动驾驶最核心的模块之一,定位又包括全局定位和局部定位,对于自动驾驶,其精度需要达到厘米级别。本文我们将讨论全局定位,即确定无人车在全局下的位置。
传统的AGV使用一类SLAM(simultaneous localization and mapping)的方法进行同时建图和定位,但是该方法实现代价高,难度大,难以应用到自动驾驶领域。自动驾驶车辆行驶速度快,距离远,环境复杂,使得SLAM的精度下降,同时远距离的行驶将导致实时构建的地图偏移过大。因此,如果在已有高精度的全局地图地图的情况下进行无人车的定位,将极大的简化该问题。

因此,将问题分为独立的两部分:建图Mapping和定位Matching。NDT是一种点云配准算法,可同时用于点云的建图和定位。

NDT配准的原理

以下是一张用于配准的target_map,即已经建好的点云地图

以下是实时扫描到的一帧点云

以下是两幅点云进行配准之后的结果,中间输出的坐标轴为当前位置(x y z Y P R)

通过不断的比对实时扫描到的点云和已经建好的全局点云地图,我们就可以持续获得我们当前的位置。ICP(迭代最近点)等配准算法通过对所有的点或者提取的特征点进行匹配配准以确定当前的位置,但是这样就有一个问题:我们所处的环境是在不断变化的,比如树木的稀疏程度,或者环境中车辆及行人的移动,乃至固有的测量误差,这些都会导致我们实时扫描到的点云与已建立的点云地图有些许的差别,从而导致较大匹配误差。

而NDT可以在很大程序上消除这种不确定性。NDT没有计算两个点云中点与点之间的差距,而是先将参考点云(即高精度地图)转换为多维变量的正态分布,如果变换参数能使得两幅激光数据匹配的很好,那么变换点在参考系中的概率密度将会很大。因此,可以考虑用优化的方法,比如牛顿法,求出使得概率密度之和最大的变换参数,此时两幅激光点云数据将匹配的最好。

可以这样来做一个通俗的理解:NDT把我们所处的三维世界按照一定长度的立方体(比如30cm30cm30cm)进行了划分,类似于一个魔方,每个立方体内并不是存储一个或一些确切的点,而且存储这个立方体被占据的概率密度。当接收到需要匹配的点云时,也按照这样的划分方式进行划分,然后进行配准。

因此,NDT具有以下的特征:

支持更大的地图,更稠密的点云 --因为最终还是要划分成voxel的形式

相比于ICP等基于点的匹配算法,速度更快

 更加容忍环境的细微变化

参考论文:The Normal Distributions Transform: A New Approach to Laser Scan Matching

应用

得益于如今众多的开源算法,我们不必重复造轮子了。
AutoWare是由日本名古屋大学和Tier IV主导的全栈开源自动驾驶系统,其core_percepetion模块中对ndt_mapping和ndt_localization进行了很好的实现。本文将从Autoware的这两个package入手,先梳理其架构和代码,再对其进行修改,以适配本地环境,如TX2。

2.1 NDT_Mapping

以下是NDT_Mapping的结构图

1 输入点云处理

1.1 截取有效范围

对于激光雷达,其过近的点由于落在车体上,过远的点已经非常稀疏,因此都需要被过滤掉。

1.2 降采样

voxel_grid_filter.setLeafSize(voxel_leaf_size, voxel_leaf_size, voxel_leaf_size);

voxel_grid_filter.filter(*filtered_scan_ptr);

2. 设置NDT

ndt.setTransformationEpsilon(trans_eps);

ndt.setMaximumIterations(max_iter);

ndt.setStepSize(step_size);

ndt.setResolution(ndt_res);

ndt.setInputSource(filtered_scan_ptr);

注:ndt.setInputTarget()在更新global_map的时候进行,即直接将global_map输入到ndt_target中

3. 进行ndt配准,计算变换矩阵

ndt.align(*output_cloud, init_guess);

output_cloud: 存储source经过配准后的点云(由于source_pointcloud被极大的降采样了,因此这个数据没什么用)

pcl::transformPointCloud(*scan_ptr, *transformed_scan_ptr, t_localizer); // 对原始点云进行变换(framd_id: /velodyne->/map)

init_guess: ndt计算的初始估计位置,在不使用gnss/imu/odom的情况下,以上一帧车辆位置的变换矩阵作为init_guess 注:ndt对位置不敏感,通常在3m以内都可以迭代计算过去,但是ndt对角度比较敏感,因此初始初始的角度不能与实际相差过大(最好在±45°之内)

4. 每n米更新一次全局地图

if (shift >= min_add_scan_shift)

{

map += *transformed_scan_ptr;

同时使用单独的线程,按照一定的频率进行地图的保存。

最终效果:

每帧扫描到的点云中,落在地面上的点云大概占30%。一般来讲,由于地面作为一个平面其相似性很强,因此这部分点云对定位的作用是不大的,可以考虑去除。但是有另一个因素需要考虑,即地面上的点云对抑制z轴漂移还是有很大作用的,因此,在NDT_Mapping中进行配准时保留地面,但在NDT_Matching中配准时使用去除地面的点云。

2.2 NDT_Matching

以下是NDT_Matching的结构图

可以看出NDT_Matching的逻辑还是很简单清晰的,即不断的接收实时扫描到的点云,以及异步更新target_map,并使用NDT算法不断进行配准获取当前位置。

由于NDT_Matching和NDT_Mapping极为相似,主要更新target_map上不同,因此NDT_Matching的代码不在此处展开了。

本文仅做学术分享,如有侵权,请联系删文。

下载1

在「3D视觉工坊」公众号后台回复:3D视觉即可下载 3D视觉相关资料干货,涉及相机标定、三维重建、立体视觉、SLAM、深度学习、点云后处理、多视图几何等方向。

下载2

在「3D视觉工坊」公众号后台回复:3D视觉github资源汇总即可下载包括结构光、标定源码、缺陷检测源码、深度估计与深度补全源码、点云处理相关源码、立体匹配源码、单目、双目3D检测、基于点云的3D检测、6D姿态估计汇总等。

下载3

在「3D视觉工坊」公众号后台回复:相机标定即可下载独家相机标定学习课件与视频网址;后台回复:立体匹配即可下载独家立体匹配学习课件与视频网址。

重磅!3DCVer-学术论文写作投稿 交流群已成立

扫码添加小助手微信,可申请加入3D视觉工坊-学术论文写作与投稿 微信交流群,旨在交流顶会、顶刊、SCI、EI等写作与投稿事宜。

同时也可申请加入我们的细分方向交流群,目前主要有3D视觉CV&深度学习SLAM三维重建点云后处理自动驾驶、CV入门、三维测量、VR/AR、3D人脸识别、医疗影像、缺陷检测、行人重识别、目标跟踪、视觉产品落地、视觉竞赛、车牌识别、硬件选型、学术交流、求职交流等微信群。

一定要备注:研究方向+学校/公司+昵称,例如:”3D视觉 + 上海交大 + 静静“。请按照格式备注,可快速被通过且邀请进群。原创投稿也请联系。

▲长按加微信群或投稿

▲长按关注公众号

3D视觉从入门到精通知识星球:针对3D视觉领域的知识点汇总、入门进阶学习路线、最新paper分享、疑问解答四个方面进行深耕,更有各类大厂的算法工程人员进行技术指导。与此同时,星球将联合知名企业发布3D视觉相关算法开发岗位以及项目对接信息,打造成集技术与就业为一体的铁杆粉丝聚集区,近2000星球成员为创造更好的AI世界共同进步,知识星球入口:

学习3D视觉核心技术,扫描查看介绍,3天内无条件退款

 圈里有高质量教程资料、可答疑解惑、助你高效解决问题

觉得有用,麻烦给个赞和在看~  

网址:自动驾驶系列:激光雷达建图和定位(NDT) https://www.yuejiaxmz.com/news/view/645433

相关内容

激光雷达被淘汰?百度发布国内首个纯视觉高阶智驾方案
芬兰全电动无人清洁车面世,搭载激光雷达国内龙头企业RoboSense激光雷达
自动驾驶系列—智能驾驶的泊车革命:APA自动泊车技术全解析
激光雷达加持!零跑C16引领未来智能驾驶体验
自动驾驶系列—GPS技术在自动驾驶中的应用与挑战:全面解析
智能驾驶辅助系统,哪些车有自动驾驶辅助系统
自动驾驶
镭神智能激光雷达全新升级,“扫清”灰尘雨雾,还原清晰视界
自动驾驶系列—自动驾驶数据脱敏:保护隐私与数据安全的关键技术
详述人工智能在自动驾驶中的应用

随便看看