Nicolas Mellado,CNRS(Centre national de la recherche scientifique,法国国家科学研究中心)的研究员,在IRIT(Institut de Recherche en Informatique de Toulouse,图卢兹计算机科学研究所)实验室的STORM研究小组工作,从事计算机图形学研究。也是Archeovision的副研究员,Archeovision是一个CNRS实验室,研究如何通过获取,建模和处理3D数据来用于文化遗产研究。研究兴趣集中在分析通过获取物理对象或场景生成的非结构化数据(通常是点云),这是几个研究社区(计算机&图形学,模式识别等)和行业中非常热门的话题。作者个人主页:https://www.irit.fr/recherches/STORM/MelladoNicolas/
四点一致集算法4PCS(4-Points Congruent Sets)由Dror Aiger于2008年提出,2014年Mellado对其进行了改进,降低了搜索阶段的复杂度,提高了配准效率,形成了Super 4PCS(Super 4-Point Congruent Sets)算法。4PCS与Super 4PCS算法基本思想都是基于RANSAC(随机抽样一致)算法,4PCS算法对确定对应点对的策略进行了优化,将原本的随机选择三个不同的点修改为以源点云中共面的四点为基,在目标点云中确定对应的四点,以构成对应四点集,这样需要验证的点集会大大减少,并且能更快的找到两组点云的最佳匹配,同时,由于四点集具有仿射不变性,在一定程度上可增强算法的鲁棒性。但是4PCS算法在搜索共面四点集过程中要耗费大量的时间,并且在找到的全等集合U中包含大量的冗余点集,需要浪费大量的时间去验证这些冗余点集(点云重叠率的计算比较耗时),因此4PCS算法很难做到快速实时的配准。针对4PCS算法配准速度非常慢的缺点,Mellado提出了Super 4PCS算法,利用智能索引使4PCS算法的计算复杂度显著降低。该方法适用于重叠区域较小或者重叠区域发生较大变化场景点云配准,无需对输入数据进行预滤波和去噪,能够快速准确的完成点云配准。
4PCS算法主要是根据共面四点之间的仿射不变关系来确定对应点的,如图所示,在仿射变换中,由三个确定的共线点a、b和c所确定比例r是不变的,对于给定的非全共线的共面四点a、b、c和d,有ab与cd相交于点e,可确定两个比例r_1和r_2 。 r_1和r_2在仿射变换中是不变的,即由源点云P中的四个共面点B={a,b,c,d}所确定的和由目标点云Q中对应的四个点所确定的是相同的。
r_1=||a−e||/||a−b|| r_2=||c−e||/||c−b||
然后根据这两个仿射不变量寻找对应的四点集,如图6所示,对目标点云Q中的任意两点计算可能存在的交点e_1和e_2: e_1=q_1+r_1(q_2−q_1) e_2=q_1+r_2(q_2−q_1)
若一对点计算出的e_1和另一对点计算出的e_2近似相等,如图所示,其中灰色点代表e_1,黄色点代表e_2,则q_5、q_3、q_4、q_1与a、b、c、d相对应。另外,对于刚体变换来说对应点对之间的距离不变,所以在刚体变换的情况下寻找对应四点集还时还应加上如下约束条件: d_1^′=||a^′−b^′||≈||a−b||=d_1 d_2^′=||c^′−d^′||≈||c−d||=d_2
找到所有与B对应的四点集U={U_1,U_2,...,U_n},则根据基B和与其对应的每一个四点集U_i都可以计算出一个刚体变换矩阵T_i,将T_i应用于源点云进行变换,并通过比较最大公共点集(Largest Common Pointset,LCP)确定最终的变换矩阵。但是4PCS算法在搜索共面四点集过程中要耗费大量的时间,并且在找到的全等集U中包含大量的冗余点集,需要浪费大量的时间去验证这些冗余点集,因此4PCS算法很难做到快速实时的配准。 为了解决这两个问题,Super 4PCS算法使用了智能索引使4PCS算法的计算复杂度显著降低。4PCS算法的时间复杂度是O(n^2+k),n是目标点云Q中点的数量,k是近似全等点集的数量。Super 4PCS算法使用智能索引对4PCS算法做了两个方面的改善:(1)利用栅格化点云的方法加速了根据距离搜索匹配点对的过程;(2)对找到点对中的冗余点对进行剔除。通过上面两个改进,将算法的时间复杂度降到最优线性复杂度O(n+k_1+k_2),其中n是目标点云Q中点的数量,k_1是点云Q中相距为d的点对的数量,k_2是经过滤波后得到的全等集合的数量。
针对改进(1),两个点云P和Q,首先从P中找到一个平面四点集B={p_1,p_2,p_3,p_4},算法的目标是在Q中提取所有与B全等的共面四点集。定义d_1=||p_1−p_2||,d_2=||p_3−p_4||,对于任意q_i∈Q,需要找到所有距离为d_1±ε和d_2±ε的点。如图所示,Super 4PCS算法对这个问题使用栅格化处理的方法,首先将Q标准化,把Q中所有点放到网格G中,然后对G进行栅格化处理,栅格大小为ε,然后以每个点为球心画半径为d±ε的球。通过在网格上执行超球面的同步自适应栅格化,递归地细分包围Q的空间,并计算一组超球体与细分体之间的交点,然后在球心和相交的点之间实现点对提取。记q_i与那些落在[d_1−ε,d_1+ε]范围内的点组成的点对集合为S_1,而q_i与那些落在[d_2−ε,d_2+ε]范围内的点组成的点对的集合为S_2,公式如下。 S_1={(q_i,q_j)│q_i,q_j∈Q,||p_i−p_j||∈[d_1−ε,d_1+ε]} S_2={(q_i,q_j)|q_i,q_j∈Q,||p_i−p_j||∈[d_2−ε,d_2+ε]}
针对改进(2),4PCS算法找到了和点集B近似全等的四点集U,但是U中的点集并不全都与B全等,这些不全等的点集就是冗余点集。如图所示,点集{(p_1,p_2),(p_3,p_4)}对应{(q_1,q_2),(q_3,q_4)}和{(q_1^′,q_2^′),(q_3,q_4)},但是{(q_1^′,q_2^′),(q_3,q_4)}和{(p_1,p_2),(p_3,p_4)}并不全等,因此{(q_1^′,q_2^′),(q_3,q_4)}是冗余点集,这就导致了4PCS算法的低效,浪费了大量时间去验证这些冗余点集。因此,Super 4PCS算法通过从点云Q中提取对应于线段之间的相同角度,相同距离以及相同不变量的四个共面点来解决此问题。设B={p_1,p_2,p_3,p_4}为从P中提取的共面四点集,e为线段p_1p_2和p_3p_4的交点,定义距离d_1=||p_1−p_2||,d_2=||p_3−p_4||,不变量r_1=||p_1−e||/d_1,r_2=||p_1−e||/d_2,由上述方法已在Q中找到了分别相距d_1和d_2的两个点对集合S_1和S_2。 S_1={(q_i,q_j)│q_i,q_j∈Q,||p_i−p_j||∈[d_1−ε,d_1+ε]} S_2={(q_i,q_j)|q_i,q_j∈Q,||p_i−p_j||∈[d_2−ε,d_2+ε]}
将角度匹配问题映射到一组法线的索引中,这样对于任何给定的查询法线n和角度θ,可以快速查询到所有与n存在角度偏差为θ的法线。将法线视为单位球(高斯球)上的一个点,查询一个单位圆上的所有点。如下图点c,圆由相对于查询法向n角度偏差为θ的法线定义。对于近似参数ε,我们栅格化一个圆,设置其单元格大小为ε。查询法线n由一个箭头表示,它定义了单位球体上的圆,该圆包含与n成角度θ的所有点。之后做全等四点集提取,构造一个单元大小为ε的网格,并在每个网格中存储如上所述的法线索引。对一个有序点对(p_1,p_2)进行方向描述方,并且对另一个点对进行同样的方向描述。通过遍历S_1中的所有点对,并计算一个新的点e,对应不变量r_1。在映射到网格的单元格中添加e,并在R^3中添加一个向量,表示从p_1到p_2的归一化方向。随后将向量插入增广法线索引中。在这一阶段的最后,所有与不变量r_1对应的点e_i都存储在网格单元中,它们的法线存储在每个单元的法线索引中。对于给定的点集B,有相交线之间的夹角θ来提取S_2中与这个夹角一致的点对,即它们与S_1中对应的对之间的夹角近似为θ。在这一阶段的最后,我们有一个Q中的4点集,它们全等于点集B,它是实集,不是超集。