用于三维扫描的旋转平台位置参数计算方法及系统与流程

文档序号:29722337发布日期:2022-04-16 19:40阅读:119来源:国知局
用于三维扫描的旋转平台位置参数计算方法及系统与流程

1.本发明涉及三维扫描领域,尤其是涉及一种用于三维扫描的旋转平台位置参数计算方法及系统。


背景技术:

2.目前,三维扫描领域在计算扫描仪的旋转平台的位置参数时,通常将标准球或者平面标定板放置于旋转平台上,利用结构光系统扫描该标准球或者平面标定板,并依据扫描结果进行计算旋转平台相对于结构光系统的位置参数。然而,这种方式在计算的过程中需要通过特定的标定物对旋转平台与结构光系统的相对位置关系进行标定,一旦旋转平台与结构光系统的相对位置关系发生变化,必须重新利用标定物对该位置关系进行标定,即重新利用标定物计算旋转平台的位置参数,由此会导致操作过程较为繁琐,不便于对旋转平台与结构光系统的相对位置关系进行标定,从而影响旋转平台位置参数的计算效率。


技术实现要素:

3.本发明提供了一种用于三维扫描的旋转平台位置参数计算方法及系统,主要在于能够提高旋转平台位置参数的计算效率,同时能够便于对旋转平台与结构光系统的相关位置关系进行标定。
4.根据本发明的第一个方面,提供一种用于三维扫描的旋转平台位置参数计算方法,包括:获取扫描到的旋转平台上的待扫描物体的多幅三维点云;从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
5.根据本发明的第二个方面,提供一种用于三维扫描的旋转平台位置参数计算装置,包括:获取单元,用于获取扫描到的旋转平台上的待扫描物体的多幅三维点云;变换单元,用于从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;筛选单元,用于根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;计算单元,用于基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
6.根据本发明的第三个方面,提供一种用于三维扫描仪的旋转平台配准系统,包括三维扫描仪,所述三维扫描仪用于扫描旋转平台上的待扫描物体,并获取多幅三维点云;所述配准系统用于执行上述用于三维扫描的旋转平台位置参数计算方法,从而实现三维扫描
仪的旋转平台配准。
7.根据本发明的第四个方面,提供一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现以下步骤:获取扫描到的旋转平台上的待扫描物体的多幅三维点云;从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
8.根据本发明的第五个方面,提供一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现以下步骤:获取扫描到的旋转平台上的待扫描物体的多幅三维点云;从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
9.本发明提供的一种用于三维扫描的旋转平台位置参数计算方法及系统,与目前通过对标准球或者标定板进行扫描,计算旋转平台位置参数的方式相比,本发明能够获取扫描到的旋转平台上的待扫描物体的多幅三维点云;并从获取的所述多幅三维点云中确定初始源点云和目标点云,以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;与此同时,根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;最终基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。由此通过直接对待扫描物体进行扫描,获取待扫描物体对应的初始源点云和目标点云,并从待扫描物体对应的目标点云中筛选出目标特征点,能够基于目标特征点在目标点云和不同初始源点云中的坐标点,计算出旋转平台的轴线向量和轴心坐标,并将其确定为所述旋转平台相对于扫描系统的位置参数,从而更方便和更高效的实现三维扫描仪的旋转平台配准。此外,在对旋转平台与扫描系统的相对于位置关系进行标定的过程中,能够避免使用标定物,尤其当旋转平台与扫描系统的相对位置关系发生变化时,能够避免再次使用标定物重新对该相对位置关系进行标定,从而能够简化操作过程,提高旋转平台位置参数的计算效率。
附图说明
10.此处所说明的附图用来提供对本发明的进一步理解,构成本技术的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:图1示出了本发明实施例提供的一种用于三维扫描的旋转平台位置参数计算方法流程图;图2示出了本发明实施例提供的另一种用于三维扫描的旋转平台位置参数计算方法流程图;
图3示出了本发明实施例提供的查找树示意图;图4示出了本发明实施例提供的一种用于三维扫描的旋转平台位置参数计算装置的结构示意图;图5示出了本发明实施例提供的另一种用于三维扫描的旋转平台位置参数计算装置的结构示意图;图6示出了本发明实施例提供的一种计算机设备的实体结构示意图。
具体实施方式
11.下文中将参考附图并结合实施例来详细说明本发明。需要说明的是,在不冲突的情况下,本技术中的实施例及实施例中的特征可以相互组合。
12.目前,一旦旋转平台与结构光系统的相对位置关系发生变化,必须重新利用标定物对该位置关系进行标定,即重新利用标定物计算旋转平台的位置参数,由此会导致操作过程较为繁琐,不便于对旋转平台与结构光系统的相对位置关系进行标定,从而影响旋转平台位置参数的计算效率。
13.为了解决上述问题,本发明实施例提供了一种用于三维扫描的旋转平台位置参数计算方法,如图1所示,所述方法包括:101、获取扫描到的旋转平台上的待扫描物体的多幅三维点云。
14.其中,待扫描物体为放置于旋转平台上待进行三维扫描的物体,本发明实施例中需要获取的待扫描物体的三维点云数量至少为三幅,为了避免浪费资源,节约存储空间,通常可以获取待扫描物体的三幅三维点云。
15.本发明实施例主要应用于计算旋转平台相对于扫描系统的位置参数的场景。本发明实施例的执行主体为能够计算旋转平台相对于扫描系统的位置参数的装置或者设备,具体可以设置在服务器一侧,也可以为本地计算机、扫描仪、旋转盘控制器等。
16.对于本发明实施例,在对旋转平台与扫描系统(结构光系统)的相对位置关系进行标定的过程中,无需要使用标准球、平面标定板等特定标定物,直接将待扫描物体放置于旋转平台上,通过获取待扫描物体的多幅三维点云,并筛选出目标点云中的目标特征点,能够基于该目标特征点对旋转平台与结构光系统的相对位置关系进行标定,即可以直接基于该目标特征点,计算旋转平台对应的位置参数。
17.具体地,在获取待扫描物体的多幅三维点云时,可以先将待扫描物体放置于旋转平台上,利用扫描系统对待扫描物体进行扫描,得到待扫描物体在0旋转角度下的三维点云,之后控制旋转平台每次沿逆时针或者顺时针方向旋转相同角度,如20度,每次旋转停止后对待扫描物体进行扫描,获取待扫描物体分别在20度和40度时的三维点云。除此之外,还可以先不对待扫描物体进行扫描,控制旋转平台沿逆时针或者顺时针方向以相同角度连续旋转3次,如20度,每次旋转停止后对待扫描物体进行扫描,获取待扫描物体分别在20度、40度和60度时的三维点云。由此按照上述两种方式能够获取待扫描物体在不同旋转角度下的三维点云。
18.需要说明是,本发明实施例中的扫描系统具体可以为结构光系统,也可以为其他扫描系统,本发明实施例不进行具体限定。本发明实施例中的旋转次数不能少于两次,通常设定为两次,通过控制旋转平台每次旋转相同角度可以获取待扫描物体的三幅三维点云。
19.102、从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云。
20.对于本发明实施例,在获取多幅三维点云之后,随机选取一幅三维点云作为目标点云,并将剩余的三维点云作为初始源点云,例如,通过控制旋转平台沿同一方向每次旋转20度,获取待扫描物体在0度、20度和40度下的三维点云p1、p2和p3,选取p1作为目标点云,并将p2和p3作为初始源点云。进一步地,分别确定所述目标点云与不同初始源点云之间的变换矩阵,并基于该变换矩阵,对所述不同初始源点云进行变换处理,得到不同变换后的源点云。其中,变换矩阵包括旋转矩阵和平移矩阵。
21.在确定旋转矩阵和平移矩阵的过程中,可以采用icp算法确定不同初始源点云与目标点云之间的旋转矩阵和平移矩阵。具体地,可以在目标点云中选取点集p,同时针对点集p中的任意一点pi,根据预设的约束条件确定pi在初始源点云中对应的qi,由此可以在初始源点云中确定点集p对应的点集q。进一步地,构建误差函数,通过该误差函数求解旋转矩阵和平移矩阵,该误差函数的具体公式如下:其中,e(r,t)为经过变换后的点集q与点集p之间的距离误差,n为点集p和点集q对应的数量,pi为点集p中的任意一点,qi为点集q中与pi相对应的点,r为旋转矩阵,t为平移矩阵。由此通过上述误差函数不断对参数r和t进行迭代,能够得到目标点云与不同初始源点云之间的旋转矩阵和平移矩阵。
22.需要说明的是,根据预设的约束条件确定点集p中的任意一点pi在初始源点云中对应的qi时,该预设条件具体可以为,即pi与qi之间的距离小于预设距离d
min
,该d
min
可以根据实际需求进行设定。
23.进一步地,在确定目标点云与不同初始源点云之间的旋转矩阵和平移矩阵之后,基于该旋转矩阵和平移矩阵对不同初始源点云进行旋转处理和平移处理,得到不同变换后的源点云。
24.103、根据所述变换后的源点云,从所述目标点云中筛选出目标特征点。
25.其中,目标特征点为用于对旋转平台与扫描系统的相对位置关系进行标定的特征点,目标特征点的数量具体可以为一个、两个或者多个,为了保证旋转平台位置参数的计算精度,筛选出的目标特征点的数量不宜过少。对于本发明实施例,为了直接从待扫描物体对应的目标点云中筛选出目标特征点,需要先从目标点云随机抽取多个特征点,之后确定每个特征点在不同变换后的源点云中对应的最邻近特征点,接着计算每个特征点与不同变换后的源点云中最邻近特征点之间的距离值,基于该距离值从多个特征点中筛选出目标特征点。
26.例如,从目标点云p1中随机抽取多个特征点,之后确定每个特征点分别在变换后的源点云p2和p3中的最邻近特征点,接着计算每个特征点与变换后的源点云p2中的最邻近特征点之间的距离d2,以及每个特征点与变换后的源点云p3中的最邻近特征点之间的距离d3,针对某个特征点,如果d2和d3均小于预设距离值,则确定该特征点为目标特征点。由此按
照上述方式能够从随机抽取的多个特征点中筛选出目标特征点,以便基于该目标特征点,计算旋转平台相对于扫描系统的位置参数。
27.104、基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
28.其中,旋转平台的位置参数包括旋转平台对应的轴线向量和轴心坐标。对于本发明实施例,在确定目标点云中的目标特征点之后,基于该目标特征点分别在目标点云和不同初始源点云中的坐标,计算旋转平台对应的轴线向量和轴心坐标。在计算旋转平台对应的轴线向量时,根据目标特征点分别在目标点云中的坐标和在不同初始源点源中的坐标,进行平面拟合,并计算该平面的法向量,基于该平面的法向量,确定旋转平台对应的轴线向量。进一步地,在确定平面的法向量之后,基于该法向量,以及目标特征点分别在目标点云和不同初始源点云中的坐标,计算平面对应的中心点坐标,并根据该平面对应的中心点坐标,确定旋转平台对应的轴心坐标。由此按照上述方式能够直接基于待扫描物体在目标点云中的目标特征点,实现旋转平台与扫描系统的相关位置关系的标定。针对旋转平台的轴线向量和轴心坐标的具体计算过程,详见步骤205。
29.本发明实施例提供的一种用于三维扫描的旋转平台位置参数计算方法,与目前通过对标准球或者标定板进行扫描,计算旋转平台位置参数的方式相比,本发明能够获取扫描到的旋转平台上的待扫描物体的多幅三维点云;并从获取的所述多幅三维点云中确定初始源点云和目标点云,以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;与此同时,根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;最终基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。由此通过直接对待扫描物体进行扫描,获取待扫描物体对应的初始源点云和目标点云,并从待扫描物体对应的目标点云中筛选出目标特征点,能够基于目标特征点在目标点云和不同初始源点云中的坐标点,计算出旋转平台的轴线向量和轴心坐标,并将其确定为所述旋转平台相对于扫描系统的位置参数,从而更方便和更高效的实现三维扫描仪的旋转平台配准。此外,在对旋转平台与扫描系统的相对于位置关系进行标定的过程中,能够避免使用标定物,尤其当旋转平台与扫描系统的相对位置关系发生变化时,能够避免再次使用标定物重新对该相对位置关系进行标定,从而能够简化操作过程,提高旋转平台位置参数的计算效率。
30.进一步的,为了更好的说明上述计算旋转平台相对于扫描系统的位置参数的过程,作为对上述实施例的细化和扩展,本发明实施例提供了另一种用于三维扫描的旋转平台位置参数计算方法,如图2所示,所述方法包括:201、获取扫描到的旋转平台上的待扫描物体的多幅三维点云。
31.对于本发明实施例,为了获取待扫描物体的多幅三维点云,步骤201具体包括:获取所述待扫描物体在所述旋转平台旋转前被扫描到的第一点云,以及在所述旋转平台旋转后被扫描到的第二点云和第三点云。例如,先将待扫描物体放置于旋转平台上,利用扫描系统对待扫描物体进行扫描,得到待扫描物体在0旋转角度下的第一点云,之后控制旋转平台旋转朝同一方向连续旋转两次,每次旋转20度,且每次旋转停止后对待扫描物体进行扫描,获取待扫描物体在20度时的第二点云和在40度时的第三点云。
32.除此之外,步骤201具体还包括:获取所述待扫描物体在所述旋转平台旋转后被扫
描到的第一点云、第二点云和第三点云。例如,将待扫描物体放置于旋转平台上后,控制旋转平台朝同一方向连续旋转三次,每次旋转20度,且每次旋转停止后对待扫描物体进行扫描,分别获取待扫描物体在20度、40度和60度时的第一点云、第二点云和第三点云。
33.需要说明的是,旋转平台在进行旋转时每次以同一角度进行旋转,具体可以控制旋转平台沿顺时针或者逆时针方向每次旋转20度,由于将旋转角度设置过大,不易于实现旋转平台的配准,而将该旋转角度设置过小,会导致轴线向量和轴心坐标的计算精度较低,因此将旋转平台每次旋转的角度设定为20度,能够保证轴线向量和轴心坐标的计算精度,便于实现旋转平台的配准。
34.202、从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云。
35.对于本发明实施例,确定目标点云和初始源点云的过程,以及对初始源点云进行变换处理的过程与步骤102相同,在此不再赘述。
36.203、从所述目标点云中随机抽取预设数量的特征点,并确定所述特征点分别在不同变换后的源点云中的最邻近特征点,以及所述特征点与所述不同变换后的源点云中最邻近特征点之间的距离值。
37.其中,预设数量可以根据实际操作需要进行设定,如随机从目标点云中抽取100个特征点。对于本发明实施例,为了提高最近邻特征点的查找效率,可以利用kd-tree算法快速确定每个特征点在不同变换后的源点云中的最邻近特征点,针对利用kd-tree算法确定最邻近特征点的具体过程,作为一种可选实施例,该方法包括:获取所述不同变换后的源点云对应的查找树;从所述查找树的根节点开始,依据所述每个特征点与所述查找树的各分支节点的比较结果不断向下查找,直至到达叶子节点;将所述叶子节点上保存的特征点确定为待查找特征点;计算所述每个特征点与所述待查找特征点之间的最小距离,以及所述每个特征点与所述根节点下未被查找过的分支节点之间的分支距离;若所述分支距离小于所述最小距离,则进入所述分支节点中进行查找,并基于查找结果,对所述待查找特征点进行更新,得到更新后的待查找特征点;将所述更新后的待查找特征点确定为所述最邻近特征点。
38.图3为变换后的源点云对应的查找树,以特征点(2.1,3.1,2.0)为例详细说明查找最邻近特征点的过程,首先从根节点(7,2,2)开始,根节点需要比较的维度特征是x轴方向上的特征,根节点x轴方向上的特征为7,特征点(2.1,3.1,2.0)x轴方向上的特征为2.1,由于2.1小于根节点x轴方向上的特征7,因此进入到查找树的左侧分支节点(5,4,2),左侧分支节点(5,4,2)需要比较的维度是y轴方向上的特征,左侧分支节点y轴方向上的特征为4,特征点(2.1,3.1,2.0)y轴方向上的特征为3.1,由于3.1小于左侧分支节点y轴方向上的特征,因此最终到达左侧的叶子节点,左侧叶子节点上存储的特征点为(2,3,3),将其暂时作为待查找特征点,并计算特征点(2.1,3.1,2.0)与当前的待查找特征点(2,3,3)之间的最小距离,通过计算最小距离为1.1414。进一步地,为了查找其他分支中是否还存在距离特征点更近的点,回溯到分支节点(5,4,2),计算特征点(2.1,3.1,2.0)与分支节点(5,4,2)之间的分支距离,由于该分支距离显然大于最小距离1.1414,因此不必进入分支节点(5,4,2)的右侧分支进行查找。进一步地,回溯到根节点(7,2,2),计算特征点(2.1,3.1,2.0)与根节点(7,2,2)之间的分支距离,由于两者之间的分支距离显然大于最小距离1.1414,因此不必进
入根节点的右侧分支进行查找,最终确定(2,3,3)为特征点(2.1,3.1,2.0)在变换后的源点云中的最邻近特征点。
39.进一步地,图3中变换后的源点云对应的查找树可以根据变换后的源点云中的特征点进行构建。例如,变换后的源点云中的特征点依次为(7,2,2)、(5,4,2)、(9,6,2)、(2,3,3)、(4,7,3)、(8,1,3),分别确定上述特征点在x轴、y轴和z轴方向上的方差,得知x轴方向上的方差最大,因此将x轴方向上的值2,5,9,4,8,7进行排序,排序选出中间值7,该中间值对应的特征点为(7,2,2),因此选择(7,2,2)作为根节点,同时将x轴方向上的特征确定为需要进行比较的特征,通过该中间值7能够划分成左侧分支和右侧分支,如图3所示,如果特征点在x轴方向上的特征小于7,则被划分到左侧分支,该左侧分支包含三个节点(5,4,2)、(2,3,3)和(4,7,3);相反如果大于7,则被划分到右侧分支,该右侧分支包含两个节点(9,6,2)和(8,1,3),继续重复上述过程,直至划分到叶子节点。
40.在按照上述方法确定每个特征点在不同变换后的源点云中的最邻近特征点的同时,还需要确定最邻近特征点在相应变换后的源点云中的索引值。进一步地,计算每个特征点与不同最邻近特征之后的距离值。例如,计算目标点云p1中的每个特征点与变换后的源点云p2中的最邻近特征点之间的距离d2,以及每个特征点与变换后的源点云p3中的最邻近特征点之间的距离d3。
41.204、基于所述距离值,从所述预设数量的特征点中筛选出目标特征点。
42.对于本发明实施例,为了确定目标特征点,步骤204具体包括:预设一个距离阈值;比较所述距离值与所述距离阈值;确定所述距离值小于所述距离阈值的特征点为目标特征点。其中,所述距离阈值可以根据实际需要进行设置。
43.紧接上面的例子,如设定距离阈值为0.005mm,针对某个特征点,如果d2和d3均小于0.005mm,则确定该特征点为目标特征点;如果d2或者d3大于或者等于0.005mm,则说明该特征点不是要找的目标特征点,将该特征点剔除。
44.205、基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
45.对于本发明实施例,在计算旋转平台相对于扫描系统的位置参数之前,需要先确定目标特征点在不同初始源点云中的坐标,针对该过程,作为一种可选实施方式,所述方法包括:确定所述目标特征点在所述不同变换后的源点云中的最邻近特征点对应的索引值;基于所述索引值,获取所述目标特征点在所述不同初始源点云中的坐标。具体地,首先根据每个特征点在不同变换后的源点云中的最邻近特征点的索引值,确定目标特征点在不同变换后的源点云中的最邻近特征点的索引值,由于该最邻近特征点很可能与目标特征点是同一点,因此可以根据不同变换后的源点云中的最邻近特征点的索引值,获取目标特征点在不同初始源点云中的坐标。
46.进一步地,为了计算旋转平台相对于扫描系统的位置参数,即轴线向量和轴心坐标,步骤205具体包括:基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,确定拟合平面对应的法向量;根据所述法向量,以及所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述拟合平面对应的中心点坐标;若存在多个所述目标特征点,计算多个所述目标特征点分别对应的法向量的均值,得到所述旋转平台对应的轴线向量,并计算多个所述目标特征点分别对应的中心点坐标的均值,得到所述旋转平台
对应的轴心坐标;将所述轴线向量和所述轴心坐标,确定为所述旋转平台相对于扫描系统的位置参数。
47.在具体应用场景中,当获取的待扫描物体的三幅三维点云分别为第一点云、第二点云和第三点云时,可以将目标点云设定为第一点云,将不同初始源点云设定为第二点云和第三点云,针对拟合平面法向量的具体确定过程,作为一种可选实施方式,该方法包括:获取第一公式;根据所述第一公式,计算所述拟合平面对应的法向量;其中,所述第一公式为:,其中,(x1,y1,z1)为所述目标特征点在所述第一点云中的坐标,(x2,y2,z2)和(x3,y3,z3)为所述目标特征点分别在第二点云和第三点云中的坐标,(a,b,c)为所述拟合平面对应的法向量。由于三个点(x1,y1,z1)、(x2,y2,z2)和(x3,y3,z3)可以确定一个平面,该平面上的任意一点与平面的法向量相乘等于1,因此通过上述公式可以解出平面的法向量。
48.进一步地,针对拟合平面中心点坐标的具体确定过程,作为一种可选实施方式,该方法包括:获取第二公式;根据所述第二公式,计算所述拟合平面对应的中心点坐标;其中,所述第二公式为:,其中,(x1,y1,z1)为所述目标特征点在所述第一点云中的坐标,(x2,y2,z2)和(x3,y3,z3)为所述目标特征点分别在所述第二点云和所述第三点云中的坐标,(a,b,c)为所述拟合平面对应的法向量,(x,y,z)为所述拟合平面对应的中心点坐标。
49.具体地,由于拟合平面的中心点坐标(x,y,z)与(x1,y1,z1)之间的距离等于中心点坐标(x,y,z)与(x2,y2,z2)之间的距离,且中心点坐标(x,y,z)与(x1,y1,z1)之间的距离等于中心点坐标(x,y,z)与(x3,y3,z3)之间的距离,除此之外,由于中心点坐(x,y,z)标在拟合平面上,中心点坐标(x,y,z)与拟合平面对应的法向量相乘得1。因此可以列出如下三个公式:通过对上述三个公式进行简化,可以得到第二公式,进而利用该第二公式可以解出拟合平面对应的中心点坐标(x,y,z)。
50.在确定每个目标特征点的拟合平面对应的法向量和中心点坐标之后,计算所有目标特征点对应的法向量的均值,得到旋转平台对应的轴线向量,同时计算所有目标特征点对应的中心点坐标的均值,得到旋转平台对应的轴心坐标。由此按照上述计算公式能够得到旋转平台对应的位置参数。
51.本发明实施例提供的另一种用于三维扫描的旋转平台位置参数计算方法,与目前
通过对标准球或者标定板进行扫描,计算旋转平台位置参数的方式相比,本发明能够获取扫描到的旋转平台上的待扫描物体的多幅三维点云;并从获取的所述多幅三维点云中确定初始源点云和目标点云,以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;与此同时,根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;最终基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。由此通过直接对待扫描物体进行扫描,获取待扫描物体对应的初始源点云和目标点云,并从待扫描物体对应的目标点云中筛选出目标特征点,能够基于目标特征点在目标点云和不同初始源点云中的坐标点,计算出旋转平台的轴线向量和轴心坐标,并将其确定为所述旋转平台相对于扫描系统的位置参数,从而更方便和更高效的实现三维扫描仪的旋转平台配准。此外,在对旋转平台与扫描系统的相对于位置关系进行标定的过程中,能够避免使用标定物,尤其当旋转平台与扫描系统的相对位置关系发生变化时,能够避免再次使用标定物重新对该相对位置关系进行标定,从而能够简化操作过程,提高旋转平台位置参数的计算效率。
52.进一步地,本发明实施例提供了一种用于三维扫描仪的旋转平台配准系统,包括三维扫描仪,所述三维扫描仪用于扫描旋转平台上的待扫描物体,并获取多幅三维点云;所述配准系统用于执行上述用于三维扫描的旋转平台位置参数计算方法,从而实现三维扫描仪的旋转平台配准。
53.进一步地,作为图1的具体实现,本发明实施例提供了一种用于三维扫描的旋转平台位置参数计算装置,如图4所示,所述装置包括:获取单元31、变换单元32、筛选单元33和计算单元34。
54.所述获取单元31,可以用于获取扫描到的旋转平台上的待扫描物体的多幅三维点云。
55.所述变换单元32,可以用于从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云。
56.所述筛选单元33,可以用于根据所述变换后的源点云,从所述目标点云中筛选出目标特征点。
57.所述计算单元34,可以用于基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
58.在具体应用场景中,所述筛选单元33,如图5所示,包括:第一确定模块331和筛选模块332。
59.所述第一确定模块331,可以用于从所述目标点云中随机抽取预设数量的特征点,并确定所述特征点分别在不同变换后的源点云中的最邻近特征点。
60.所述第一确定模块331,还可以用于确定所述特征点与所述不同变换后的源点云中最邻近特征点之间的距离值。
61.所述筛选模块332,可以用于基于所述距离值,从所述预设数量的特征点中筛选出目标特征点。
62.在具体应用场景中,所述筛选模块332,具体可以用于预设一个距离阈值;比较所述距离值与所述距离阈值;确定所述距离值小于所述距离阈值的特征点为目标特征点。
63.在具体应用场景中,所述多幅三维点云包括第一点云、第二点云和第三点云,所述获取单元31,具体可以用于获取所述待扫描物体在所述旋转平台旋转前被扫描到的第一点云,以及在所述旋转平台旋转后被扫描到的第二点云和第三点云;或者获取所述待扫描物体在所述旋转平台旋转后被扫描到的第一点云、第二点云和第三点云。
64.在具体应用场景中,所述所述旋转平台旋转时均以同一角度进行旋转。
65.在具体应用场景中,为了目标特征点在所述不同初始源点云中的坐标,所述装置还包括:确定单元35。
66.所述确定单元35,可以用于确定所述目标特征点在所述不同变换后的源点云中的最邻近特征点对应的索引值。
67.所述获取单元31,还可以用于基于所述索引值,获取所述目标特征点在所述不同初始源点云中的坐标。
68.在具体应用场景中,所述计算单元34,包括:第二确定模块341和计算模块342。
69.所述第二确定模块341,可以用于基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,确定拟合平面对应的法向量。
70.所述计算模块342,可以用于根据所述法向量,以及所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述拟合平面对应的中心点坐标。
71.所述计算模块342,还可以用于若存在多个所述目标特征点,计算多个所述目标特征点分别对应的法向量的均值,得到所述旋转平台对应的轴线向量,并计算多个所述目标特征点分别对应的中心点坐标的均值,得到所述旋转平台对应的轴心坐标。
72.所述第二确定模块341,还可以用于将所述轴线向量和所述轴心坐标,确定为所述旋转平台相对于扫描系统的位置参数。
73.在具体应用场景中,所述目标点云为第一点云,所述不同初始源点云分别为第二点云和第三点云,所述第二确定模块341,具体可以用于获取第一公式;根据所述第一公式,计算所述拟合平面对应的法向量;其中,所述第一公式为:,其中,(x1,y1,z1)为所述目标特征点在所述第一点云中的坐标,(x2,y2,z2)和(x3,y3,z3)为所述目标特征点分别在所述第二点云和所述第三点云中的坐标,(a,b,c)为所述拟合平面对应的法向量。
74.进一步地,所述计算模块342,具体可以用于获取第二公式;根据所述第二公式,计算所述拟合平面对应的中心点坐标;其中,所述第二公式为:,其中,(x1,y1,z1)为所述目标特征点在所述第一点云中的坐标,(x2,y2,z2)和(x3,y3,z3)为所述目标特征点分别在所述第二点云和所述第三点云中的坐标,(a,b,c)为所述拟
合平面对应的法向量,(x,y,z)为所述拟合平面对应的中心点坐标。
75.在具体应用场景中,所述旋转平台旋转时均以同一角度进行旋转,所述同一角度为20度。
76.需要说明的是,本发明实施例提供的一种用于三维扫描的旋转平台位置参数计算装置所涉及各功能模块的其他相应描述,可以参考图1所示方法的对应描述,在此不再赘述。
77.基于上述如图1所示方法,相应的,本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现以下步骤:获取扫描到的旋转平台上的待扫描物体的多幅三维点云;从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
78.基于上述如图1所示方法和如图4所示装置的实施例,本发明实施例还提供了一种计算机设备的实体结构图,如图6所示,该计算机设备包括:处理器41、存储器42、及存储在存储器42上并可在处理器上运行的计算机程序,其中存储器42和处理器41均设置在总线43上所述处理器41执行所述程序时实现以下步骤:获取扫描到的旋转平台上的待扫描物体的多幅三维点云;从获取的所述多幅三维点云中确定初始源点云和目标点云,并以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。
79.通过本发明的技术方案,本发明能够获取扫描到的旋转平台上的待扫描物体的多幅三维点云;并从获取的所述多幅三维点云中确定初始源点云和目标点云,以所述目标点云为基准,对所述初始源点云进行变换处理,得到变换后的源点云;与此同时,根据所述变换后的源点云,从所述目标点云中筛选出目标特征点;最终基于所述目标特征点分别在所述目标点云和不同初始源点云中的坐标,计算所述旋转平台相对于扫描系统的位置参数。由此通过直接对待扫描物体进行扫描,获取待扫描物体对应的初始源点云和目标点云,并从待扫描物体对应的目标点云中筛选出目标特征点,能够基于目标特征点在目标点云和不同初始源点云中的坐标点,计算出旋转平台的轴线向量和轴心坐标,并将其确定为所述旋转平台相对于扫描系统的位置参数,从而更方便和更高效的实现三维扫描仪的旋转平台配准。此外,在对旋转平台与扫描系统的相对于位置关系进行标定的过程中,能够避免使用标定物,尤其当旋转平台与扫描系统的相对位置关系发生变化时,能够避免再次使用标定物重新对该相对位置关系进行标定,从而能够简化操作过程,提高旋转平台位置参数的计算效率。
80.显然,本领域的技术人员应该明白,上述的本发明的各模块或各步骤可以用通用的计算装置来实现,它们可以集中在单个的计算装置上,或者分布在多个计算装置所组成的网络上,可选地,它们可以用计算装置可执行的程序代码来实现,从而,可以将它们存储在存储装置中由计算装置来执行,并且在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤,或者将它们分别制作成各个集成电路模块,或者将它们中的多个模块或
步骤制作成单个集成电路模块来实现。这样,本发明不限制于任何特定的硬件和软件结合。
81.以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包括在本发明的保护范围之内。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1