CN112381862A - 一种cad模型与三角网格全自动配准方法和装置 - Google Patents

一种cad模型与三角网格全自动配准方法和装置 Download PDF

Info

Publication number
CN112381862A
CN112381862A CN202011165530.3A CN202011165530A CN112381862A CN 112381862 A CN112381862 A CN 112381862A CN 202011165530 A CN202011165530 A CN 202011165530A CN 112381862 A CN112381862 A CN 112381862A
Authority
CN
China
Prior art keywords
point
point cloud
sampling
points
feature
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202011165530.3A
Other languages
English (en)
Other versions
CN112381862B (zh
Inventor
任茂栋
邬宏
冯超
唐正宗
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Xtop 3d Technology Shenzhen Co ltd
Original Assignee
Xtop 3d Technology Shenzhen Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Xtop 3d Technology Shenzhen Co ltd filed Critical Xtop 3d Technology Shenzhen Co ltd
Priority to CN202011165530.3A priority Critical patent/CN112381862B/zh
Publication of CN112381862A publication Critical patent/CN112381862A/zh
Application granted granted Critical
Publication of CN112381862B publication Critical patent/CN112381862B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/30Determination of transform parameters for the alignment of images, i.e. image registration
    • G06T7/33Determination of transform parameters for the alignment of images, i.e. image registration using feature-based methods
    • G06T7/344Determination of transform parameters for the alignment of images, i.e. image registration using feature-based methods involving models
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T17/00Three dimensional [3D] modelling, e.g. data description of 3D objects
    • G06T17/20Finite element generation, e.g. wire-frame surface description, tesselation

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Graphics (AREA)
  • Geometry (AREA)
  • Software Systems (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Image Analysis (AREA)

Abstract

本发明公开了CAD模型与三角网格全自动配准方法和装置,包括:S1、读取标称CAD模型和初始扫描三角网格;提取初始扫描三角网格顶点作为源点云,标称CAD模型细分后的CAD三角网格的顶点作为目标点云;S2、对源点云和目标点云采样,计算采样点法向量;S3、将采样点作为特征点并用FPFH描述特征点;S4、对目标点云特征点,在FPFH空间构建kd‑tree;从源点云特征点中选四个特征点并在目标点云中查找四个最近邻点构成四个对应点对;S5、快速剔除错误点对;S6、用四个对应点对估计基本矩阵作为迭代初值重复步骤S4和S5进行RANSAC迭代,得到有效点对集;S7、对有效点对集进行奇异值分解得到旋转平移矩阵;S8、利用旋转平移矩阵对源点云进行旋转平移完成配准。

Description

一种CAD模型与三角网格全自动配准方法和装置
技术领域
本发明涉及工业数字化检测技术领域,具体涉及一种CAD模型与三角网格全自动配准方法和装置。
背景技术
近年来,随着三坐标测量机、三维扫描系统、CT测量仪等数字化检测设备在工业领域的广泛应用,数字化检测技术在大型、复杂零件的尺寸测量和保证制造精度方面发挥着至关重要的作用。
在实际检测过程中,数字化检测设备获得的三角网格,其本身的测量精度一般都能够满足实际测量要求,然而由于扫描得到的三角网格与CAD模型在空间坐标系中的原点不同,所以这对后续的尺寸偏差分析会造成影响,甚至可能导致零件合格性的误判,使得数字化测量设备的测量精度失去意义。因此,为提高零件制造精度和合格率,实现网格模型与CAD模型的配准就成为数字化检测技术应用的一个关键。
目前关于网格模型与CAD模型的配准主要有基于点集迭代的配准方法和基于几何特征的配准方法。其中,基于点集迭代的配准方法不考虑被测零件的几何特征,直接利用点云集合查找CAD模型上的对应点并通过对应点对的反复迭代实现点云模型与CAD模型的配准,其中最具代表性的是迭代最近点算法(Iterative Closest Point,简称ICP算法)。此类算法的时间复杂度随点云数目和迭代次数的增加而显著增大,因此配准效率较低。同时,这类算法的配准控制点集为点云模型的子集,配准准确性严重依赖于点云模型,当初始的源点云和目标点云相对位置偏差较大时,容易出现误匹配,从而导致算法失效,无法实现配准。
基于几何特征的配准方法通过对点云数据中可以反映局部几何特征的点集进行采样分析,再将所采样的点集作为配准控制点,从而减少配准点集的数量,因而计算速度快。但由于复杂的点云模型的几何特征识别难度极大,而且不同零件的点云模型一致性差,因此这种配准方法会丢失反映零件制造质量的关键特征,造成配准结果的准确性不高、不稳定,实用性不强。
发明内容
鉴于上述分析,现有的配准方法未能对CAD模型做有效处理,并且受限于实际测量获得的模型通常含有极大的点云数据量,现有的配准方法在配准精度和配准速度方面存在明显不足。
本发明的主要目的在于提出一种面向工业检测的CAD模型与三角网格全自动配准方法和装置,以克服现有的配准方法所存在的上述问题。
为达上述目的,本发明采用以下技术方案:
一种CAD模型与三角网格全自动配准方法,包括如下步骤:
S1、读取标称CAD模型和用三维扫描系统扫描得到初始扫描三角网格模型;提取初始扫描三角网格模型的顶点作为待配准的源点云;利用CAD三角剖分算法对所述标称CAD模型进行三角剖分,得到CAD三角网格,再对该CAD三角网格进行细分以提高点云均匀度和稠密度,并提取细分后的CAD三角网格的顶点作为目标点云;
S2、分别对所述源点云和所述目标点云进行采样,采样比例根据所述源点云和所述目标点云的平均点距r0自适应确定;计算采样后的源点云和目标点云中的每一采样点的法向量;
S3、将源点云和目标点云中的每一采样点作为特征点,根据各采样点的法向量分别计算各采样点的点快速特征直方图,利用所述点快速特征直方图描述对应的所述特征点;
S4、对于目标点云中的特征点,在点快速特征直方图特征空间构建kd-tree;从源点云中的特征点中随机选择四个特征点,根据建立好的kd-tree,在目标点云中查找并记录所述四个特征点中每个特征点的最近邻点,以作为所述四个特征点在目标点云中的对应点,从而得到四个对应点对;
S5、对于所述四个对应点对,利用修剪算法剔除误匹配点对;
S6、利用所述四个对应点对估计基本矩阵作为迭代初始值,重复步骤S4和S5进行RANSAC迭代,在后面的重复迭代过程中仅将满足修剪算法的匹配点对用于计算更新基本矩阵,并在整个源点云上进行验证以筛选正确匹配点对;最后选取具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵,并将该数据集作为有效点对集;
S7、针对步骤S6得到的有效点对集,进行奇异值分解,求解出旋转平移矩阵;
S8、利用所述旋转平移矩阵对步骤S1中待配准的源点云进行旋转平移,完成所述标称CAD模型与所述初始扫描三角网格的全自动配准。
更进一步地,步骤S1中对所述CAD三角网格进行细分时采用Loop细分算法;步骤S2中对所述源点云和所述目标点云进行采样的方法是体素采样。
更进一步地,步骤S2在求取每一采样点法向量的过程中,均需要搜索被求点的第一邻域半径r1内的邻域点来拟合平面,并以平面的法向量作为被求点的法向量;其中,所述第一邻域半径r1根据所述平均点距r0来设置。
更进一步地,步骤S3中点快速特征直方图的计算过程包括:
S31、根据平均点距r0确定第二邻域半径r2,对于采样后的源点云和目标点云中的任意采样点p:都以该采样点p为原点选择所述第二邻域半径r2内的所有近邻点,并分别计算该采样点p与采样点p的每个近邻点之间的三个特征元素值,然后将所有特征元素值统计成采样点p的简化点特征直方图;
S32、分别对所述第二邻域半径r2中的每个所述近邻点再确定邻域,并对所述第二邻域半径r2中的每个点按照步骤S31形成各自的简化点特征直方图;
S33、对采样点p的所述第二邻域半径r2中每个所述近邻点的简化点特征直方图进行加权统计:
Figure BDA0002745653920000031
其中,FPFH(p)表示采样点p的点快速特征直方图,SPFH(p)表示采样点p的简化点特征直方图,权重wi表示采样点p与所述第二邻域半径r2中第i个近邻点pi之间的距离,k表示采样点p的k邻域,SPFH(pi)表示所述第i个近邻点pi的简化点特征直方图。
更进一步地,所述第一邻域半径r1为1.5r0≤r1≤2.5r0,所述第二邻域半径r2为4r0≤r2≤6r0
更进一步地,步骤S31中所述三个特征元素值的计算过程包括:对于两个点ps及pt(s≠t),在其中一个点处定义一个固定的坐标系ps-uvw,该坐标系的三坐标轴定义如下:
Figure BDA0002745653920000041
其中点ps为源点云和目标点云中当前正在求解点快速特征直方图的采样点,称为查询点;点pt表示点ps的第二邻域半径r2内的任意一个近邻点,ns为点ps的法向量,||pt-ps||2为点ps与点pt之间的距离,
Figure BDA0002745653920000042
为点ps到点pt的单位向量;
点ps的表面法线的角度变换由下式确定,式中α、φ、θ即为采样点ps与近邻点pt之间的三个特征元素:
Figure BDA0002745653920000043
其中,nt为点pt的法向量。
更进一步地,步骤S31中采样点ps的简化点特征直方图的建立包括:将采样点ps及第二邻域半径r2内各个近邻点之间的三个特征元素值合并到直方图中,其中,合并过程是将每个特征元素的取值范围划分为5个子区间,然后统计每个子区间上的特征元素值个数,得到一个区间分为53=125份的简化点特征直方图。
更进一步地,步骤S5中利用修剪算法剔除错误点对包括:
判断每个对应点对是否同时满足如下三个条件:
①该点对内的两个点之间的间距小于预设阈值;
②该点对内的两个点的法向量点积小于预设弧度值;
③lsource<0.85*ltarget或ltarget<0.85*lsource;其中,lsource为所述四个特征点中任意两个特征点PA、PB之间连线的长度;ltarget为PA、PB在目标点云中的两个对应点QA、QB之间连线的长度;若所述三个条件均满足,则不进行剔除;若不满足所述三个条件的其中任一条件,则判断为错误点对予以剔除。从而达到快速剔除错误点对的目的,提高迭代算法的效率。
更进一步地,步骤S6中所述验证包括:利用当前最新的基本矩阵将整个源点云进行旋转平移,判断旋转平移后的源点云中的各个点距离目标点云中最近的点的距离是否小于阈值,若小于所述阈值则判断为正确匹配点对,反之则为误匹配点对。
本发明另还提出了一种CAD模型与三角网格全自动配准装置,包括:
源点云生成程序,用于读取由三维扫描系统扫描得到的初始扫描三角网格模型,并提取该初始扫描三角网格模型的顶点作为待配准的源点云;
目标点云生成程序,用于读取标称CAD模型,并利用CAD三角剖分算法对所述标称CAD模型进行三角剖分,得到CAD三角网格,再对该CAD三角网格进行细分以提高点云均匀度和稠密度,并提取细分后的CAD三角网格的顶点作为目标点云;
采样程序,用于分别对所述源点云和所述目标点云进行采样;
法向量计算程序,用于计算采样后的源点云和目标点云中的每一采样点的法向量;
点快速特征直方图计算程序,用于根据各采样点的法向量分别计算各采样点的点快速特征直方图,并将所述采样点作为特征点,用所述点快速特征直方图描述对应的所述特征点;
对应点对构建程序,用于:对于目标点云中的特征点,在点快速特征直方图特征空间构建kd-tree;并从源点云中的特征点中随机选择四个特征点,根据建立好的kd-tree,在目标点云中查找并记录所述四个特征点中每个特征点的最近邻点,以作为所述四个特征点在目标点云中的对应点,从而得到四个对应点对;
修剪算法程序,用于对所述四个对应点对,利用修剪算法剔除错误点对;
RANSAC迭代程序,用于:利用所述四个对应点对估计基本矩阵作为迭代初始值,重复执行所述对应点对构建程序和所述修剪算法程序进行RANSAC迭代,其中,在后面的重复迭代过程中仅将满足修剪算法的匹配点对用于计算更新基本矩阵,并在整个源点云上进行验证以筛选正确匹配点对;最后选取具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵,并将该数据集作为有效点对集;
奇异值分解算法程序,用于针对所述有效点对集,进行奇异值分解,求解出旋转平移矩阵;
配准程序,用于利用所述旋转平移矩阵对所述待配准的源点云进行旋转平移,完成所述标称CAD模型与所述初始扫描三角网格的全自动配准。
本发明的有益效果在于:通过对由标称CAD模型直接转化的CAD三角网格进行细分,使由网格顶点组成的点云更加均匀,可在一定程度上改善配准的精度;根据平均点距的大小自适应决定采样比例,在精简点云的同时还促使采样后的源点云和目标点云的平均点距相近,不仅可以减少计算量提高该方法的配准速度,而且可以提高配准精度;在RANSAC迭代过程中,增加修剪算法快速剔除错误点对,仅将满足修剪算法的匹配项用于计算转换,并对修剪算法剔除后的点对在整个点云上进行进一步验证,以进一步过滤误匹配点对,在兼顾匹配精度的情况下,显著提高了匹配速度。
附图说明
图1为本发明整体步骤流程示意图;
图2-1和图2-2分别为盖子的标称CAD模型和初始扫描三角网格得到的点云模型;
图3-1和图3-2为采样后的目标点云和源点云;
图4为坐标系的坐标轴定义示意图;
图5为配准后的源点云和目标点云(重叠区域混合越均匀表示配准效果越好)。
具体实施方式
下面结合附图和具体的实施方式对本发明作进一步说明。
本发明的具体实施方式提出一种面向工业检测的CAD模型与三角网格全自动配准方法,参考图1,该配准方法包括如下步骤S1-S8:
S1、分别提取待配准的源点云以及目标点云。具体而言,对于目标物体模型,分别读取标称CAD模型和用三维扫描系统扫描得到初始扫描三角网格模型。其中,提取初始扫描三角网格模型的顶点作为待配准的源点云;另外,利用CAD三角剖分算法对标称CAD模型进行三角剖分,得到CAD三角网格,由于直接得到的CAD三角网格往往比较细长,因此再对该CAD三角网格进行诸如Loop算法的细分操作,以使点云分布更加均匀,点云更加稠密,然后提取细分后的CAD三角网格的顶点作为目标点云。
S2、因源点云和目标点云的平均点距r0差别比较大,因此需要分别对所述源点云和所述目标点云进行采样,以使平均点距相近,同时采样还可避免点云过于密集的问题,采样的方法可使用体素采样,采样比例可根据源点云和目标点云的平均点距r0自适应确定。进一步地,还需对于采样后的源点云和目标点云中的每一采样点,计算各点的法向量。在求取每一采样点的法向量时,均需要搜索被求点的邻域点来拟合平面,并以平面的法向量作为被求点的法向量;其中,搜索邻域点时的邻域半径r1根据所述平均点距r0来设置,例如可设为1.5r0≤r1≤2.5r0,优选为r1=2*r0。应当理解的是,此处邻域半径r1的设置仅是示例性的,本领域技术人员可根据具体需求进行适应性的调整。
S3、将源点云和目标点云中的每一采样点作为特征点,根据各采样点的法向量分别计算各采样点的点快速特征直方图,利用所述点快速特征直方图描述对应的所述特征点。对于某个点而言,其FPFH的计算过程如下,包括S31-S33:
S31、根据平均点距r0确定第二邻域半径r2,例如确定为4r0≤r2≤6r0,优选地可以将第二邻域半径r2设为r2=5*r0,同样这也只是示例,不应构成对本发明的限制。对于采样后的源点云和目标点云中的任意采样点p,都以该采样点p为原点选择第二邻域半径r2内的所有近邻点,并分别计算该采样点p与它的第二邻域半径r2内的每个近邻点之间的三个特征元素值,然后将所有特征元素值统计成采样点p的简化点特征直方图(Simplified PointFeature Histogram,SPFH)。
具体而言,三个特征元素的求解过程包括:
对于两个点ps及pt(s≠t),在其中一个点例如点ps处定义一个如图4所示的固定的坐标系ps-uvw,该坐标系的三坐标轴定义如下:
Figure BDA0002745653920000081
其中点ps为源点云和目标点云中当前正在求解点快速特征直方图的采样点,由于求解时需要查询其近邻点,因此我们也将其称为查询点;点pt表示点ps的第二邻域半径r2内的任意一个近邻点,ns为点ps的法向量,||pt-ps||2为点ps与点pt之间的距离,
Figure BDA0002745653920000082
为点ps到点pt的单位向量。
点ps的表面法线的角度变换可由下式(2)确定,式中α、φ、θ即为采样点ps与近邻点pt之间的三个特征元素:
Figure BDA0002745653920000083
其中,nt为点pt的法向量。
在得到了点ps与它的第二邻域半径r2内各个近邻点之间的三个特征元素值之后,将这些特征元素值合并到直方图中,其中,合并过程是将每个特征元素的取值范围划分为5个子区间,然后统计每个子区间上的特征元素值个数,从而可以得到一个区间分为53=125份的简化点特征直方图,这样就得到了点ps的简化点特征直方图。简化点特征直方图是一种姿态不变的局部特征,在这个简化点特征直方图里面有一个区间的值不为0就代表着这个特征元素有一定的值。
S32、分别对第二邻域半径r2中的每个点再确定邻域,并对第二邻域半径r2中的每个点按照步骤S31的方法形成各自的简化点特征直方图。具体而言,对于点ps的第二邻域半径r2中的任意一个点ps_j,再去确定它邻域,然后利用步骤S31的方法得到点ps_j的简化点特征直方图;
S33、进行到步骤S32之后,相当于每个采样点,不但得到了它的简化点特征直方图,还得到了它的第二邻域半径r2中的每个近邻点的简化点特征直方图。在此基础上,对任意采样点p而言,它的点快速特征直方图可以通过下式(3)进行加权统计求出:
Figure BDA0002745653920000091
其中,FPFH(p)即表示采样点p的点快速特征直方图,SPFH(p)表示采样点p的简化点特征直方图,权重wi表示采样点p与第二邻域半径r2中第i个近邻点pi之间的距离,k表示采样点p的k邻域,即采样点p的邻域r2内有k个邻域点,SPFH(pi)表示所述第i个近邻点pi的简化点特征直方图。
S4、在步骤S3计算得到每个采样点的FPFH特征之后,分别进行步骤S41和S42。S41:对于目标点云中的FPFH特征点,在点快速特征直方图特征空间构建kd-tree;S42:对于源点云中的FPFH特征点,选择随机四个特征点,根据建立好的kd-tree,在目标点云中查找并记录所述四个特征点中每个特征点的最近邻点,以作为所述四个特征点在目标点云中的对应点,从而得到四个对应点对,进行RANSAC迭代。
S5、在进行RANSAC迭代时,可以利用修剪算法快速剔除上述对应点对中的错误点对。具体而言,可以判断每个对应点对是否满足以下三个条件:
①该点对内的两个点之间的间距小于预设阈值;
②该点对内的两个点的法向量点积小于预设弧度值;
③lsource<0.85*ltarget或ltarget<0.85*lsource;其中,lsource为所述四个特征点中任意两个特征点PA、PB之间连线的长度;ltarget为PA、PB在目标点云中的两个对应点QA、QB之间连线的长度;
若某个对应点对同时满足上述三个条件,则不进行剔除;若不满足上述三个条件其中任一条件,则判断为错误点对并剔除。这样可以达到快速剔除错误点对的效果。
S6、在进行RANSAC迭代时,利用上述四个对应点对估计基本矩阵作为迭代初始值,重复步骤S4和步骤S5进行RANSAC迭代。在后面的重复迭代过程中仅将满足修剪算法的匹配点对用于计算更新基本矩阵,并在整个源点云上进行验证以筛选正确匹配点对;最后选取具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵,并将该数据集作为有效点对集。也就是说,初始时,用四个对应点对估计基本矩阵作为迭代初始值,而此后的每一次迭代在重复了步骤S5之后,都是用满足修剪算法的点对来估计基本矩阵,并在每一次迭代时用最新得到的基本矩阵在整个源点云上进行验证以筛选正确匹配点对,比如利用基本矩阵将整个源点云进行旋转平移,判断旋转平移后的源点云中的各个点距离目标点云中最近的点的距离是否小于阈值,若小于阈值则认为源点云中的该点与目标点云中该最近的点为正确匹配点对,反之为误匹配点对。这样一来,每一次迭代,每个基本矩阵下,都能得到对应的正确匹配点对的数量和误匹配点对的数量。当正确匹点对越多、误差(点对之间的距离)越小,表示该基本矩阵越有可能是正确的基本矩阵。在完成若干次迭代之后,选择具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵(即认为是正确的基本矩阵),并将该数据集作为有效点对集。
S7、针对步骤S6得到的所述有效点对集,进行奇异值分解(Singular ValueDecomposition,SVD),求解出旋转平移矩阵。
S8、利用所述旋转平移矩阵对步骤S1中待配准的源点云进行旋转平移,完成标称CAD模型与初始扫描三角网格的全自动配准。
在一种实施例中,如图2-1和图2-2所示分别为一盖子的标称CAD模型和初始扫描三角网格模型得到的点云模型,图3-1和图3-2分别为该盖子模型采样后的目标点云和源点云,利用本发明前述配准方法完成全自动配准之后的配准结果如图5所示,从效果图中可以看出配准后两种颜色的源点云和目标点云的重叠区域混合很均匀,配准效果很好。
在另一种实施例中,提出一种CAD模型与三角网格全自动配准装置,该装置包括源点云生成程序、目标点云生成程序、采样程序、法向量计算程序、点快速特征直方图计算程序、对应点对构建程序、修剪算法程序、RANSAC迭代程序、奇异值分解算法程序以及配准程序。
其中,所述源点云生成程序用于读取由三维扫描系统扫描得到的初始扫描三角网格模型,并提取该初始扫描三角网格模型的顶点作为待配准的源点云。所述目标点云生成程序用于读取标称CAD模型,并利用CAD三角剖分算法对所述标称CAD模型进行三角剖分,得到CAD三角网格,再对该CAD三角网格进行细分以提高点云均匀度和稠密度,并提取细分后的CAD三角网格的顶点作为目标点云。所述目标点云生成程序中还包含Loop细分算法的程序,用于对所述CAD三角网格进行所述细分。
所述采样程序用于分别对所述源点云和所述目标点云进行采样,采样的方式可选择体素采样。所述法向量计算程序用于计算采样后的源点云和目标点云中的每一采样点的法向量。在一种实施例中,所述法向量计算程序在求取每一采样点法向量的过程中,均需要搜索被求点的第一邻域半径r1内的邻域点来拟合平面,并以平面的法向量作为被求点的法向量;其中,所述第一邻域半径r1根据所述平均点距r0来设置。
所述点快速特征直方图计算程序用于将所述采样点作为特征点,根据各采样点的法向量分别计算各采样点的点快速特征直方图。在一种实施例中,所述点快速特征直方图计算程序被处理器执行时可实现前述步骤S31~S33。
所述对应点对构建程序用于:对于目标点云中的特征点,在点快速特征直方图特征空间构建kd-tree;并从源点云中的特征点中随机选择四个特征点,根据建立好的kd-tree,在目标点云中查找并记录所述四个特征点中每个特征点的最近邻点,以作为所述四个特征点在目标点云中的对应点,从而得到四个对应点对。
所述修剪算法程序用于对所述四个对应点对,利用修剪算法快速剔除错误点对。在一种实施例中,所述修剪算法程序被处理器执行时,可实现如下步骤:
判断每个对应点对是否同时满足如下三个条件:
①该点对内的两个点之间的间距小于预设阈值;
②该点对内的两个点的法向量点积小于预设弧度值;
③lsource<0.85*ltarget或ltarget<0.85*lsource;其中,lsource为所述四个特征点中任意两个特征点PA、PB之间连线的长度;ltarget为PA、PB在目标点云中的两个对应点QA、QB之间连线的长度;
若所述三个条件均满足,则不进行剔除;若不满足所述三个条件中的任一条件,则判断为错误点对予以剔除。
所述RANSAC迭代程序用于:利用所述四个对应点对估计基本矩阵作为迭代初始值,重复执行所述对应点对构建程序和所述修剪算法程序进行RANSAC迭代,其中,在后面的重复迭代过程中仅将满足修剪算法的匹配点对用于计算更新基本矩阵,并在整个源点云上进行验证以筛选正确匹配点对;最后选取具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵,并将该数据集作为有效点对集。
所述奇异值分解算法程序,用于针对所述有效点对集,进行奇异值分解,求解出旋转平移矩阵。
所述配准程序,用于利用所述旋转平移矩阵对所述待配准的源点云进行旋转平移,完成所述标称CAD模型与所述初始扫描三角网格的全自动配准。
以上内容是结合具体的优选实施方式对本发明所作的进一步详细说明,不能认定本发明的具体实施只局限于这些说明。对于本发明所属技术领域的技术人员来说,在不脱离本发明构思的前提下,还可以做出若干等同替代或明显变型,而且性能或用途相同,都应当视为属于本发明的保护范围。

Claims (10)

1.一种CAD模型与三角网格全自动配准方法,其特征在于,包括如下步骤:
S1、读取标称CAD模型和用三维扫描系统扫描得到的初始扫描三角网格模型;提取初始扫描三角网格模型的顶点作为待配准的源点云;利用CAD三角剖分算法对所述标称CAD模型进行三角剖分,得到CAD三角网格,再对该CAD三角网格进行细分以提高点云均匀度和稠密度,并提取细分后的CAD三角网格的顶点作为目标点云;
S2、分别对所述源点云和所述目标点云进行采样,采样比例根据所述源点云和所述目标点云的平均点距r0自适应确定;计算采样后的源点云和目标点云中的每一采样点的法向量;
S3、将源点云和目标点云中的每一采样点作为特征点,根据各采样点的法向量分别计算各采样点的点快速特征直方图,利用所述点快速特征直方图描述对应的所述特征点;
S4、对于目标点云中的特征点,在点快速特征直方图特征空间构建kd-tree;从源点云中的特征点中随机选择四个特征点,根据建立好的kd-tree,在目标点云中查找并记录所述四个特征点中每个特征点的最近邻点,以作为所述四个特征点在目标点云中的对应点,从而得到四个对应点对;
S5、对于所述四个对应点对,利用修剪算法剔除错误点对;
S6、利用所述四个对应点对估计基本矩阵作为迭代初始值,重复步骤S4和S5进行RANSAC迭代,在后面的重复迭代过程中仅将满足修剪算法的匹配点对用于计算更新基本矩阵,并在整个源点云上进行验证以筛选正确匹配点对;最后选取具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵,并将该数据集作为有效点对集;
S7、针对步骤S6得到的有效点对集,进行奇异值分解,求解出旋转平移矩阵;
S8、利用所述旋转平移矩阵对步骤S1中待配准的源点云进行旋转平移,完成所述标称CAD模型与所述初始扫描三角网格的全自动配准。
2.如权利要求1所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S1中对该CAD三角网格进行细分时采用Loop细分算法;步骤S2中对所述源点云和所述目标点云进行采样的方法是体素采样。
3.如权利要求1所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S2在求取每一采样点法向量的过程中,均需要搜索被求点的第一邻域半径r1内的邻域点来拟合平面,并以平面的法向量作为被求点的法向量;其中,所述第一邻域半径r1根据所述平均点距r0来设置。
4.如权利要求3所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S3中点快速特征直方图的计算过程包括:
S31、根据平均点距r0确定第二邻域半径r2,对于采样后的源点云和目标点云中的任意采样点p:都以该采样点p为原点选择所述第二邻域半径r2内的所有近邻点,并分别计算该采样点p与采样点p的每个近邻点之间的三个特征元素值,然后将所有特征元素值统计成采样点p的简化点特征直方图;
S32、分别对所述第二邻域半径r2中的每个所述近邻点再确定邻域,并对所述第二邻域半径r2中的每个所述近邻点按照步骤S31形成各自的简化点特征直方图;
S33、对采样点p的所述第二邻域半径r2中每个所述近邻点的简化点特征直方图进行加权统计:
Figure FDA0002745653910000021
其中,FPFH(p)表示采样点p的点快速特征直方图,SPFH(p)表示采样点p的简化点特征直方图,权重wi表示采样点p与所述第二邻域半径r2中第i个近邻点pi之间的距离,k表示采样点p的k邻域,SPFH(pi)表示所述第i个近邻点pi的简化点特征直方图。
5.如权利要求4所述的CAD模型与三角网格全自动配准方法,其特征在于,所述第一邻域半径r1为1.5r0≤r1≤2.5r0,所述第二邻域半径r2为4r0≤r2≤6r0
6.如权利要求4所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S31中所述三个特征元素值的计算过程包括:
对于两个点ps及pt(s≠t),在其中一个点处定义一个固定的坐标系ps-uvw,该坐标系的三坐标轴定义如下:
Figure FDA0002745653910000031
其中点ps为源点云和目标点云中当前正在求解点快速特征直方图的采样点,称为查询点;点pt表示点ps的第二邻域半径r2内的任意一个近邻点,ns为点ps的法向量,||pt-ps||2为点ps与点pt之间的距离,
Figure FDA0002745653910000032
为点ps到点pt的单位向量;
点ps的表面法线的角度变换由下式确定,式中α、φ、θ为采样点ps与近邻点pt之间的三个特征元素:
Figure FDA0002745653910000033
其中,nt为点pt的法向量。
7.如权利要求6所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S31中采样点ps的简化点特征直方图的建立包括:将采样点ps及第二邻域半径r2内各个近邻点之间的三个特征元素值合并到直方图中,其中,合并过程是将每个特征元素的取值范围划分为5个子区间,然后统计每个子区间上的特征元素值个数,得到一个区间分为53=125份的简化点特征直方图。
8.如权利要求1所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S5中利用修剪算法剔除错误点对包括:
判断每个对应点对是否同时满足如下三个条件:
①该点对内的两个点之间的间距小于预设阈值;
②该点对内的两个点的法向量点积小于预设弧度值;
③lsource<0.85*ltarget或ltarget<0.85*lsource;其中,lsource为所述四个特征点中任意两个特征点PA、PB之间连线的长度;ltarget为PA、PB在目标点云中的两个对应点QA、QB之间连线的长度;
若所述三个条件均满足,则不进行剔除;若不满足所述三个条件中的任一条件,则判断为错误点对予以剔除。
9.如权利要求1所述的CAD模型与三角网格全自动配准方法,其特征在于,步骤S6中所述验证包括:
利用当前最新的基本矩阵将整个源点云进行旋转平移,判断旋转平移后的源点云中的各个点距离目标点云中最近的点的距离是否小于阈值,若小于所述阈值为正确匹配点对,反之为误匹配点对。
10.一种CAD模型与三角网格全自动配准装置,其特征在于,包括:
源点云生成程序,用于读取由三维扫描系统扫描得到的初始扫描三角网格模型,并提取该初始扫描三角网格模型的顶点作为待配准的源点云;
目标点云生成程序,用于读取标称CAD模型,并利用CAD三角剖分算法对所述标称CAD模型进行三角剖分,得到CAD三角网格,再对该CAD三角网格进行细分以提高点云均匀度和稠密度,并提取细分后的CAD三角网格的顶点作为目标点云;
采样程序,用于分别对所述源点云和所述目标点云进行采样;
法向量计算程序,用于计算采样后的源点云和目标点云中的每一采样点的法向量;
点快速特征直方图计算程序,用于根据各采样点的法向量分别计算各采样点的点快速特征直方图,并将所述采样点作为特征点,用所述点快速特征直方图描述对应的所述特征点;
对应点对构建程序,用于:对于目标点云中的特征点,在点快速特征直方图特征空间构建kd-tree;并从源点云中的特征点中随机选择四个特征点,根据建立好的kd-tree,在目标点云中查找并记录所述四个特征点中每个特征点的最近邻点,以作为所述四个特征点在目标点云中的对应点,从而得到四个对应点对;
修剪算法程序,用于对所述四个对应点对,利用修剪算法剔除错误点对;
RANSAC迭代程序,用于:利用所述四个对应点对估计基本矩阵作为迭代初始值,重复执行所述对应点对构建程序和所述修剪算法程序进行RANSAC迭代,其中,在后面的重复迭代过程中仅将满足修剪算法的匹配点对用于计算更新基本矩阵,并在整个源点云上进行验证以筛选正确匹配点对;最后选取具有最多正确匹配点对的数据集的基本矩阵作为最终基本矩阵,并将该数据集作为有效点对集;
奇异值分解算法程序,用于针对所述有效点对集,进行奇异值分解,求解出旋转平移矩阵;
配准程序,用于利用所述旋转平移矩阵对所述待配准的源点云进行旋转平移,完成所述标称CAD模型与所述初始扫描三角网格的全自动配准。
CN202011165530.3A 2020-10-27 2020-10-27 一种cad模型与三角网格全自动配准方法和装置 Active CN112381862B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011165530.3A CN112381862B (zh) 2020-10-27 2020-10-27 一种cad模型与三角网格全自动配准方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011165530.3A CN112381862B (zh) 2020-10-27 2020-10-27 一种cad模型与三角网格全自动配准方法和装置

Publications (2)

Publication Number Publication Date
CN112381862A true CN112381862A (zh) 2021-02-19
CN112381862B CN112381862B (zh) 2022-10-14

Family

ID=74577232

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011165530.3A Active CN112381862B (zh) 2020-10-27 2020-10-27 一种cad模型与三角网格全自动配准方法和装置

Country Status (1)

Country Link
CN (1) CN112381862B (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113658166A (zh) * 2021-08-24 2021-11-16 凌云光技术股份有限公司 一种基于网格模型的点云缺陷检测方法和装置
CN113902782A (zh) * 2021-10-21 2022-01-07 济南大学 一种挖掘机周边障碍物三维点云的快速配准方法及系统
CN113962932A (zh) * 2021-09-10 2022-01-21 上海大学 一种基于三维立体建模的螺纹检测方法
CN116309759A (zh) * 2023-05-25 2023-06-23 南京信息工程大学 一种基于快速三角特征直方图的点云粗配准方法
CN118171547A (zh) * 2024-05-16 2024-06-11 深圳十沣科技有限公司 自动化网格生成方法、装置、设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110235898A1 (en) * 2010-03-24 2011-09-29 National Institute Of Advanced Industrial Science And Technology Matching process in three-dimensional registration and computer-readable storage medium storing a program thereof
CN108665491A (zh) * 2018-03-22 2018-10-16 西安电子科技大学 一种基于局部参考点的快速点云配准方法
CN109559340A (zh) * 2018-11-29 2019-04-02 东北大学 一种并行的三维点云数据自动化配准方法
US20190295266A1 (en) * 2016-05-20 2019-09-26 Nokia Technologies Oy Point cloud matching method

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110235898A1 (en) * 2010-03-24 2011-09-29 National Institute Of Advanced Industrial Science And Technology Matching process in three-dimensional registration and computer-readable storage medium storing a program thereof
US20190295266A1 (en) * 2016-05-20 2019-09-26 Nokia Technologies Oy Point cloud matching method
CN108665491A (zh) * 2018-03-22 2018-10-16 西安电子科技大学 一种基于局部参考点的快速点云配准方法
CN109559340A (zh) * 2018-11-29 2019-04-02 东北大学 一种并行的三维点云数据自动化配准方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
宋鹏飞: "三维测量点云与CAD模型配准算法研究", 《中国优秀硕士学位论文全文数据库 信息科技辑》 *

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113658166A (zh) * 2021-08-24 2021-11-16 凌云光技术股份有限公司 一种基于网格模型的点云缺陷检测方法和装置
CN113658166B (zh) * 2021-08-24 2024-04-12 凌云光技术股份有限公司 一种基于网格模型的点云缺陷检测方法和装置
CN113962932A (zh) * 2021-09-10 2022-01-21 上海大学 一种基于三维立体建模的螺纹检测方法
CN113902782A (zh) * 2021-10-21 2022-01-07 济南大学 一种挖掘机周边障碍物三维点云的快速配准方法及系统
CN116309759A (zh) * 2023-05-25 2023-06-23 南京信息工程大学 一种基于快速三角特征直方图的点云粗配准方法
CN116309759B (zh) * 2023-05-25 2023-08-15 南京信息工程大学 一种基于快速三角特征直方图的点云粗配准方法
CN118171547A (zh) * 2024-05-16 2024-06-11 深圳十沣科技有限公司 自动化网格生成方法、装置、设备及存储介质

Also Published As

Publication number Publication date
CN112381862B (zh) 2022-10-14

Similar Documents

Publication Publication Date Title
CN112381862B (zh) 一种cad模型与三角网格全自动配准方法和装置
CN109887015B (zh) 一种基于局部曲面特征直方图的点云自动配准方法
CN106023298B (zh) 基于局部泊松曲面重建的点云刚性配准方法
CN105654483B (zh) 三维点云全自动配准方法
CN111986115A (zh) 激光点云噪声和冗余数据的精准剔除方法
CN104778688A (zh) 点云数据的配准方法及装置
CN104463894A (zh) 一种多视角三维激光点云全局优化整体配准方法
CN112257722B (zh) 基于抗差非线性高斯-赫尔默特模型的点云拟合方法
CN108665491A (zh) 一种基于局部参考点的快速点云配准方法
CN113168729B (zh) 一种基于局部参考坐标系的3d形状匹配方法及装置
CN116402866A (zh) 基于点云的零件数字孪生几何建模与误差评定方法及系统
CN110047133A (zh) 一种面向点云数据的列车边界提取方法
CN112329726B (zh) 人脸识别方法及装置
CN111400830A (zh) 一种三维毛坯工件的加工校准方法及装置
CN116309026A (zh) 一种基于统计局部特征描述与匹配的点云配准方法及系统
CN113450269A (zh) 一种基于3d视觉的点云关键点提取方法
CN117132630A (zh) 一种基于二阶空间兼容性度量的点云配准方法
CN113658194B (zh) 一种基于参照物的点云拼接方法、装置及存储介质
CN115953604B (zh) 一种不动产地理信息测绘数据采集方法
CN115147433A (zh) 点云配准方法
Shmukler et al. Verification of 3D freeform parts by registration of multiscale shape descriptors
CN110554405B (zh) 一种基于组合聚类的正态扫描配准方法和系统
CN115147471A (zh) 一种基于曲率密度特征的激光点云自动配准方法
CN113963114A (zh) 一种基于多边形生长的离散边界点追踪方法
CN115100277A (zh) 复杂曲面结构零件位姿确定方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant