1. Introduction
With the development of sensor technology, in application fields such as space on-orbit service, intelligent robots, automatic driving, UAVs, etc., it is challenging and important to complete object detection and use the captured information to calculate the position and attitude parameters. The pose-measurement methods for noncooperative objects based on the image method [
1,
2] can solve the 3D pose by extracting matching points from 2D images. It has the characteristics of good flexibility and low cost, but it is difficult to maintain the stability of the measurement results under the influence of interference factors such as light changes and a weak texture structure. On the other hand, with the continuous development of noncontact 3D measurement equipment such as LIDAR and laser scanners, point-cloud measurements are becoming more accurate and the amount of data is increasing. How to use the point cloud information obtained by the existing 3D scanning system to design a more robust and accurate pose measurement algorithm has become an important part of high-accuracy pose measurement for noncooperative objects. In the actual pose measurement process, it is usually necessary to register the partial overlapping point cloud data in different states. The relative pose-measurement method based on point clouds mainly includes auxiliary methods applied to cooperative objects and automatic methods applied to noncooperative objects. Auxiliary methods usually use artificial markers [
3], rotating platforms [
4], attitude sensors [
5], and other auxiliary equipment to register the point clouds. However, the auxiliary measurement method has great limitations. Some measuring objects are not allowed to paste marker points, and the measurement efficiency is also greatly affected. The instruments must be calibrated accurately using the rotating platform and the attitude sensor, and extra inaccuracies will be introduced by the auxiliary devices used in the calibration. In noncooperative posture measurement, the automatic technique has gained increasing attention, which has the advantages of requiring no manual prior knowledge and high efficiency, extracting the similar structural features of the point cloud overlapping area, and solving the coordinate transformation matrix.
For the automatic measurement of the relative pose for noncooperative point clouds, Besl et al. [
6] proposed an iterative closest point (ICP) algorithm based on point-to-point registration, which constructs the corresponding relationship through the nearest neighbor search, and then singular value decomposition (SVD) is used to minimize the Euclidean distance between the corresponding pairs to achieve the solution of the relative pose matrix. Chetverikov [
7] improved the construction process of matching point pairs in the traditional ICP algorithm and used the proportion of overlapping regions of adjacent frame point clouds as prior information to filter corresponding pairs to achieve a better registration effect. He [
8] et al. proposed a noncooperative pose-tracking method based on the geometric characteristics of point clouds, which improved the accuracy of matchings according to the density, normal vector, and other characteristics of the point clouds. Chen [
9] et al. recognized the plane features on noncooperative objects and solved the relative pose of the feature points using the ICP algorithm. The plane feature extraction operation improved the accuracy and efficiency of the pose measurement. Zhu [
10] et al. used a combination of local and global constraints to remove outliers in the initial matchings, which improved the accuracy of the matching pairs. Li [
11] et al. proposed a rough registration algorithm based on principal component analysis combined with bounding boxes and FPFH descriptors, which overcame the problem that the ICP algorithm had high requirements for the initial values. Recently, He [
12] et al. proposed a pose-measurement method based on geometric characteristics and used a random-sampling persistence algorithm to eliminate abnormal matching pairs, which improved the robustness of the relative pose measurement.
However, in the actual measurement process, the point cloud obtained by the discrete sampling of the laser scanning system is sparse, and the final matching points of the point-to-point pose measurement algorithm cannot one-by-one correspond to the actual measured surface, which results in the existence of pose-measurement errors. Low [
13] investigated how to reduce the total distances between points and a tangent plane using the ICP approach. The object function included the normal vector, and the normal vector angle and the Euclidean distance were both minimized via least-squares optimization. Generalized ICP [
14] was proposed to take into account the normal vector information. The influence of the sparsity on the discrete point cloud was somewhat reduced by this method, but it was not appropriate for complicated surface structures. On this basis, Jacopo [
15] proposed the Normal ICP method to filter the matching pairs through the similarity of local area curvature, and minimize the distance from the point to the plane and the angle between the normal vector when solving the transformation matrix. Pengyu [
16] used CoBigICP to expand GICP. The geometric information of the local corresponding region was introduced into the optimization function, and the registration effect is better. Although the above methods reduce the influence of point cloud sparsity by constructing an objective function to minimize the distance from the point to the tangent plane, the registration effect for some objects with complex surface morphology is not good. In this regard, the 3D-NDT method proposed by Das [
17] used the probability density function to model the distance between points and realized the soft matching of correspondence. Evangelidis [
18,
19] proposed a point-cloud pose-measurement method based on the Gaussian mixture model. The target point cloud was represented by the Gaussian mixture model (GMM), and the transformation matrix was solved step by step by the Expectation Maximization (EM) algorithm. Choi [
20] introduced the color information of matching point pairs into the probability cost function and constructed the probability distribution of the corresponding local area for the adjacent point set. However, the measurement equipment was required to provide RGB color information of the point cloud. Liu Tong [
21] built a 3D model by fitting the target point cloud with a B-spline surface and gradually optimized the distance from the point to the 3D model in the registration process to improve the registration accuracy. However, this method required the fitting of closed surfaces and the high integrity of the target point cloud, so it could not be applied to the relative pose measurement for noncooperative objects with large nonoverlapping areas. Huang [
22] proposed a variant ICP method based on an adaptive moving least squares (MLS) surface. MLS surface fitting was carried out in the local area of sparse point clouds, and the distance between points was replaced by the distance from the point to the projection of the MLS surface in the minimization objective function. Moreover, Huang further improved the fitting ability of traditional MLS surfaces to complex surfaces through a heterogeneous Gaussian kernel function and improved the registration accuracy. However, this method could not determine whether the projection area was accurate during the construction of the corresponding pairs, which led to lower accuracy of the final matchings or even the inability to obtain the correct matching pairs, which affected the final relative pose measurement’s accuracy.
In summary, to improve the accuracy of pose measurement, many researchers have conducted much research, but most of them mainly focused on improving the accuracy of the point-to-point pose measurement. There are few studies on nonpoint-to-point high-accuracy pose measurement for sparse point clouds, and there are still some problems in the existing methods, which cannot meet the actual measurement requirements. To overcome the influence of point-cloud sparsity on pose-measurement accuracy, this paper proposes a relative pose-measurement algorithm based on double-constrained intersurface mutual projections. First, the scanning interferometer was used to obtain the high-accuracy point-cloud information for the noncooperative objects, and then the similarity of the feature descriptor in the high-dimensional feature space was used to determine the bidirectional projection areas from the surface to the surface. Then, the position of the projection point was solved iteratively along the direction of the weighted normal vector to obtain the correspondences. Finally, the more accurate matching pairs were selected by the consistency constraints of rigid body transformation, and the relative pose matrix was calculated to achieve high-accuracy measurement of the relative pose for noncooperative objects. The innovation points of this paper are summarized as follows:
- (1)
A heterogeneous moving least squares surface (HMLS) was constructed in the local mutual-projection area of point clouds to generate more accurate matchings, which reduced the impact of point-cloud sparsity on point-cloud pose measurement.
- (2)
The similarity constraints of feature descriptors and the consistency constraints of rigid body transformation were applied to the selection of matching point pairs, and the accuracy of pose measurement for pairwise point clouds was improved;
- (3)
An evaluation method for separating the pose-measurement error from the instrument error was proposed. Based on the Stanford dataset validation experiment, the actual noncooperative pose measurement experiments were further carried out through the self-made 3D swept-frequency interferometer, which reflected the significant advantages of the proposed method.
The main structure of this paper is as follows.
Section 2 first analyzes the problems of the traditional ICP algorithm and describes the details of the relative pose-measurement algorithm based on double-constrained intersurface mutual projections.
Section 3 provides the experimental results and the analytical discussions thereof.
Section 4 concludes the work of this paper.
2. Method
The traditional ICP pose-measurement algorithm defines the target point cloud
as the reference frame, and its pose state is fixed. The source point cloud is defined as
, and its rotation matrix
and translation matrix
relative to the reference frame are the transformation parameters to be solved.
and
are the number of target points and source points, respectively. The corresponding set
is determined according to the Euclidean-distance-nearest principle between points. N is the number of correspondences in the overlapping area, which can be calculated according to the overlap rate. Take the sum of the squares of the point distances as the optimization function:
and represent the rotation matrix and translation matrix of the source point cloud relative to the target point cloud, respectively. The point-to-point registration will seriously affect the accuracy of the relative position and attitude measurement due to the problem of dislocation for point clouds under different scanning angles. In contrast, the surface-to-surface registration method can fit the local shape of dense objects and make full use of the current point cloud structure information to improve registration accuracy. The main steps in proposing the method are as follows.
First, the point cloud of the noncooperative object was obtained by a 3D swept frequency interferometer. Then, after calculating the feature descriptor and normal vector of the point cloud, the multiscale feature descriptor was used to construct the initial corresponding set, and the mutual-projection area was determined according to the corresponding relationships. Local surface fitting was carried out for the point clouds, and the original points were mutually projected to establish a new corresponding set. Finally, the rigid-transformation consistent-distance constraint was used to filter the sets to obtain the final matchings and solve the coordinate-transformation matrix.
2.1. Principle of Point-Cloud Measurement for Noncooperative Objects
The measurement principle of the point cloud for noncooperative object is shown in
Figure 1. The infrared laser emitted by the swept-frequency-interferometry ranging module was incident on the reflector. With the point of incidence as the origin, the coordinate system of the measurement system was established. We set the distance from the origin to the measured target as
. The scanning angles of the 2D turntable were the azimuth
and pitch
. In the scanning process, the 2D turntable read the values of the azimuth and pitch angles in real time and recorded the distance from the origin to the measured point measured by the swept-frequency-interferometry ranging module. Finally, Equation (2) was used to convert the 3D point cloud of the object from the polar coordinate system to the Cartesian coordinate system. After the current viewing angle scanning was completed, the target cloud
and the source cloud
were obtained with the changing pose of the measured objects.
and
were the number of points of the target point cloud and source point cloud, respectively.
2.2. Projection from a Point to the MLS Surface
Local surface fitting is an important step in projection tasks. Amenta [
23] set
as the energy function of the MLS surface. A point
outside the surface was projected along the normal vector
of the corresponding local area. We defined the set of projection points that minimized the energy function as the MLS surface.
was set as the k-nearest neighbors of the source point cloud relative to the target point cloud;
Figure 2 shows the constructed MLS surface. The expression of the isosurface
was:
The initial point
moved to the projection point
on the corresponding surface by minimizing the energy function
along the weighted normal vector
of the K-neighborhood point set; the scalar
represented the single approximation step size. When
was zero, the energy function
reached the minimum value. Then, the weighted normal vector
was introduced to transform the energy function into a function with a single-variable parameter. After that, Brent’s [
24] algorithm was used to solve for the value of
in the nonlinear minimization function
. Finally, the position of the projection point
was updated. When the difference between two adjacent projection points was less than the threshold
, the iteration was terminated. For some objects with smooth surfaces, we usually set parameter
to
.
The first term of the summation equation in the energy function represented the normal distance between the current iteration point
and the nearest neighbor point
, and
represented the weighting function.
was the projection direction represented by the weighted normal vectors (3) of K adjacent points in the local surface region during each iteration.
The Gaussian kernel function
in the above MLS surface projection process has two different expressions. The Gaussian kernel function used in the traditional MLS surface is isotropic and can only describe the local surface with a single feature. However, the surface topography of real objects has anisotropic characteristics. When the flatness and steepness of the local point cloud in different directions are different, the traditional MLS surface projection results will have a large deviation. Therefore, the principal curvature parameters
and
in two orthogonal directions were introduced to construct the heterogeneous Gaussian kernel function. The heterogeneous Gaussian kernel function was defined as Equation (6), and the function widths could be expressed as
and
.
was a scale factor that could indirectly control the width of the kernel function and affect the projection accuracy. The next section will discuss the influence of this parameter through experiments.
and
were the principal directions of curvatures
k1 and
k2, respectively.
2.3. Local Feature Similarity Constraint
The above point-to-HMLS surface projection steps could generate new corresponding points on the local surface, but there was no corresponding determination mechanism to constrain the construction of the corresponding projection area. Inaccurate projection areas are prone to lead to inaccurate location information of projection points. Therefore, the feature similarity constraint was used to construct the intersurface mutual-projection regions. First, the multiscale feature descriptors
and
of the target point cloud
and source point cloud
were calculated as in reference [
25]. This feature descriptor first determined the neighborhood point sets under different scale radii and then performed a principal component analysis on the point sets. The eigenvalues of different neighborhood point sets after the principal component analysis were normalized to obtain feature descriptors with a high robustness, high scale invariance, and high rotation invariance.
As shown in
Figure 3, in the overlapping region of the target cloud and the source cloud, the MLS surfaces
and
were used to fit the local neighborhood.
represented a point in the source cloud, and the KD-tree algorithm was used to build the nearest-neighbor index of the target cloud to obtain the initial correspondence
, as shown in the matching point pairs connected by the dotted lines in the figure. Then, the local projection area of
relative to the target cloud was fitted by
.
However, the projection region correspondence constructed by the single Euclidean distance nearest condition was not reliable. Therefore, according to the local feature similarity constraint, the correct corresponding point
of
was supposed to be in the neighborhood
. We set the neighborhood point set of the projection area corresponding to point
as
and the corresponding feature descriptor as
. Then
represented the feature descriptor set of the neighborhood points. The neighborhood point
that was nearest to the Euclidean distance of
in the feature space was taken as the new corresponding point of
to build a new correspondence
, as shown by the solid line in
Figure 3. To reduce the influence of outliers and noise points caused by measurement errors on the relative pose measurement, threshold
was set to filter the minimum Euclidean distance in the feature space, as shown in Equation (6). When the minimum value was less than
, the relationship was considered a correct matching, and bidirectional projection areas
and
were obtained. Otherwise, the corresponding points were removed from the initial set. The selection of threshold
should not only filter outliers and noise points, but also should ensure the number of final matching pairs. The threshold
should be selected within the appropriate range. According to [
25] and the previous test, we set
to 0.01.
2.4. Distance Constraint of an Intersurface Mutual Projection
The accuracy of matching pairs seriously affects the final relative pose-measurement results. Therefore, after the mutual projection of points to local surfaces, it was necessary to further use the rigid-transformation-consistency distance constraint to further filter the constructed intersurface mutual-projection point pairs.
As shown in
Figure 4, the corresponding point pair
was obtained by the similarity constraints of the feature descriptors in the target cloud
and the source cloud
. Then, the normal vector information and Equation (2) were used to project the two points to the corresponding regions
and
, respectively, and obtain two pairs of new corresponding points
and
. If the relationships
and
were correct, they should have satisfied the constraint of rigid-transformation consistency
. In the actual pose-measurement process, the condition that the distance of corresponding point pairs be completely equal was too strict. Therefore, the constraint condition was changed as follows:
If the relative difference of the matching was less than the threshold
, the relationships were regarded as the correct correspondences and added to the final matching point set. Otherwise, the corresponding relation was ignored. We set
to 0.005 according to the same principle as
in
Section 2.3.
2.5. Relative Pose Measurement Based on Double-Constrained Intersurface Mutual Projections
To improve the accuracy of the relative-pose-measurement algorithm for noncooperative objects, the specific steps of the surface-to-surface registration algorithm based on double constrained intersurface mutual projections were as follows:
1. The swept-frequency interferometer was used to measure the noncooperative object, and the point cloud information was obtained according to Equation (2);
2. We preprocessed the input target cloud
and source cloud
. According to [
25], we calculated the multiscale feature descriptors
and
, principal curvatures
and
, and normal vectors
and
;
3. The point number in the overlapping area was determined according to the overlap rate parameter of the adjacent frames. The initial set of corresponding points was constructed by the k-nearest neighbor search. Point in the source point cloud corresponded to the neighborhood point set of the target point cloud. According to the similarity of the feature descriptor and Equation (7), the corresponding pair set under the similarity constraint of the feature descriptor was obtained. Thus, the bidirectional projection regions and were constructed.
4. We used Equation (3) to realize the mutual projection between each point and the corresponding area. In the projection process, the heterogeneous Gaussian kernel (6) was used to approach the step size step by step. Then, we constructed new corresponding sets and ;
5. We filtered the corresponding set with the rigid-transformation-consistent constraint (8) and added the correspondences and that satisfied the distance constraint to the final matching sets and ;
6. We solved the coordinate-transformation matrix and based on Equation (1) and updated the source point cloud iteratively until the convergence condition was satisfied.
The above algorithm looped through steps 2 to 5 until the difference in the transformation matrix was sufficiently small. When the number of iterations exceeded the maximum number , the pairwise registration process would end. could prevent the algorithm from a failure to converge caused by a slight fluctuation in the registration results of the adjacent frames. The implementation details of the algorithm are shown in Algorithm 1.
Algorithm 1: Relative pose measurement based on double-constrained projection |
Input: Source point cloud Q and target point cloud P measured by the swept frequency interferometer Output: Transformation R and t that aligns P and Q 1 Initial pose , and maximum number of iterations L; 2 Compute ,,,,,; 3 Initial q = 0; 4 While , are not converged or l < L do 5 Initial set of corresponding points by kd-tree; 6 for i = 1:N do 7 if 8 Build bidirectional projection region: and ; 9 end 10 Point to HMLS surface projection: and ; 11 if 12 Preserve the current corresponding point and ; 13 else 14 Delete the current corresponding point; 15 end 16 end 17 Compute , through the final set of points and ; 18 Update the source point cloud: 19 l = l + 1; 20 end 21 return , ; |