Next Article in Journal
Electrophysiological Features to Aid in the Construction of Predictive Models of Human–Agent Collaboration in Smart Environments
Previous Article in Journal
Predicting Perceived Exhaustion in Rehabilitation Exercises Using Facial Action Units
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Improved Registration Algorithm Based on Double Threshold Feature Extraction and Distance Disparity Matrix

School of Instrument Science and Opto-Electronics Engineering, Hefei University of Technology, Hefei 230009, China
*
Author to whom correspondence should be addressed.
Sensors 2022, 22(17), 6525; https://doi.org/10.3390/s22176525
Submission received: 11 July 2022 / Revised: 20 August 2022 / Accepted: 24 August 2022 / Published: 30 August 2022
(This article belongs to the Topic Manufacturing Metrology)

Abstract

:
Entire surface point clouds in complex objects cannot be captured in a single direction by using noncontact measurement methods, such as machine vision; therefore, different direction point clouds should be obtained and registered. However, high efficiency and precision are crucial for registration methods when dealing with huge number of point clouds. To solve this problem, an improved registration algorithm based on double threshold feature extraction and distance disparity matrix (DDM) is proposed in this study. Firstly, feature points are extracted with double thresholds using normal vectors and curvature to reduce the number of points. Secondly, a fast point feature histogram is established to describe the feature points and obtain the initial corresponding point pairs. Thirdly, obviously wrong corresponding point pairs are eliminated as much as possible by analysing the Euclidean invariant features of rigid body transformation combined with the DDM algorithm. Finally, the sample consensus initial alignment and the iterative closest point algorithms are used to complete the registration. Experimental results show that the proposed algorithm can quickly process large data point clouds and achieve efficient and precise matching of target objects. It can be used to improve the efficiency and precision of registration in distributed or mobile 3D measurement systems.

1. Introduction

With the rapid development of machine vision in recent years, vision technology based on 3D point clouds has been widely used in the fields of industrial design, reverse engineering, surface defect detection, and virtual reality. Compared with traditional 2D images, 3D data provide richer information [1]. As a special information format that contains complete 3D spatial data, 3D point cloud data have elicited extensive attention [2]. At present, methods for collecting 3D data include the time-of-flight [3], stereo vision [4], laser scanning [5], and structured light [6] methods. Limited by the scanning angle of the device and the shape of the object, the complete 3D information of an object must be collected from multiple views, and point clouds must be registered into a complete model. Point cloud registration is a key step in capturing the complete shape of 3D objects.
The purpose of point cloud registration is to find a 3D rigid body transformation, such that the point cloud of the same object from different perspectives can be transformed into the same coordinate system for rapid and accurate matching and splicing. Splicing accuracy directly affects the accuracy of model reconstruction [7]. The same-source registration can be divided into optimization-based registration methods, feature-learning methods, and end-to-end learning registration [8]. The deep learning-based methods do not require iteration, but large training data is needed [9,10,11]. Besides, the registration results are sensitive to noise. Optimization-based registration is to use optimization strategies to estimate the transformation matrix without training data. The most widely used point cloud registration algorithm is the iterative closest point (ICP) algorithm proposed by Besl et al. [12]. This algorithm requires a good initial position and a high overlap rate. Moreover, it easily falls into the local optimal solution. Therefore, this algorithm is typically used for fine registration [13]. To improve the efficiency and accuracy of registration, scholars have proposed a variety of methods, including velocity updating ICP [14], generalised ICP (GICP) [15], and globally optimal ICP [16]. Magnusson [17] proposed a registration algorithm that differed from the ICP registration model, called the 3D normal distribution transformation algorithm. This algorithm was based on the probability density model, did not require calculating the nearest neighbour corresponding points, and reduced computational complexity. Zhong [18] designed an inherent shape feature to describe point feature information by establishing the local reference coordinate system and 3D histogram of each point. However, the uneven distribution of points and measurement noise affected the registration results. Rusu et al. [19] proposed a point feature histogram (PFH) algorithm and a fast PFH (FPFH) algorithm [20,21] for local feature descriptions. Yun et al. [22] calculated congruent triangles by using the centroid of a point cloud ball to obtain the corresponding relationship between them. Coarse registration was performed through the centroid. Jauer P. et al. [23] used knowledge in mechanics and thermodynamics to assume that a point cloud is a rigid body composed of particles. A force was applied between two particle systems to cause one of the systems to move towards the rigid body of the other system to complete point cloud registration. Chen et al. [24] designed a novel descriptor based on a plane/line. This descriptor was particularly used for establishing structure-level correspondence between point clouds for coarse registration. Raobo Li et al. [25] proposed a point cloud registration method that used the feature transformation processing of the centre of gravity. Two feature vectors were constructed from the nearest and farthest points of the centre of gravity, and a third feature vector was synthesised. Finally, point cloud registration was performed. Wang et al. [26] used the principal component analysis (PCA) method to realise the coarse registration of point clouds. In fine registration, the nearest point is iterated on the basis of the two-way distance proportion. This method exhibits a certain improvement in accuracy and speed compared with the classical ICP algorithm; however, it is more sensitive to noise points. Song et al. [27] conducted a down-sampling of a point cloud, extracted feature points through the angle characteristics of a normal vector neighbourhood, and established FPFH for feature descriptions. The combination of the sample consensus initial alignment (SAC-IA) and ICP algorithms was used to complete point cloud registration. Xu et al. [28] proposed an improved ICP algorithm that combined the random sample consensus algorithm, intrinsic shape signatures, and 3D shape context. Min et al. [29] synthesized a hybrid mixture probabilistic model with the directional and positional information of each point to completes point cloud registration. KOIDE et al. [30] proposed a multi-point distribution aggregation method to extend the GICP approach.
The aforementioned methods can be classified into two categories. The first category includes algorithms based on a global search strategy, which reaches the optimal solution with continuous iteration. Their limitation is the existence of noise points, which increase computational costs. The second category includes methods based on feature matching, which extracts representative feature points from a point cloud to reduce the amount of calculation. The selection of feature points and their description method will determine the registration result. These methods frequently lead to low registration accuracy due to the lack of representativeness or insufficient number of feature points. The accuracy of feature point extraction directly affects registration precision. Therefore, studying an appropriate method to obtain accurate feature points is a challenge.
In the current study, we use the normal vector and the curvature of a local point cloud for feature extraction with double threshold to extract representative feature points. The FPFH descriptor is used to describe the feature points and obtain the initial corresponding point set. By considering the invariance of distance and angle between feature points, the distance disparity matrix (DDM) algorithm is used to eliminate the wrong corresponding point pairs, and thus, determine accurate corresponding point pairs. Then, the SAC-IA algorithm is used for coarse registration to obtain a better initial position of point clouds. Finally, the ICP algorithm is used for fine registration. Representative feature points are obtained by extracting feature points with double thresholds and removing mismatched pairs, making the subsequent registration fast and accurate. The combination of coarse and fine registration solves the problems of slowness and low accuracy of the ICP algorithm.
The remainder of this paper is organised as follows. Section 2 provides details of our proposed method and describes relevant principles. Section 3 introduces an experiment of this method on three models in the basic geometry library and evaluates its accuracy and efficiency. Section 4 presents the conclusions of this study.

2. Materials and Methods

The flowchart of the proposed method, which mainly includes five steps, is shown in Figure 1. P represents the source point cloud, and Q represents the target point cloud. Firstly, the feature points of the origin cloud are extracted using the normal vector and curvature with double threshold to reduce the number of point clouds and registration time. Secondly, the FPFH is used to describe the feature points to obtain the initial set of corresponding point pairs. Thirdly, the mismatched point pairs are removed using the DDM algorithm to improve the accuracy of the corresponding point pairs. Fourthly, the SAC-IA algorithm is used for the coarse registration of point clouds to provide a good initial position for subsequent registration. Finally, the ICP algorithm is used for fine registration.

2.1. Normal Vector Calculation

The normal vector is an important geometric attribute in a point cloud data model. The included angle of the normal vector of the points in the local neighbourhood can reflect the change information of the surface, as illustrated in Figure 2. When the normal vector in the region surface changes gradually, the region is relatively flat. When the normal vector changes abruptly, the region fluctuates considerably. Therefore, the appropriate threshold can be set in accordance with the change in the normal vector in the neighbourhood to obtain the feature point.
PCA [31] is a common method for calculating the normal vector. For any p i in point cloud P , covariance analysis is performed on p i and its neighbouring points p i j in its k-neighbourhood. The specific steps for calculating the normal vector are as follows:
(1)
For point p i ( x i , y i , z i ), its neighbourhood points p i 1 , p i 2 , … p i k are found in a ball of radius r .
(2)
Equations (1) and (2) are used to calculate the normal vector of point n i , where p ¯ i is the 3D centroid of the neighbourhood point set, and C is the covariance matrix of p ¯ i . The three eigenvectors and the corresponding three eigenvalues of covariance matrix C are calculated via eigenvalue decomposition. The eigenvector that corresponds to the smallest eigenvalue is the normal vector of point p ¯ i .
(3)
The direction of the normal vector is determined using Equation (3). In general, the direction of the normal vector is consistent towards the viewpoint direction (from viewpoint   v p to p i ).
p ¯ i = 1 k j = 1 k p i j
C = 1 k j = 1 k ( p i j p ¯ i ) ( p i j p ¯ i ) T
n i = { n i ,     n i ( v p p i ) > 0 n i ,     n i ( v p p i ) < 0

2.2. Curvature Calculation

Curvature is a concept that describes the degree of curvature of a surface and is a basic attribute of a surface. During point cloud processing, the curvature is also an important attribute for describing the geometric characteristics of point clouds. Each point in the point cloud and its adjacent points can be typically fitted into a local surface, and the local surface curvature is used as the curvature of the point. In the current study, the least squares method is used to calculate the curvature of point clouds. The curvature calculation process is summarised as follows:
(1)
Point p i is set as the coordinate origin, establishing the local coordinate system ( u ,   v ,   w ). The direction of the normal vector of the surface at point p i is the direction of the w -axis. The u - and v - axes are on the tangent plane at point p i , as shown in Figure 3. The u - v - and w -axes are orthogonal.
(2)
Basic equation of quadric surface [32]:
S ( u , v ) = ( u , v , w ( u , v ) )
w ( u , v ) = a u 2 + b u v + c v 2 + e u + f v
If e and f in Equation (5) are equal to zero, then Equation (4) represents a quadratic parabolic surface. For point p i , its neighbourhood point p j   ( j = 1 , 2 , , k ) is converted into the local coordinate system ( u ,   v ,   w ) , and the converted coordinates are ( u j , v j , w j ) . The coordinates are substituted into the formula calculation. When k is greater than 3, a set of overdetermined equations is obtained. In accordance with the least squares method, the optimal fitting parameters a , b , and c are finally obtained.
(3)
The first fundamental quantity ( E , F , G ) and the second fundamental quantity ( L , M , N ) of the fitted surface can be obtained by solving the first- and second-order partial derivatives of the equation from the basic equation of the surface. Combined with the surface parameter equation, the principal curvature ( k 1 , k 2 ), Gaussian curvature ( K ), and average curvature ( H ) can be calculated.
{ k 1 = a + c + ( a c ) 2 + b 2 k 2 = a + c ( a c ) 2 + b 2 K = k 1 . k 2 = L N M 2 E G F 2 = 4 a c b 2 H = k 1 + k 2 2 = E N 2 F M + L G 2 ( E G F 2 ) = a + c
The feature extraction method based on curvature can accurately identify the feature information of a point cloud, accurately extract the detailed features of the abrupt and gradual regions of the surface and effectively retain the feature information of the model.

2.3. Double Threshold Feature Extraction Based on the Normal Vector and Curvature

Double threshold feature extraction based on the normal vector and curvature extracts feature information by using the included angle of the normal vector and the threshold of the average curvature feature weight of points in the local neighbourhood of the point cloud. This method exhibits evident improvement in stability and accuracy due to the constraints of the normal vector and curvature.
The angle of the normal vector is used to construct the constraint condition of feature judgement: the angle between points p i and p j in their k-neighbourhood is expressed by θ i j , where n i and n j are the normal vectors of the p i and p j .
θ i j = a r c c o s n i   ·   n j | n i | | n j | ,   θ i j ϵ [ 0 , π ]
The change degree f i of the included angle of the normal vector of point p i is defined as follows:
f i = 1 k j = 1 k θ i j
The average curvature local characteristic weight w H of point p i in its k-neighbourhood is defined as follows:
{ w H ( p i ) = 1 k i = 1 k ( | H p i | H ¯ ) + ( H i H ¯ ) H ¯ = 1 k i = 1 k H i
where H represents the average curvature of point p i in its k-neighbourhood. Whether the point belongs to the feature point by f i of the normal vector and w H of the curvature is determined. If f i is greater than the set threshold α 1 , then the point is divided into the potential feature point sets. If f i is less than the set threshold, then it is not a feature point. If w H is greater than the set threshold α 2 , then the point is a feature point, and it is added to the feature point set. If w H is less than the set threshold, then the point is not a feature point, and it is removed from the potential feature point set. Then, the FPFH is used to describe the feature point set to obtain the initial sets of corresponding point pairs A extracted from P and B extracted from Q .

2.4. DDM Algorithm

In rigid body transformation, the distance and principal axis angle of any two feature points remain unchanged before and after transformation. The consistent characteristics of this distance and angle can be used to eliminate unreliable or wrong matching point pairs. Consider the feature point sets   A { a 1 , a 2 , , a n } and B { b 1 , b 2 , , b n } , where ( a i , b i ) represents the corresponding point pair. As shown in Figure 4, the distance between feature points remains basically unchanged before and after transformation; that is, | d i k a d i k b | < e , and e represents the error threshold. If a mismatch   ( a k ,   b k ) occurs, then the distance between other points in b k and B will change considerably compared with the distance between other corresponding points in a k and A , i.e., | d i k a d i k b | > e . This difference in Euclidean distance can be used to eliminate external point pairs [33].
The calculation process is as follows:
(1)
The distance matrix for point sets A and B is calculated, i.e., M A = [ a i j ] , M B = [ b i j ] ,( i = 1 , 2 , , n , j = 1 , 2 , n ), where a i j = d ( a i , a j ) , b i j = d ( b i , b j ) .
(2)
The DDM is calculated, i.e., M D D M = [ c i j ] , c i j = | a i j b i j | . Each element in the matrix represents the difference between the Euclidean distances of two feature points before and after rigid body transformation; hence, it is called DDM. If the point pair set has no external value, then a i j = b i j , c i j = 0 ; otherwise, if ( a k ,   b k ) is a wrong match, then a large nonzero value will appear in row k and column k of the symmetric matrix M D D M , resulting in ( a k ,   b k ) being distinguished from other point pairs.
(3)
A vector m is defined to store the mean value of each row of M D D M , and the extreme values m m a x   and   m m i n are determined. If the subtraction of the two values is less than the set threshold α 3 , then m m a x = 0 , and the extreme value is continuously found; otherwise, the cycle is exited.
From the preceding calculation process, an out-of-area matching is manifested in M D D M by more nonzero values in its corresponding row, resulting in a large mean m i , which is positively correlated with its offset degree. Moreover, m i can reflect the matching accuracy of point pairs ( a i ,   b i ) . Therefore, wrong matching point pairs can be detected and eliminated by observing vector m . Then the correct sets of corresponding points A C and B C are obtained.

2.5. SAC-IA Coarse Registration

To achieve the good registration effect of 3D point clouds, the coarse-to-fine registration strategy is adopted. SAC-IA is used to realise the coarse registration. The principle of the SAC-IA registration algorithm is as follows:
(1)
A number of sampling points are selected from the source point cloud P , and the distance between each point should be greater than the minimum distance given in advance to ensure that there are different FPFH between points.
(2)
According to the FPFH, one or more points similar to the sampling points are found in the target point cloud Q , and these similar points are regarded as the corresponding points of the sampling points.
(3)
The transformation matrix is calculated in accordance with the corresponding points. The performance of registration is evaluated according to the total distance error function by solving the corresponding point transformation, which is expressed as follows:
H ( l i ) = {   1 2 l i 2 ,                                                 | l i < m i 1 2 m i ( 2 l i m i ) ,     | l i > m i
in which, m i is the specified value and l i is the distance difference after the corresponding point transformation. When the registration process is completed, the one with the smallest error in all the transformations is considered the optimal transformation matrix for initial registration.
In coarse registration, we use the correct sets of corresponding points A C and B C to replace the P and Q , and obtain the initial translation matrix. Perform the initial transformation matrix on the point cloud A C , and get the transformed corresponding point cloud A C .

2.6. ICP Fine Registration

After coarse registration with the SAC-IA algorithm, the source and target point clouds roughly coincide, but the registration accuracy is low. Then, the ICP algorithm is used for fine registration. The specific algorithm steps are as follows:
(1)
The point cloud after coarse registration P and the target point cloud Q are taken as the initial point set for fine registration.
(2)
For all points p i of P , the nearest corresponding point q i in Q is found to form the initial corresponding point pairs.
(3)
Use the least square method to solve the optimal rotation matrix R and translation matrix T , perform R , T on the point cloud P and the mean square error (MSE) function d k is minimized.
d k = 1 N i = 1 N q i ( R p i + T ) 2
(4)
Set the threshold ε , if the condition d k d k + 1 < ε is met, end the iteration and get the final transformation matrix R and T .
In fine registration, we use the point cloud A C to replace the P . According to the finally obtained R and T , the source point cloud P is transformed into the coordinate system of the target point cloud Q to complete the registration.

3. Results

The software environment used in this experiment is Microsoft Visual Studio 2017 and Point Cloud Library running on an AMD Ryzen 7 4800u computer with 16.0 GB and a 64-bit Windows 10 operating system.

3.1. Selection of Mian Parameters

To verify the effectiveness of the algorithm, validation experiments are performed using Bunny, Dragon, Armadillo, and Buddha models from Stanford University, and the Airplane model from the Modelnet40 Dataset [34]. To verify the soundness and efficiency of the algorithm proposed in this study, it is compared with the ICP algorithm and the algorithms in [27,28]. MSE is a commonly used error measurement method in point cloud registration; it is the average of the sum of squares distances between the corresponding points of two-point clouds. A smaller MSE indicates a better registration effect. The results of each algorithm are compared in terms of MSE and registration time.
Registration results of the proposed algorithm are related to four main parameters, including the neighbourhood radius k, thresholds α 1 , α 2 , and α 3 . Table 1 shows the average number of neighbourhood points under different values of k. For each point p i , calculate the normal vector and curvature under different values of k.
When k = 0.001   m , the average number of neighbourhood points is too few and no result is obtained, whilst when k     0.003   m , too many points lead to long calculation time. Thus, the value of k is selected as 0.002 m.
Based on the calculated results of f i , w H , and M D D M , we set the initial scope of α 1 [ 10 ,   30 ]   rad , α 2 [ 5 ,   20 ]   1 / m and α 3 [ 0.0005 ,   0.002 ]   m . Figure 5 is the flowchart of how to obtain the threshold value α 1 . First, we input the initial value that α 1 = 10   rad , α 2 = 5   1 / m , and α 3 = 0.002   m in the proposed algorithm and get the registration results MSE M 0 and time T 0 . Then, the step size α 1 = 1 is set. When the threshold value is too large and the number of extracted feature points is too small, the registration fails. The next registration is performed under α 1 = α 1 + α 1 , and the MSE M 1 and time T 1 are obtained. By comparing these two registration results, the α 1 under the smaller registration result is selected for the next comparison. Finally, we get the value of α 1 with the smallest registration result in the range. The initial value of α 1 is modified, and then calculate it in the same way to get the value of α 2 . The step size α 2 = 1   and α 3 = 0.0001 are set.
The value of all parameters in the proposed algorithm are listed in Table 2.

3.2. The Results of Experiments

The experiment is divided into two cases. Case 1: the point cloud under one angle is converted into another angle by the matrix for registration. Case 2: two-point clouds are collected under different angles for registration.
For Case 1, the target point cloud is converted from the source point cloud with the same number of points, and the two-point clouds exhibit one-to-one correspondence without missing points. Case 1 simulates the unique correspondence of feature points under ideal conditions as a way to verify that the feature points extracted by our algorithm are valid and correct. Theoretically, if the feature points are accurate, the two-point clouds can overlap exactly.
Table 3 shows the registration results of each algorithm for the five models in Case 1. ICP takes a long time to process the big data point cloud, has low efficiency, and exhibits poor registration effects. As the number of point clouds increases, the time becomes longer. The algorithms in [27,28] down-sample the initial point cloud and extract feature points by a single feature. The number of the extracted feature points is large and it takes time to complete the coarse registration. Although the registration is completed, the MSE of the two algorithms is large, which indicates that the feature points contain the wrong points. It can also be seen from Figure 6 that there is a position error between the two-point clouds. The MSE of our algorithm is almost zero and the two-point clouds completely overlap, which represents exact registration with accurate feature points.
In the Airplane model, the algorithms in [27,28] spend a lot of time on coarse registration. The reason is that the down-sampling is affected by point cloud density. The proposed algorithm calculates the feature information based on the neighbourhood points without the influence of the point cloud density. For models with particularly complex surfaces, such as the Buddha, many feature points take time in coarse registration, but accurate registration can also be accomplished. In the figures, the target point clouds are in green, the source point clouds are in red.
For Case 2, i.e., the conventional case, there are occlusion, deletion, noise interference, and other factors, which will lead to different point cloud data collected from different views in multi-view 3D scanning. Therefore, the accuracy of feature points plays an important part in registration.
Table 4 shows the registration results of Case 2 in different models. The accuracy of the ICP algorithm and the algorithms in [27,28] is comparable, whilst the proposed algorithm is more accurate. For general surfaces, the registration time of our algorithm is considerably shorter than that of the ICP algorithm, 1/4 of that of the algorithm in [27] and 1/2 of that of the algorithm in [28]. When the point cloud density changes, there are too many points after the down-sample, resulting in a long registration time of the algorithms in [27,28]. The time of our algorithm is not affected by the point cloud density and is still able to complete the registration in a relatively short time. For complex surfaces, although our algorithm takes longer time in registration, the accuracy is high. As can be seen from Figure 7, our registration effect is the best compared to the other three algorithms, especially when registering objects with complex surfaces.
The comparison of the number of point clouds in each processing stage is provided in Table 5. After the double threshold feature extraction of the original point cloud, the number of point clouds is considerably reduced. After the feature description and finding the corresponding point pairs, the mismatched point pairs are removed by the DDM algorithm, and the number of finally registered point clouds is about 0.1% of the original point clouds. Therefore, the selection of highly representative feature points is a prerequisite for high-precision registration. Compared with those of the traditional ICP and improved algorithms, the efficiency and accuracy of our proposed algorithm are significantly improved.
The algorithm proposed in this study uses neighbourhood point information to extract feature points, eliminate mismatched point pairs, reduce the number of point cloud registrations, and improve the correspondence between point pairs, which is suitable for objects that have distinctive features on the surface. The accuracy of the registration is not affected by the density of the point cloud, but the registration time is related to the complexity of the surface. Compared with those obtained via down-sampling, feature points extracted on the basis of the normal vector and curvature are more representative and can achieve high-precision point cloud registration.

4. Conclusions

In the process of point cloud registration, feature points affect the registration results, which represent the big data point cloud, and can improve the efficiency of the algorithm. In addition, the descriptor can determine the final performance. It can provide a useful representation of the shape around the fixed point and help search for the corresponding relationship between the two shapes, avoiding an exhaustive search. The combination of the two can considerably improve the efficiency and accuracy of registration.
In the current study, we proposed an improved registration algorithm based on double threshold feature extraction and DDM. We studied the translation-rotation invariance of point cloud geometric features during rigid body transformation, and we extract feature points with double threshold by using normal vector and curvature. Wrong points may occur in feature extraction under a single condition. The double constraints of the normal vector and curvature make extracting more representative feature points possible. It also greatly reduces the number of original point clouds and reduces the number of subsequent calculations. Some feature points extracted via down-sampling cannot represent the feature of this region, and the probability of wrong point pairs is relatively high. FPFH is applied to describe feature points and find initial matching point pairs quickly. According to the principle of the DDM algorithm, it can effectively remove the mismatched point pairs of the initial matching and further reduce the number of point clouds. The final number of the point cloud is just 0.1% of the original point cloud. Through the above processing, we not only improve the accuracy of the feature points, but also gradually reduce the amount of data to be processed at the same time, which paves the way for subsequent registration.
However, the final corresponding point pairs cannot be guaranteed to be completely correct and influence the final registration results due to noise and other interference factors. Besides, the registration time of this algorithm is related to the complexity of the object surface. Too many feature points lead to a longer registration time. In the next step, we will first perform noise processing on the original point cloud data and investigate feature descriptors to improve the accuracy of the corresponding point pairs to help make registration more precise.

Author Contributions

Conceptualization, B.W. and J.Z.; Data curation, J.Z.; Formal analysis, B.W. and Y.W.; Funding acquisition, B.W. and B.H.; Investigation, B.W. and Y.W.; Methodology, B.W. and J.Z.; Project administration, B.W. and B.H.; Resources, B.W. and B.H.; Software, J.Z. and Y.H.; Supervision, Y.W.; Validation, J.Z. and Y.H.; Visualization, J.Z. and Y.H.; Writing—original draft, J.Z.; Writing—review & editing, B.W., J.Z. and Y.H. All authors have read and agreed to the published version of the manuscript.

Funding

This work was supported in part by Hefei Municipal Natural Science Foundation (Grant No. 2022022), and National Natural Science Foundation of China (Grant No. 51975178).

Data Availability Statement

Not applicable.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Azizmalayeri, F.; Peyghambarzadeh, S.M.M.; Khotanlou, H.; Salarpour, A. Kernel Correlation Based CNN for Point Cloud Classification Task. In Proceedings of the 2018 8th International Conference on Computer and Knowledge Engineering (ICCKE), Mashhad, Iran, 25–26 October 2018; pp. 200–204. [Google Scholar] [CrossRef]
  2. Liu, J.; Bai, D.; Chen, L. 3D point cloud registration algorithm based on greedy projection triangulation. Appl. Sci. 2018, 8, 1776. [Google Scholar] [CrossRef]
  3. Moring, I.; Ailisto, H.; Koivunen, V.; Myllylä, R. Active 3D vision system for automatic model-based shape inspection. Opt. Lasers Eng. 1989, 10, 149–160. [Google Scholar] [CrossRef]
  4. Luo, H.; Pape, C.; Reithmeier, E. Scale-Aware Multi-View Reconstruction Using an Active Triple-Camera System. Sensors 2020, 20, 6726. [Google Scholar] [CrossRef] [PubMed]
  5. Baltsavias, E.P. A comparison between photogrammetry and laser scanning. ISPRS J. Photogramm. Remote Sens. 1999, 54, 83–94. [Google Scholar] [CrossRef]
  6. Gong, Y.; Zhang, S. Ultrafast 3D shape measurement with an off-the-shelf DLP projector. Opt. Express 2010, 18, 19743–19754. [Google Scholar] [CrossRef] [PubMed]
  7. Li, X.C.; Yan, Z.Y.; Lin, S. Point Cloud Registration Based on Neighbourhood Characteristic Point Extraction and Matching. Acta Photonica Sin. 2020, 49, 0415001. [Google Scholar] [CrossRef]
  8. Huang, X.; Mei, G.; Zhang, J.; Abbas, R. A comprehensive survey on point cloud registration. arXiv 2021. [Google Scholar] [CrossRef]
  9. Liu, X.; Qi, C.R.; Guibas, L.J. FlowNet3D: Learning Scene Flow in 3D Point Clouds. In Proceedings of the 2019 IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR), Long Beach, CA, USA, 15–20 June 2019; pp. 529–537. [Google Scholar] [CrossRef]
  10. Ao, S.; Hu, Q.; Yang, B.; Markham, A.; Guo, Y. Spinnet: Learning a general surface descriptor for 3d point cloud registration. In Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition, Nashville, TN, USA, 25 June 2021; pp. 11753–11762. [Google Scholar] [CrossRef]
  11. Zhang, Z.; Dai, Y.; Sun, J. Deep learning based point cloud registration: An overview. Virtual Real. Intell. Hardw. 2020, 2, 222–246. [Google Scholar] [CrossRef]
  12. Besl, P.J.; McKey, H.D. A method for registration of 3D shapes. IEEE Trans. Pattern Anal. Mach. Intell. 1992, 14, 239–256. [Google Scholar] [CrossRef]
  13. He, Y.; Liang, B.; Yang, J.; Li, S.; He, J. An iterative closest points algorithm for registration of 3D laser scanner point clouds with geometric features. Sensors 2017, 17, 1862. [Google Scholar] [CrossRef]
  14. Hong, S.; Ko, H.; Kim, J. VICP: Velocity updating iterative closest point algorithm. In Proceedings of the 2010 IEEE International Conference on Robotics and Automation, Anchorage, Alaska, 3–8 May 2010; pp. 1893–1898. [Google Scholar] [CrossRef]
  15. Segal, A.; Haehnel, D.; Thrun, S. Generalised-ICP. Robot. Sci. Syst. 2009, 2, 435. [Google Scholar] [CrossRef]
  16. Yang, J.; Li, H.; Jia, Y. Go-ICP: Solving 3D Registration Efficiently and Globally Optimally. In Proceedings of the 2013 IEEE International Conference on Computer Vision, Sydney, Australia, 1–8 December 2013. [Google Scholar] [CrossRef]
  17. Magnusson, M.; Lilienthal, A.; Duckett, T. Scan registration for autonomous mining vehicles using 3D-NDT. J. Field Robot. 2007, 24, 803–827. [Google Scholar] [CrossRef]
  18. Yu, Z. Intrinsic shape signatures: A shape descriptor for 3D object recognition. In Proceedings of the IEEE International Conference on Computer Vision Workshops, Montreal, BC, Canada, 11–17 October 2010. [Google Scholar] [CrossRef]
  19. Rusu, R.B.; Blodow, N.; Marton, Z.C.; Beetz, M. Aligning point cloud views using persistent feature histograms. In Proceedings of the 2008 IEEE/RSJ International Conference on Intelligent Robots and Systems, Nice, France, 22–26 September 2008; pp. 3384–3391. [Google Scholar] [CrossRef]
  20. Rusu, R.B.; Blodow, N.; Beetz, M. Fast point feature histograms (FPFHs) for 3D registration. In Proceedings of the 2009 IEEE International Conference on Robotics and Automation, Kobe, Japan, 12–17 May 2009; pp. 3212–3217. [Google Scholar] [CrossRef]
  21. Zhao, J.; Li, C.; Tian, L.; Zhu, J. FPFH-based graph matching for 3D point cloud registration. In Proceedings of the Tenth International Conference on Machine Vision (ICMV 2017), Vienna, Austria, 13–15 November 2017; Volume 10696, pp. 143–155. [Google Scholar] [CrossRef]
  22. Yun, D.; Kim, S.; Heo, H.; Ko, K.H. Automated registration of multi-view point clouds using sphere targets. Adv. Eng. Inform. 2015, 29, 930–939. [Google Scholar] [CrossRef]
  23. Jauer, P.; Kuhlemann, I.; Bruder, R.; Schweikard, A.; Ernst, F. Efficient registration of high-resolution feature enhanced point clouds. IEEE Trans. Pattern Anal. Mach. Intell. 2018, 41, 1102–1115. [Google Scholar] [CrossRef] [PubMed]
  24. Chen, S.; Nan, L.; Xia, R.; Zhao, J.; Wonka, P. PLADE: A plane-based descriptor for point cloud registration with small overlap. IEEE Trans. Geosci. Remote Sens. 2019, 58, 2530–2540. [Google Scholar] [CrossRef]
  25. Raobo, L.; Xiping, Y.; Shu, G.; Rui, B.; Sha, G.; Lin, H. Research on Point Cloud Registration Method Using Gravity Feature Transformation. Acta Photonica Sin. 2021, 50, 1112002. [Google Scholar] [CrossRef]
  26. Bin, W.; Lin, L.; Yuqing, H. Three-dimensional cardiac point cloud registration by improved iterative closest point method. Opt. Precis. Eng. 2020, 28, 474–484. [Google Scholar] [CrossRef]
  27. Chenghang, S.; Jingru, L.; Guanjie, L. Improved ICP algorithm point cloud registration by feature point sampling consistency. Beijing Surv. Mapp. 2021, 35, 6. [Google Scholar] [CrossRef]
  28. Xu, G.; Pang, Y.; Bai, Z.; Wang, Y.; Lu, Z. A Fast Point Cloud Registration Algorithm for Laser Scanners. Appl. Sci. 2021, 11, 3426. [Google Scholar] [CrossRef]
  29. Min, Z.; Wang, J.L.; Meng, M.Q.H. Robust generalized point cloud registration using hybrid mixture model. In Proceedings of the 2018 IEEE International Conference on Robotics and Automation (ICRA), Brisbane, Australia, 21–25 May 2018; pp. 4812–4818. [Google Scholar] [CrossRef]
  30. Koide, M.Y.; Oishi, S.; Banno, A. Voxelized gicp for fast and accurate 3d point cloud registration. In Proceedings of the 2021 IEEE International Conference on Robotics and Automation (ICRA), Xi’an, China, 30 May–5 June 2021; pp. 11054–11059. [Google Scholar] [CrossRef]
  31. Shui, W.; Zhou, M. An approach for model reconstruction based on multi-view scans registration. In Proceedings of the 2010 International Conference on Audio, Language and Image Processing, Shanghai, China, 23–25 November 2010; pp. 601–606. [Google Scholar] [CrossRef]
  32. Milroy, M.J.; Bradley, C.; Vickers, G.W. Segmentation of a wraparound model using an active contour. Comput. Aided Des. 1997, 29, 299–320. [Google Scholar] [CrossRef]
  33. Luo, N.; Wang, Q. Optimised initial aligning algorithm for point cloud registration. J. Xidian Univ. 2017, 44, 69–74. [Google Scholar] [CrossRef]
  34. Wu, Z.; Song, S.; Khosla, A.; Yu, F.; Zhang, L.; Tang, X.; Xiao, J. 3D ShapeNets: A Deep Representation for Volumetric Shapes. In Proceedings of the 28th IEEE Conference on Computer Vision and Pattern Recognition (CVPR2015), Columbus, OH, USA, 23–28 June 2015; pp. 1912–1920. [Google Scholar] [CrossRef] [Green Version]
Figure 1. Flowchart of the proposed algorithm.
Figure 1. Flowchart of the proposed algorithm.
Sensors 22 06525 g001
Figure 2. Normal vector reaction surface information. (a) Gradual region; (b) Abrupt region.
Figure 2. Normal vector reaction surface information. (a) Gradual region; (b) Abrupt region.
Sensors 22 06525 g002
Figure 3. Local coordinate system.
Figure 3. Local coordinate system.
Sensors 22 06525 g003
Figure 4. Schematic of wrong point pair.
Figure 4. Schematic of wrong point pair.
Sensors 22 06525 g004
Figure 5. Flowchart of how to obtain the threshold value α 1 .
Figure 5. Flowchart of how to obtain the threshold value α 1 .
Sensors 22 06525 g005
Figure 6. Registration effect of the same angle. (a) Initial position; (b) ICP; (c) Algorithm in [27]; (d) Algorithm in [28]; (e) Proposed.
Figure 6. Registration effect of the same angle. (a) Initial position; (b) ICP; (c) Algorithm in [27]; (d) Algorithm in [28]; (e) Proposed.
Sensors 22 06525 g006
Figure 7. Registration effect of different angles.(a)Initial position; (b)ICP; (c) Ref. [27]; (d) Ref. [28]; (e) Proposed.
Figure 7. Registration effect of different angles.(a)Initial position; (b)ICP; (c) Ref. [27]; (d) Ref. [28]; (e) Proposed.
Sensors 22 06525 g007
Table 1. The average number of neighbourhood points under different values of k.
Table 1. The average number of neighbourhood points under different values of k.
k/m0.010.00090.00080.00070.00060.0050.0040.0030.0020.001
Neighbourhood points62350740230922915910258255
Table 2. All parameters of the proposed algorithm.
Table 2. All parameters of the proposed algorithm.
ParametersValueDefinition
k0.002 mNeighbourhood radius
α 1 20 radThreshold of normal vector change degree
α 2 15 1/mThreshold of average curvature local characteristic weight
α 3 0.001 mThreshold of ending the DDM algorithm
R F P F H 0.004 mRadius of calculating FPFH
ε i c p 0.01 mMax distance threshold of corresponding points for ICP
I t e r i c p 50Max iteration number for ICP
Table 3. Registration results from the same angle.
Table 3. Registration results from the same angle.
ModelNumber of PointsAlgorithmTime of Coarse RegistrationTime of ICPMSE
Bunny
(0°)
40,256ICP/61.758 s1.939 × 10−7
Algorithm in [27]11.805 s1.088 s2.560 × 10−7
Algorithm in [28]3.443 s0.652 s9.116 × 10−7
Proposed1.676 s0.604 s1.259 × 10−16
Armadillo
(60°)
23,404ICP/20.287 s5.169 × 10−7
Algorithm in [27]8.593 s0.663 s3.041 × 10−7
Algorithm in [28]2.839 s0.412 s8.219 × 10−8
Proposed2.807 s0.345 s3.515 × 10−16
Dragon
(24°)
34,836ICP/56.146 s2.735 × 10−7
Algorithm in [27]10.561 s0.908 s3.967 × 10−7
Algorithm in [28]4.833 s0.616 s9.306 × 10−8
Proposed1.610 s0.511 s8.385 × 10−16
Buddha
(0°)
78,056ICP/164.677 s5.632 × 10−8
Algorithm in [27]30.416 s4.158 s8.658 × 10−8
Algorithm in [28]4.098 s1.418 s4.228 × 10−8
Proposed20.666 s2.873 s6.643 × 10−16
Plane36,980ICP/39.74 s5.185 × 10−12
Algorithm in [27]324.319 s3.639 s5.932 × 10−7
Algorithm in [28]132.853 s1.103 s1.904 × 10−7
Proposed1.146 s0.539 s 1.835 × 10−15
Table 4. Registration results of different angles.
Table 4. Registration results of different angles.
ModelNumber of PointsAlgorithmTime of Coarse RegistrationTime of ICPMSE
Bunny
(0° and 45°)
40,256, 40,097ICP/47.315 s9.332 × 10−6
Algorithm in [27]6.141 s1.261 s1.302 × 10−6
Algorithm in [28]2.900 s0.737 s2.995 × 10−5
Proposed0.991 s0.599 s4.481 × 10−8
Armadillo
(60° and 90°)
23,404, 28,341ICP/19.867 s6.527 × 10−6
Algorithm in [27]11.957 s0.815 s2.230 × 10−6
Algorithm in [28]3.580 s0.519 s4.474 × 10−6
Proposed1.558 s0.427 s6.581 × 10−8
Dragon
(24° and 48°)
34,836, 22,092ICP/27.818 s1.559 × 10−5
Algorithm in [27]3.385 s0.709 s6.722 × 10−6
Algorithm in [28]4.701 s0.531 s2.325 × 10−5
Proposed1.789 s0.348 s9.180 × 10−8
Buddha
(0° and 48°)
78,056, 69,158ICP/224.568 s2.223 × 10−5
Algorithm in [27]9.837 s2.454 s2.159 × 10−5
Algorithm in [28]3.789 s1.511 s2.158 × 10−5
Proposed10.260 s1.137 s7.440 × 10−8
Airpane36,980, 34,117ICP/165.056 s2.235 × 10−4
Algorithm in [27]274.603 s6.119 s6.248 × 10−6
Algorithm in [28]49.362 s2.317 s5.254 × 10−6
Proposed0.910 s0.491 s2.037 × 10−8
Table 5. Comparison of numbers in each processing stage.
Table 5. Comparison of numbers in each processing stage.
Point CloudsNumber of Points
Original PointsFeature PointsInitial Matched PointsFinal Matched Points
Bunny 0° and 45°40,256, 40,0971044, 4873115
Armadillo 60° and 90°23,404, 28,3412324, 27117338
Dragon 24° and 48°34,836, 22,0921441, 12287949
Buddha 0° and 48°78,056, 69,1587436, 5648884375
Airplane36,980, 34,1171162, 8791510
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Wang, B.; Zhou, J.; Huang, Y.; Wang, Y.; Huang, B. Improved Registration Algorithm Based on Double Threshold Feature Extraction and Distance Disparity Matrix. Sensors 2022, 22, 6525. https://doi.org/10.3390/s22176525

AMA Style

Wang B, Zhou J, Huang Y, Wang Y, Huang B. Improved Registration Algorithm Based on Double Threshold Feature Extraction and Distance Disparity Matrix. Sensors. 2022; 22(17):6525. https://doi.org/10.3390/s22176525

Chicago/Turabian Style

Wang, Biao, Jie Zhou, Yan Huang, Yonghong Wang, and Bin Huang. 2022. "Improved Registration Algorithm Based on Double Threshold Feature Extraction and Distance Disparity Matrix" Sensors 22, no. 17: 6525. https://doi.org/10.3390/s22176525

APA Style

Wang, B., Zhou, J., Huang, Y., Wang, Y., & Huang, B. (2022). Improved Registration Algorithm Based on Double Threshold Feature Extraction and Distance Disparity Matrix. Sensors, 22(17), 6525. https://doi.org/10.3390/s22176525

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop