龙空技术网

激光点云系列之三:点云配准

九章智驾 149

前言:

现在看官们对“基于刚体变换的ndt配准算法有哪些”都比较关注,我们都需要分析一些“基于刚体变换的ndt配准算法有哪些”的相关资讯。那么小编同时在网络上搜集了一些对于“基于刚体变换的ndt配准算法有哪些””的相关文章,希望我们能喜欢,各位老铁们一起来了解一下吧!

作者 | 奚少华

在第一篇《详解激光雷达点云数据的处理过程》和第二篇《激光雷达点云处理中遇到的问题及对策》的激光点云系列文中,笔者分别分析了激光雷达的点云处理流程和点云处理环节中遇到的典型问题及对策。在本篇文章中,笔者将重点分析激光点云在定位环节中的点云配准技术。

由于受到视场角的限制,激光雷达在实时采集点云数据时,只能获得有限视野范围内的点云图像。为了获得三维场景的点云数据,感知算法人员需要在已知的初始姿态信息下,将采集到的前后两帧不同点云转换到统一坐标系下,将点云重合的部分拼接在一起——这就是点云配准技术。

下文将逐一分析点云配准具体是什么、点云配准的技术方法、点云配准面临的问题及对策。

01

点云配准在自动驾驶方面的应用

点云配准早先主要应用于建筑行业中的建筑信息模型(BIM)、采矿行业中的矿区开采等,而在自动驾驶领域内的作用主要有三类,分别为三维地图构建、高精地图定位、姿态估计。

第一,三维地图构建。在建高精地图时,自动驾驶系统通过激光雷达采集回来的相邻帧点云进行点云配准后,将不同位置采集回来的点云统一到一个坐标系下,然后构建出一个三维的高精度地图。

第二,高精地图定位。在自动驾驶车辆行驶时,车辆需要做到厘米级的精准定位。例如,自动驾驶车辆需要估计其在地图上的精确位置及车与道路路沿的距离。自动驾驶系统通过点云配准技术,将实时采集到的点云数据与高精地图的数据做匹配,为自动驾驶车辆给出精确的定位。

第三,姿态估计。自动驾驶系统通过点云配准技术来估计车辆的相对姿态信息,然后并有利于对车辆做决策规划。

02

点云配准的工作原理与技术方法

2.1点云配准的工作原理

点云配准的工作原理是激光雷达由于受到环境等各种因素的限制,在点云采集过程中单次采集到的点云只能覆盖目标物表面的一部分,为了得到完整的目标物点云信息,就需要对目标物进行多次扫描,并将得到的三维点云数据进行坐标系的刚体变换,把目标物上的局部点云数据转换到同一坐标系下。

通俗点来说,点云配准的关键是如何寻找到初始点云和目标点云之间的对应关系,然后通过这个对应关系将原始点云和目标点云进行匹配,并计算出它们的特征相似度,最后统一到一个坐标系下。

图:点云的三维建图效果

(数据来源:互联网)

点云配准通常可分为两个步骤,分别是粗配准和精配准。

粗配准,即点云的初始配准,指的是通过一个旋转平移矩阵的初值,将两个位置不同的点云尽可能地对齐。粗配准的主流方法包括RANSAC、4PCS等。

经过粗配准之后,两片点云的重叠部分已经可以大致对齐,但精度还远远达不到自动驾驶车辆的定位要求,需要进一步做精配准。

精配准指的是在初始配准的基础上,进一步计算两个点云近似的旋转平移矩阵。精配准的主流方法包括ICP、NDT、深度学习等。

2.2点云配准的技术方法

上文提到了一些点云配准的具体方法,由于各家自动驾驶公司的技术水平与技术方案都不同,所以他们会采用不同的点云配准方法——有些公司会在粗配准或者精配准过程中只采取一种方法,也有些公司会采取多种组合的方法。比如,在精准配过程中,某些公司会采用ICP+深度学习的方式。该章节将详细论述上文的几种点云配准方法。

2.2.1粗配准的技术方法

(1)RANSAC(RAndom SAmple Consensus,随机采样一致)

方法原理:该算法从给定的样本集中随机选取一些样本并估计一个数学模型,将样本中的其余样本带入该数学模型中验证,如果有足够多的样本误差在给定范围内,则该数学模型最优,否则继续循环该步骤。

RANSAC算法被引入三维点云配准领域,其本质就是不断的对源点云进行随机样本采样并求出对应的变换模型,接着对每一次随机变换模型进行测试,并不断循环该过程直到选出最优的变换模型作为最终结果。

具体步骤:

1)对点云进行降采样和滤波处理,减少点云的计算量。

2)基于降采样和滤波处理后的点云数据,进行特征提取。

3)使用RANSAC算法进行迭代采样,获取较为理想的变换矩阵。

4)使用所获得的变换矩阵进行点云变换操作。

优点:适用于较大点云数据量的情况,可以在不考虑点云间距离大小的情况下,都能实现点云的粗配准。

缺点:存在配准精度的不稳定的问题。

(2)4PCS(4-Points Congruent Sets,全等四点集)

方法原理:该算法利用刚体变换中的几何不变性(如向量/线段比例、点间欧几里得距离),根据刚性变换后交点所占线段比例不变以及点之间的欧几里得距离不变的特性,在目标点云中尽可能寻找4个近似共面点(近似全等四点集)与之对应,从而利用最小二乘法计算得到变换矩阵,基于RANSAC算法框架迭代选取多组基,根据最大公共点集(LCP)的评价准则进行比较得到最优变换。

具体步骤:

1)在目标点云集合中寻找满足长基线要求的共面四点基(基线的确定与输入参数中overlap有很大关系,overlap越大,基线选择越长,长基线能够保证匹配的鲁棒性,且匹配数量较少)。

2)提取共面四点基的拓扑信息,计算四点基间的两个比例因子。

3)计算四种可能存在的交点位置,进而计算所有中长基线点对的交点坐标,比较交点坐标并确定匹配集合,寻找到对应的一致全等四点。

4)寻找点云中所有的共面四点集合,重复上述步骤可得到全等四点集合,并寻找最优全等四点对。

优点:适用于重叠区域较小或者重叠区域发生较大变化场景点云配准,无需对输入数据进行预滤波和去噪。

缺点:不适合工程化应用。

2.2.2精配准的技术方法

(1)ICP(Iterative Closest Point,最近点迭代法)

方法原理:选取两片点云中距离最近的点作为对应点,通过所有对应点对求解旋转和平移变换矩阵,并通过不断迭代的方式使两片点云之间的配准误差越来越小,直至满足我们提前设定的阈值要求或迭代次数。

具体步骤:

1)计算源点云中的每一个点在目标点集中的对应近点。

2)求得使上述对应点对平均距离最小的刚体变换,并求得平移参数和旋转参数。

3)对求得的平移和旋转矩阵进行空间变换,得到新的变换点集。

4)如果新的变换点集与参考点集满足两点集的平均距离小于某一给定阈值,或者迭代次数达到设定的最大值,则停止迭代计算,否则新的变换点集作为新的源点云继续迭代,直到达到目标函数的要求。

优点:

1)不需要对点云集进行分割和特征提取。

2)在初值较好的情况下,可以得到很好的算法收敛性。

缺点:

1)在搜索对应点的过程中,计算量较大,计算速度较慢。

2)对配准点云的初始位置有一定要求,不合理的初始位置会导致算法陷入局部最优。

3)ICP算法在寻找对应点时,模型会将任何两个点云之间的欧氏距离最近的点作为对应点,这种假设会产生一定数量的错误对应点。

(2)NDT(Normal Distribution Transform,正态分布点云算法)

方法原理:先对待配准点云进行栅格化处理,将其划分为指定大小的网格,通过正态分布的方式,构建每个网格的概率分布函数,之后优化求解出最优变换参数,使得源点云概率密度分布达到最大,以实现两个点云之间的最佳匹配。

具体步骤:

1)将空间划分成各个格子cell(也叫体素voxel grid)。

2)将参考点云投到各个网格中。

3)基于网格中的点,计算格子的正态分布概率密度函数(probability density function, PDF)的参数。

4)将第二幅点云的每个点按转换矩阵变换。

5)第二幅扫描点云的点落于参考点云的哪个网格,计算相应的概率分布函数PDF。

6)求最大似然函数,得到最优变换参数。

优点:

1)对初始配准的要求不高,即使初始值的误差较大,也能有很好的效果。

2)不需要进行点云之间的特征匹配,避免了特征匹配中出现的问题,例如点云噪声、物体移动、点云重合度对特征匹配的影响。

缺点:

1)对体素格子大小的要求较高,太大会导致配准精度低,而太小会导致计算量加大。

2)配准精度相比ICP算法略低。

(3)基于深度学习的点云配准

深度学习除了应用在感知层面,也应用到了定位层面的点云配准环节中。

基于深度学习的点云配准指的是利用深度学习模型来提取原始点云的特征,从而获取到点云的初始配置值,然后根据特征值再进一步地完成精配准。近年来,常见的基于深度学习的点云配准方法包括PointNetLK,Deep ICP,DCP,PRNet,IDAM,RPM-Net,3DRegNet,DGR等。

相比于其它传统的配准方法(ICP和NDT),基于深度学习的方法可以使得计算速度更快,并能学习到更高级的特征,从而达到更高的鲁棒性。

根据配准方法的结构是完全由深度神经网络组成还是将非深度学习方法的一部分组件替换为基于深度学习的网络,将基于学习的点云配准方法分为部分深度学习的方法和端到端的深度学习方法。

部分深度学习的点云配准方法是指直接用基于深度学习的组件替换掉非深度学习点云配准方法中的某个组件,这就可能给原来的算法带来速度或鲁棒性的提升。部分深度学习的点云配准方法最大的优势在于灵活性较大。

端到端的点云配准方法是指从点云的输入到最后的配准结果都在一个完整的网络中实现。端到端的点云配准方法能够最大程度地发挥深度学习方法的高效和智能,也能够更好地发挥GPU的并行计算能力,有更快的计算速度。

当前,自动驾驶行业内应用点云配准技术仍属于前期阶段。某自动驾驶公司感知算法工程师说:“基于深度学习的点云配准仍然处于早期阶段,其应用的精度无法保证,而且结合ICP等传统方法的应用也需要大量的计算时间。”

03

点云配准面临的问题及对策

3.1 配准时点云数量过多的问题及对策

当前,车上的数据都是先上传到云端再处理,但这样一方面数据的回传成本很高,另一方面,无法做到数据处理的实时性,进而难以保障自动驾驶车辆的安全性,因此,需要将数据处理环节在车端完成。

现有量产车上的算力有限,无法直接处理庞大的点云数据,这成为了点云配准时的一大障碍,而解决这一问题的主要方法就是点云精简。

点云精简是指将目标点云数据集合中的无用点云去除。主要可以有两种方式来实现:

1)去除冗余是指在数据配准之后,将一些重复区域的数据予以去除,而这部分数据的数据量大,并且多为无用数据,对建模的速度以及质量有很大影响。

2)抽稀简化是指由于激光雷达扫描获得的点云数据密度过大、数量过多,其中一部分数据对于后期建模用处不大,所以在满足一定精度以及保持被测物体几何特征的前提下,该部分数据就需要进行精简,以提高数据的实际运算速度、建模效率以及模型精度。

3.2点云初始配准的问题及对策

在前文中提到,初始配准也叫作粗配准,它是点云配准的关键点,一般通过IMU和车辆轮速计的运动数据来获取配准的初始值,但当前行业内点云初始配准的效率不高。

提高初始配准的效率可以缩小不同视角下的点云之间的旋转错位和平移错位,同时可以提高点云配准整体的成功率和效率。

对于ICP算法来说,初始配准的初始值效果会很大程度上影响ICP算法的精度。对于NDT算法来说,虽然初始值对于算法的效果不敏感,但是提高初始配准的效率和质量,也同样能提升NDT算法的配准精度。

那么,在自动驾驶领域内,技术人员是如何提高点云的初始配准效率?

一种是抓取目标关键点。纵目科技感知算法工程师汤强说:“为了提高点云的初始配准,最直接的方法就是提取选取一个关键目标,比如一辆车,然后从这个关键目标上选取几个关键点去做旋转矩阵和平移矩阵。”

另一种是特征提取,比如FPFH(快速点特征直方图)。图达通算法负责人许建博士说:“区别于ICP算法和NDT算法,基于特征提取的点云配准方法可以提高点云配准速度和精度。它通过提取的一些特征后(如棱角或者线、面),利用两个点云间的空间拓扑结构,来进行点云之间的匹配。此外,实际工程应用中,数据关联、系统偏差估计等在线点云配准技术也非常重要。”

3.3同源点云配准的问题及对策

同源点云配准是指从同一类型的传感器获取点云数据,但在不同的时间和视角下进行的点云配准。

在自动驾驶车辆上,除了一颗主激光雷达外,车端可能还会配置一些补盲激光雷达,或者采用两颗以上的主激光雷达方案。这些激光雷达采集的点云都属于是同源点云数据,但是从不同激光雷达采集回来的点云,由于从不同时间点和不同视角采集的情况,在点云配准时会遇到一些问题。

一方面,多个激光雷达从不同角度采集回来的点云数据,它们的三维坐标系不同,并且产生的噪点所在的坐标系也不同。在做点云配准时,点云数据需要统一到一个坐标系下才可以实现更精准的配准效果。

许建说:“为了能让多个激光雷达采集的点云统一到同一坐标系下,在联合标定时,多目标的点云配准会比单目标的点云配准带来更多的信息,使得配准精度会更高。单一目标的话,激光扫描到目标物上的时,目标边缘点云不完整,会影响配准的精度。多目标的话,激光雷达采集的点云信息会更多。比如,目标静止的时候,多目标之间就会形成拓扑结构信息,使得点云初始配准的信息更丰富,有利于提高配准整体的精度。”

另一方面,不同激光雷达之间的硬件性能指标可能不同,这会造成同一目标物表面覆盖的点云数量可能都不同。

汤强说:“不同性能的激光雷达,它们的角分辨率参数都不同,意味着点云密度不同,导致点云配准最终效果会受到影响。为了调节点云密度的不同,感知算法人员可以应用点云精简的方法,降低点云密度较高的激光雷达参数,也可以从硬件上进行调节,例如,技术人员可能会将两个激光雷达的角分辨率调节至同一个水平上。”

3.4跨源点云配准的问题及对策

跨源点云配准是指对不同类型传感器的点云进行配准。它的优点是结合多个不同类型的传感器各自的优势,为自动驾驶系统提供更丰富的三维点云信息。相比于同源点云配准,跨源点云配准尚处于学术阶段,而其在自动驾驶领域的应用也是预研阶段。

某自动驾驶方案商的技术专家说:“跨源点云配准是未来点云配准技术的主要挑战之一。”

具体来说,由于不同类型的传感器之间的工作原理不同,传感器之间的点云的分辨率、点云密度质量、点云图像画面尺度、点云距离信息等都会不相同,而这些问题造成了跨源点云配准的技术实现难度大大增加。

以4D成像雷达与激光雷达为例,虽然4D成像雷达可以与激光雷达一样,能够形成点云数据,但是4D成像雷达的点云密度或许只能达到某些低线数的激光雷达(如16线、32线等),而无法达到高线数激光雷达(如128线等)的点云密度。另外,在角分辨率参数上,4D成像雷达只能接近1°的参数水平,而某些激光雷达可以做到0.1°的水平。当两个传感器扫描到同一个物体表面时,它们各自采集到的点云效果也会不同。例如在车辆前方较远处的点云数据中,激光雷达的点云质量或许比4D毫米波的点云质量会更好(前者的能量返回更多以及点云数量更多), 造成了最终点云配准的精度下降。

在现有的学术研究中,跨源点云配准的方法已有很多,但主要是在增强现实、建筑施工等领域内有应用,在自动驾驶领域内几乎没有相应的应用。下图为笔者整理的一些跨源点云配准的方法。比如,CSGM是将配准问题转化为图匹配问题,并利用图匹配理论来克服跨源点云配准的问题。再比如,FMR是探讨了深度学习在跨源点云配准的方面的应用。

图:跨源点云配准方法

(数据来源:《2021最新关于点云配准的全面综述》)

参考文献

【1】点云配准,自动驾驶里的“滴血认亲”

【2】2021最新关于点云配准的全面综述

【3】RANSAC算法思想与实现点云粗配准

【4】3D点云配准算法-4PCS(4点全等集配准算法)

【5】ICP点云配准算法

【6】点云配准ICP&NDT

【7】基于学习的点云配准方法

标签: #基于刚体变换的ndt配准算法有哪些 #基于刚体变换的ndt配准算法有哪些步骤 #点云标定