The present disclosure relates to the technical field of image processing, and more particularly, to a plane-geometry consistency detection method, a computer device, and a storage medium.
Planes are the main feature used in artificial image scenes and have been widely used in many measuring and mapping methods. 3D mapping technology provides detailed and accurate information about the scene, and can be used for simultaneous localization and mapping (SLAM), augmented reality, video stabilization, 3D reconstruction and other fields because it can be applied to inexpensive sensors. It is becoming more popular and used by people day by day.
However, when considering its accuracy, speed, and robustness, the registration of the plane remains challenging. Many plane registration methods take a lot of time to retrieve the relative geometric constraints between frames by using various features, such as points, edges, planes, etc. Therefore, this kind of method needs to select the key frame structure to achieve a real-time performance.
In addition, some algorithms use projection-related methods, such as NDT (Normal Distribution Transform) or ICP (Itera. Closest Point), etc., which need good initial prediction and derive local optimal solutions.
Therefore, these methods are highly dependent on initialization to retrieve good geometric constraints.
In view of the above-mentioned drawbacks of the prior art, the purpose of the present disclosure is to provide a plane-geometry consistency detecting method, a computer device, and a storage medium to solve the problems in the prior art.
In order to achieve the above-mentioned goal and other related goals, the present invention provides a plane-geometry consistency detection method, wherein each plane is uniquely represented in a coordinate system by a normal vector thereof and a distance between an origin of the coordinate system where the plane is located and the plane; the method is used to obtain a consistent conversion relationship from converting a first plane set composed of first planes in a first coordinate system to a second plane set composed of second planes in a second coordinate system, the conversion relationship is represented by a target rotation matrix and a target translation matrix; the method comprises: obtaining a first normal vector set and a first distance set respectively composed of first normal vectors and first distances used for representing the first planes, and a second normal vector set and a second distance set respectively composed of second normal vectors and second distances used for representing the second planes; obtaining the target rotation matrix, comprising: obtaining pairs of the first normal vectors in the first normal vector set and a pair of the second normal vectors of the second normal vector set whose angle matches an angle of the pair of the first normal vectors, computing a first rotation matrix converting each pair of the first normal vector set to a pair of the second normal vectors whose angle matches, and obtaining a first projection matrix of each first rotation matrix in a special orthogonal group SO(3) space; converting each obtained first projection matrix to a rotation vector by inverse transform of Rodriguez's rotation formula to obtain a rotation vector set; clustering each element in the rotation vector set to obtain a first target classification with most elements, respectively putting a pair of the first normal vectors and a pair of the second normal vectors as a computing basis of each element, which is the rotation vector, of the first target classification in a first normal vector sequence and a second normal vector sequence; and computing a second rotation matrix of converting the first normal vector sequence to the second normal vector sequence, and obtaining a second projection matrix of each second rotation matrix in the special orthogonal group SO(3) space as the target rotation matrix; obtaining the target translation matrix, comprising: subtracting each second distance in the second distance set from each first distance in the first distance set to obtain each distance difference and form a distance difference set; clustering each element in the distance difference set to obtain a second target classification with most elements; and combining second normal vectors that belong to a same plane with each second distances as a computing basis of each distance difference to obtain the target translation matrix according to the first distance and the second distance that are a computing basis of each element, which is the distance difference, in the second target classification.
In one embodiment, the first rotation matrix is obtained from a mapping relationship between a pair of first normal vectors together with another first normal vector perpendicular to them and a pair of second normal vectors, whose angle matches, together with another second normal vector perpendicular to them.
In one embodiment, the first normal vectors of each pair are not parallel; the first normal vector of each parallel first plane and the second normal vector of each parallel second plane are set to the same.
In one embodiment, an angle matching means that a difference between an angle between a pair of first normal vectors and an angle between a pair of second normal vectors is within a predetermined range.
In one embodiment, the clustering method comprises: inserting each element of the first target classification or the second target classification into a hash table, and establishing its corresponding index according to each element; or
In one embodiment, the index of each element is established according to contained data and a maximum reachable value thereof.
In one embodiment, the rotation matrix represents a vector extending along a direction of a rotation axis vector and having a length representing a rotation angle thereof; a method of establishing a first hash table for inserting the rotation vectors comprises: dividing a three-dimensional angle space into a plurality of cube-shaped cells of size ϵ3, ϵ∈(0,2π); and establishing a three-dimensional hash table of size N3 as the first hash table,
and computing the index
to insert the rotation vectors of the rotation vector set into the cells, wherein r is the rotation vector.
In one embodiment, a method of establishing a second hash table for inserting the distance differences comprises: dividing a three-dimensional space into a plurality of cube-shaped cells of size thd3, thd∈(0,maxD); establishing a three-dimensional hash table of size N3 as the second hash table,
and computing the index
to insert the distance differences of the distance difference set into the second hash table, wherein d is the distance difference, maxD is a maximum distance, and thd is a cell size threshold.
In one embodiment, the first/second projection matrix is obtained by performing a singular value decomposition on the first/second rotation matrix to obtain two orthogonal matrixes.
In one embodiment, the method further comprises: computing a score of the obtained the plurality of target rotation matrixes, wherein the score relates to an amount of non-parallel plane groups for computing the target rotation matrixes and an amount of parallel planes constituting each plane group; wherein the target rotation matrix with a best score is the rotation matrix meeting the maximum geometric consistency of converting the first plane set to the second plane set.
In order to achieve the above-mentioned goal and other related goals, the present invention provides a computer device comprising: a processing unit and a storage unit; the storage unit for storing a computer program; and the processing unit for running the computer program to implement a plane-geometry consistency detection method; wherein each plane is uniquely represented in a coordinate system by a normal vector thereof and a distance between an origin of the coordinate system where the plane is located and the plane; the method is used to obtain a consistent conversion relationship from converting a first plane set composed of first planes in a first coordinate system to a second plane set composed of second planes in a second coordinate system, the conversion relationship is represented by a target rotation matrix and a target translation matrix; the plane-geometry consistency detection method comprising: obtaining a first normal vector set and a first distance set respectively composed of first normal vectors and first distances used for representing the first planes, and a second normal vector set and a second distance set respectively composed of second normal vectors and second distances used for representing the second planes; obtaining the target rotation matrix, comprising: obtaining pairs of the first normal vectors in the first normal vector set and a pair of the second normal vectors of the second normal vector set whose angle matches an angle of the pair of the first normal vectors, computing a first rotation matrix converting each pair of the first normal vector set to a pair of the second normal vectors whose angle matches, and obtaining a first projection matrix of each first rotation matrix in a special orthogonal group SO(3) space; converting each obtained first projection matrix to a rotation vector by inverse transform of Rodriguez's rotation formula to obtain a rotation vector set; clustering each element in the rotation vector set to obtain a first target classification with a most elements, respectively putting a pair of the first normal vectors and a pair of the second normal vectors as a computing basis of each element, which is the rotation vector, of the first target classification in a first normal vector sequence and a second normal vector sequence; and computing a second rotation matrix of converting the first normal vector sequence to the second normal vector sequence, and obtaining a second projection matrix of each second rotation matrix in the special orthogonal group SO(3) space as the target rotation matrix; obtaining the target translation matrix, comprising: subtracting each second distance in the second distance set from each first distance in the first distance set to obtain each distance difference and form a distance difference set; clustering each element in the distance difference set to obtain a second target classification with most elements; and combining second normal vectors that belong to a plane same with each second distances as a computing basis of each distance difference to obtain the target translation matrix according to the first distance and the second distance that are a computing basis of each element, which is the distance difference, in the second target classification.
In one embodiment, the first rotation matrix is obtained from a mapping relationship between a pair of first normal vectors together with another first normal vector perpendicular to them and a pair of second normal vectors, whose angle matches, together with another second normal vector perpendicular to them.
In one embodiment, the first normal vectors of each pair are not parallel; the first normal vector of each parallel first plane and the second normal vector of each parallel second plane are set to the same.
In one embodiment, an angle matching means that a difference between an angle between a pair of first normal vectors and an angle between a pair of second normal vectors is within a predetermined range.
In one embodiment, the clustering comprises: inserting each element of the first target classification or the second target classification into a hash table, and establishing its corresponding index according to each element.
In one embodiment, the index of each element is established according to contained data and a maximum reachable value thereof.
In one embodiment, the rotation matrix represents a vector extending along a direction of a rotation axis vector and having a length representing a rotation angle thereof; a method of establishing a first hash table for inserting the rotation vectors comprises: dividing a three-dimensional angle space into a plurality of cube-shaped cells of size ϵ3, ϵ∈(0,2π); and establishing a three-dimensional hash table of size N3 as the first hash table,
and computing the index
to insert the rotation vectors of the rotation vector set into the cells, wherein r is the rotation vector.
In one embodiment, a method of establishing a second hash table for inserting the distance differences comprises: dividing a three-dimensional space into a plurality of cube-shaped cells of size thd3, thd∈(0,maxD); establishing a three-dimensional hash table of size N3 as the second hash table,
and computing the index
to insert the distance differences of the distance difference set into the second hash table, wherein d is the distance difference, maxD is a maximum distance, and thd is a cell size threshold.
In one embodiment, the first/second projection matrix is obtained by performing a singular value decomposition on the first/second rotation matrix to obtain two orthogonal matrixes.
In one embodiment, the method further comprises: computing a score of the obtained the plurality of target rotation matrixes, wherein the score relates to an amount of non-parallel plane groups for computing the target rotation matrixes and an amount of parallel planes constituting each plane group; wherein the target rotation matrix with a best score is the rotation matrix meeting the maximum geometric consistency of converting the first plane set to the second plane set.
In order to achieve the above-mentioned goal and other related goals, the present disclosure provides a computer-readable storage medium storing a computer program, performing the method when the computer program is ran by a processor.
As mentioned above, the plane-geometry consistency detection method, the computer device, and the storage medium of the present disclosure are achieved by obtaining a first normal vector set, a first distance set, a second normal vector set, and a second distance set; obtaining a target rotation matrix, comprising: obtaining pairs of the first normal vectors in the first normal vector set and a pair of the second normal vectors of the second normal vector set whose angle matches an angle of the pair of the first normal vectors, computing a first rotation matrix and a first projection matrix thereof; converting the obtained first projection matrix to a rotation vector to obtain a rotation vector set; clustering each element in the rotation vector set to obtain a first target classification with most elements to obtain a first normal vector sequence and a second normal vector sequence; computing a second rotation matrix of converting the first normal vector sequence to the second normal vector sequence, and using a second projection matrix thereof as the target rotation matrix; furthermore, obtaining a distance difference set from the first distance set and the second distance set, clustering to obtain a second target classification, and using the first distance and the second distance of the element thereof and the corresponding second normal vector to obtain the target translation matrix. The solution of the present disclosure achieves a high-consistency and fast plane mapping in different coordinate systems.
These and other objectives of the present invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
The following specific embodiments illustrate the implementation of the present disclosure, and a person skilled in the art may readily understand other advantages and effects of the present disclosure from the content disclosed in the specification. The present disclosure may also be implemented or applied by other different specific implementations, and details in the specification may also be modified or changed based on different viewpoints and applications without departing from the spirit of the present disclosure. It should be noted that the embodiments of the present disclosure and the features of the embodiments may be combined with each other if there is no conflict.
Suppose that the first plane set in the first coordinate system FA is expressed as {PiA}, wherein the contained plane can be uniquely represented by a normal vector niA thereof and a distance between an origin of the first coordinate system and the plane diA, such that a point pA located on PiA satisfies:
n
i
A
·p
A
=d
i
A
and ∥niA∥2=1,diA≥0(1).
The conversion relationship of rigid body motion between FA and FB satisfies fBA=(RBA,TBA), where RBA is a rotation matrix converting FA to FB, TBA is a translation matrix; correspondingly, the plane parameters of the physical plane observed in FA and FB satisfy:
n
j
B
=R
BA
·n
i
A (2)
(njB)T·TBA=djB−diA (3).
Wherein the derivation process of Eq. (3) is:
Similarly, each plane PjB in FB can be uniquely represented by (njB, djB) satisfying the above equations.
Therefore, corresponding to the two plane sets {PiA} and {PjB}, the problem of establishing a maximum geometry consistency conversion relationship between them can be transformed into the following constraint optimization problem:
(RBA,TBA)=argmax(R
Then, find out the rigid body mapping relationship fBA to maximize the cardinality of the sets R
R
,T
{(PiA,PjB)|fBA(PiA)=PjB} (5)
The method comprises:
Step S101: obtaining a first normal vector set and a first distance set respectively composed of first normal vectors and first distances used for representing the first planes, and a second normal vector set and a second distance set respectively composed of second normal vectors and second distances used for representing the second planes.
Following the above, suppose that the first plane is expressed as PiA, the corresponding first plane set is expressed as {PiA}; the second plane is expressed as PjB, the corresponding second plane set is expressed as {PjB}; the first normal vector is expressed as niA, and the second normal vector is expressed as njB.
Step S102: obtaining the target rotation matrix RBA.
In one embodiment, using the characteristics of rigid body motion, i.e. maintaining the norm and intersection of vectors, to compute the rotation matrix between plane sets in two coordinate systems is applied. In other words, by generating a rotation proposal from the angle between the planes, we can extract the maximum rotation consistency from it. In this regard, creating a rotation proposal first, ignoring the impossible rotation proposal and adopting a measurement mechanism based on voting (e.g. clustering) as described below to effectively measure the consistency.
Correspondingly, step S102 may specifically comprise:
Step S121: obtaining pairs of the first normal vectors in the first normal vector set and a pair of the second normal vectors of the second normal vector set whose angle matches an angle of the pair of the first normal vectors.
In one embodiment, assuming that the first plane set {PiA} of size NA is given, according to the angle between the pair of the first normal vectors, there are CN
Computed as:
Therefore, according to the computation of each angle to form a first angle group PGA corresponding to the first plane set:
From Eq. (8), it can be seen that ni and nj are the normal vectors of different planes in FA.
Similarly, assuming that θp,q is the angle between the second normal vector np of a plane and the second normal vector nq of the other plane of the second plane set {PiB}, then we can get CN
Step S122: computing a first rotation matrix converting each pair of the first normal vector set to a pair of the second normal vectors whose angle matches, and obtaining a first projection matrix of each first rotation matrix in a special orthogonal group SO(3) space.
Specifically, the angle matching relationship between the paired angle groups PGA and PGB in the two plane sets is used to find out the mapping relationship between the plane sets. That is, between the angle θi,j of PGA and the angle θp,q of PGB, the minimum solution using two sets of normal to generate rotation proposal is:
Wherein nk is a vector constructed according to ni and n1 and perpendicular to them, nr is a vector constructed according to np and nq and perpendicular to them; the reason of the construction is that the rotation matrix is a 3×3 matrix, and each normal vector is a 3×1 vector, and after having ni and nj, np and nq, still need to obtain a position-related vector (which may be a normal vector) of each corresponding coordinate system to create a 3×3 matrix. The method of obtaining the vertical vector of each pair of normal vector in this embodiment belongs to a minimal algebraic solution of RBA with a smaller amount of computation.
In addition, in this embodiment, because RBA is an orthonormal matrix falling in a Lie group SO(3), but R*BA may not fall in SO(3). Hence, this embodiment uses an SVD method to project R*BA into SO(3) to obtain RBA. Since U and V must be orthogonal matrixes after SVD decomposition, RBA is also an orthogonal matrix.
The RBA obtained here is just a preliminary result. The computation method thereof may optimize the computation amount and further optimize the consistency.
Specifically, let N=max{NA,NB}. There are CN
Due to the characteristics of rigid body motion, an angle between the two planes is maintained in FA and FB. Therefore, it is not necessary to traverse all the elements of the two angle groups. In addition, the parallel planes are ignored because they have similar normal vectors having no contribution to rotation proposal set. For example, the selected pair of first normal vectors is not parallel, and the corresponding pair of the second normal vectors, whose angle matches, will not be parallel; and multiple parallel first normal vectors or multiple parallel second normal vectors may be regarded as the same when participating in the computation of the rotation proposal.
Selectively, a threshold thθ>0 is introduced as an acceptable angle noise threshold to establish a criterion for the matching angle, such that, for θi,j∈PGA, θp,q in PGB whose angle values are in the range of (θi,j−thθ,θi,j+thθ) are regarded as θi,j. Therefore, by search algorithms, such as binary search, the search time for possible matches of θi,j will be reduced to O(log N2); furthermore, in the worst case whose corresponding time complexity is O(N4), for example, the most planes are perpendicular to each other, the total time complexity of finding out all pairs whose angle matches in PGA and PGB will be reduced to O(N2 log N) in average.
Then, the matching set M is defined as the following equations (14)-(15):
{(ij,pq,R)|abs(θp,q−θi,j)<thθ} (14)
θi,j∈PGA,θp,q∈PGB (15)
For further consistency optimization, see the following steps:
Step S123: converting each obtained first projection matrix to a rotation vector by inverse transform of Rodriguez's rotation formula to obtain a rotation vector set.
Step S124: clustering each element in the rotation vector set to obtain a first target classification with most elements, respectively putting a pair of the first normal vectors and a pair of the second normal vectors as a computing basis of each element, which is the rotation vector, of the first target classification in a first normal vector sequence and a second normal vector sequence.
Step S125: computing a second rotation matrix of converting the first normal vector sequence to the second normal vector sequence, and obtaining a second projection matrix of each second rotation matrix in the special orthogonal group SO(3) space as the target rotation matrix.
For example, in order to reduce the search space, according to the inverse transform of Rodriguez's rotation formula, R is transformed into a three-dimensional rotation vector with the rotation axis (vector) as the direction and the angle as the length to obtain a more compact representation of R by the axis and the angle.
The rotation matrix R in SO(3) should satisfy RTR=RRT=I (where I is an identity matrix) and det(R)=1, which is the characteristic of the orthogonal matrix, and the rotation matrix r can be computed as follows:
Wherein, as the vector representation of the rotation axis, A may be derived according to Rodriguez's formula, r11+r22+r33 is the component on the diagonal of the rotation matrix; due to cos θ=(r11+r22+r33−1)/2, C is cos θ; and the modulus of ρ is sin θ, so s=sin θ.
If s=0 and c=1, then r=0; if s=0 and c=−1, then let v be equal to a non-zero column of R+I.
Then, get
In this embodiment, the S function is also involved to flip the coordinate symbol of r to ensure the uniqueness;
More generally, if s≠0, then get:
Therefore, transforming the matching set M to be related to r:
{(ij,pq,r)|abs(θp,q−θi,j)<thθ} (21)
which is the rotation vector set.
Now, we still need to find out the most consistent rotation matrix, and the principle of clustering can be used; accordingly, there are many effective methods to extract the maximum consistency, such as using a hash table or performing a binary search to cluster each rotation vector to extract a classification with most elements, which is a rotation vector, to reconstruct the target rotation matrix.
In one embodiment, a hash table may be used to solve this problem.
In order to perform a clustering analysis on the rotation vector, a three-dimensional angle space is divided into a plurality of cube-shaped cells of size ϵ3 to store rotation vector of M, where ϵ∈(0,2π). Therefore, a first hash table of size N3 is generated, where N is given by the amount of cells in each rotation axis.
Establish a three-dimensional hash table of size N3 as the first hash table, where:
and compute the index:
to insert each rotation vector of rotation vector set into each cell; where r is the rotation vector.
After the hash table is obtained, the cell Cr with largest amount of elements nc, which is the first target classification, according to Eq. (2) to get the best rotation proposal between {PiA} and {PjB} as the target rotation matrix.
Specifically, according to Cr, VA and VB with size 3×nc are obtained. Specifically, since each normal vector is a 3×1 vector, then VA and VB in Eq. (24) and (25) are both 3*nc matrixes. Therefore, in Eq. (26), Eq. (27) and (28) whose principle is similar to Eq. (12) and (13) are used to obtain the target rotation matrix RBA:
V
A=[n1An2A . . . nn
V
B=[n1Bn2B . . . nn
R
BA=(VB*VAT)*(VA*VAT)−1 (26)
[USV]=SVD(R*BA) (27)
R
BA=[U·V′] (28)
Step S103: obtaining the translation matrix TBA.
Specifically, for each rigid object, in rigid body motion, the distance between any two points thereof will not change with time. By comparing two plane set's difference set {diA} and {djB}, we can observe that there is a certain difference in the distance that satisfies most plane relations. Therefore, obtaining the translation matrix TBA between FA and FB in step S103 can be derived from the following process described in detail:
Step S131: subtracting each second distance in the second distance set from each first distance in the first distance set to obtain each distance difference and form a distance difference set.
Step S132: clustering each element in the distance difference set to obtain a second target classification with most elements.
Step S133: combining second normal vectors that belong to a same plane with each second distances as a computing basis of each distance difference to obtain the target translation matrix according to the first distance and the second distance that are a computing basis of each element, which is the distance difference, in the second target classification.
For example, the distance set is defined as {di,j}; suppose that the first distance is expressed as diA, the second distance is expressed as djB, then the elements in , which is the distance difference, is expressed as:
d
ij
=d
i
A
−d
j
B (29)
Similar to the above embodiment, each distance difference of the distance difference set may be inserted into a second hash table.
Specifically, inserting all the elements, which are distance differences, in into the second hash table according to the computed index; the computation method of the index comprises:
wherein, maxD and thd respectively represent the defined maximum distance and the size threshold of the cell storing the element. Finally, selecting the cell Cd with most elements, which is the second target classification, to compute the translation matrix TBA.
Furthermore, extracting at least 3 elements {di1,j1, di2,j2, . . . , dim,jm} from Cd, and according to Eq. (3), obtaining:
and transformed into:
Since dim,jm is detectable and known, and the second normal vector corresponding to the same plane as dj
Based on the above-mentioned second hash table with
cells and O(N2) translation proposal, the time complexity of obtaining process of the translation matrix is O(N2).
In addition, as described in the abovementioned embodiment, for planes that are parallel to each other, because their normal vectors are parallel, the planes that are parallel to each other (for example, each parallel first plane, each parallel second plane) are regarded as one plane group. Then, when computing the rotation proposal, each plane group is equivalent to only participating in the computation once, which can reduce the amount of the computation.
However, after the hash table clustering analysis, each target rotation matrix will be voted to compute a score, and the target rotation matrix with the highest score is selected as the rotation matrix with the best consistency; the score is defined as the amount of all planes used to compute the corresponding target rotation matrix, and all planes include all the first planes PiA of the first plane set {PiA} in FA and all the second plane PjB of the second plane set {PjB} in FB.
Since the parallel planes are ignored when computing the first rotation matrix, the ignored parallel planes should be added back when computing the score.
For example, suppose that the target rotation matrix Ri is computed based on m plane groups that are not parallel to each other, wherein each plane group has rj parallel planes, wherein each plane group may be composed of a group of parallel PiA or a group of parallel PjB; the score of Ri relates to m and rj.
In one embodiment, the score computation method of Ri may be: Σj=1mrj
Suppose:
Since each plane group is composed of n planes, according to the content obtained by the translation matrix TBA, O(n2) is required to find out the matching plane. Therefore, the total time to compute the score of the rotation matrix Ri is:
Σj=1mrj2≤(Σj=1mrj)2≤N2 (33)
Therefore, it takes time of O(k*N2) in total to compute all the scores of the best k rotations
Then, the rotation matrix with the best score represents the maximum geometry consistency.
The computer device 200 comprises: a storage unit 201 and a processing unit 202.
The storage unit is utilized for storing a computer program; and
The processing unit is utilized for running the computer program to implement, for example, the plane-geometry consistency detection method in the embodiment of
obtaining a first normal vector set and a first distance set respectively composed of first normal vectors and first distances used for representing the first planes, and a second normal vector set and a second distance set respectively composed of second normal vectors and second distances used for representing the second planes; obtaining the target rotation matrix, comprising: obtaining pairs of the first normal vectors in the first normal vector set and a pair of the second normal vectors of the second normal vector set whose angle matches an angle of the pair of the first normal vectors, computing a first rotation matrix converting each pair of the first normal vector set to a pair of the second normal vectors whose angle matches, and obtaining a first projection matrix of each first rotation matrix in a special orthogonal group SO(3) space; converting each obtained first projection matrix to a rotation vector by inverse transform of Rodriguez's rotation formula to obtain a rotation vector set; clustering each element in the rotation vector set to obtain a first target classification with a most elements, respectively putting a pair of the first normal vectors and a pair of the second normal vectors as a computing basis of each element, which is the rotation vector, of the first target classification in a first normal vector sequence and a second normal vector sequence; and computing a second rotation matrix of converting the first normal vector sequence to the second normal vector sequence, and obtaining a second projection matrix of each second rotation matrix in the special orthogonal group SO(3) space as the target rotation matrix; obtaining the target translation matrix, comprising: subtracting each second distance in the second distance set from each first distance in the first distance set to obtain each distance difference and form a distance difference set; clustering each element in the distance difference set to obtain a second target classification with most elements; and combining second normal vectors that belong to a same plane with each second distances as a computing basis of each distance difference to obtain the target translation matrix according to the first distance and the second distance that are a computing basis of each element, which is the distance difference, in the second target classification.
In one embodiment, the first normal vectors of each pair are not parallel; the first normal vector of each parallel first plane and the second normal vector of each parallel second plane are set to the same.
In one embodiment, an angle matching means that a difference between an angle between a pair of first normal vectors and an angle between a pair of second normal vectors is within a predetermined range.
In one embodiment, the clustering comprises: inserting each element of the first target classification or the second target classification into a hash table, and establishing its corresponding index according to each element.
In one embodiment, the index of each element is established according to contained data and a maximum reachable value thereof.
In one embodiment, the rotation matrix represents a vector extending along a direction of a rotation axis vector and having a length representing a rotation angle thereof; a method of establishing a first hash table for inserting the rotation vectors comprises: dividing a three-dimensional angle space into a plurality of cube-shaped cells of size ϵ3, ϵ∈(0,2π); and establishing a three-dimensional hash table of size N3 as the first hash table,
and computing the index
to insert the rotation vectors of the rotation vector set into the cells, wherein r is the rotation vector.
In one embodiment, a method of establishing a second hash table for inserting the distance differences comprises: dividing a three-dimensional space into a plurality of cube-shaped cells of size thd, thd∈(0,maxD); establishing a three-dimensional hash table of size N3 as the second hash table,
and computing the index
to insert the distance differences of the distance difference set into the second hash table, wherein d is the distance difference, maxD is a maximum distance, and thd is a cell size threshold.
In one embodiment, the first/second projection matrix is obtained by performing a singular value decomposition on the first/second rotation matrix to obtain two orthogonal matrixes. “/” means and/or, that is, the first projection matrix is obtained by performing a singular value decomposition on the first rotation matrix to obtain two orthogonal matrix and/or the second projection matrix is obtained by performing a singular value decomposition on the second rotation matrix.
In one embodiment, the method further comprises: computing a score of the obtained the plurality of target rotation matrixes, wherein the score relates to an amount of non-parallel plane groups for computing the target rotation matrixes and an amount of parallel planes constituting each plane group; wherein the target rotation matrix with a best score is the rotation matrix meeting the maximum geometric consistency of converting the first plane set to the second plane set.
In some embodiments, the storage unit 201 may comprise, but not limit to, a high-speed random access memory and a non-volatile memory. For example, one or more disk storage devices, flash memory devices, or other non-volatile solid-state storage devices.
The processing unit 202 may be a general-purpose processing unit comprising a central processing unit (CPU), a network processor (NP), etc.; it may also be a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), or other programmable logic devices, discrete gate or transistor logic device, discrete hardware component.
In addition, various computer programs related to the above-mentioned method embodiment (such as the method embodiment in
For specific implementation, the computer program is a routine, a program, an object, a component, a data structure, etc., that performs a specific task or implements a specific abstract data type.
In conclusion, the plane-geometry consistency detection method, the computer device, and the storage medium of the present disclosure is achieved by obtaining a first normal vector set, a first distance set, a second normal vector set, and a second distance set; obtaining a target rotation matrix, comprising: obtaining pairs of the first normal vectors in the first normal vector set and a pair of the second normal vectors of the second normal vector set whose angle matches an angle of the pair of the first normal vectors, computing a first rotation matrix and a first projection matrix thereof; converting the obtained first projection matrix to a rotation vector to obtain a rotation vector set; clustering each element in the rotation vector set to obtain a first target classification with most elements to obtain a first normal vector sequence and a second normal vector sequence; computing a second rotation matrix of converting the first normal vector sequence to the second normal vector sequence, and using a second projection matrix thereof as the target rotation matrix; furthermore, obtaining a distance difference set from the first distance set and the second distance set, clustering to obtain a second target classification, and using the first distance and the second distance of the element thereof and the corresponding second normal vector to obtain the target translation matrix. The solution of the present disclosure achieves a high-consistency and fast real-time plane mapping in different coordinate systems.
The above-mentioned embodiments only exemplarily illustrate the principles and effects of the present application, and are not used to limit the present disclosure. People skilled in this technology may readily modify or change the above-mentioned embodiments without departing from the spirit and the range of the present disclosure. Therefore, all equivalent modifications or changes made by people skilled in the art without departing from the spirit and the technical ideas disclosed in the present disclosure should be covered by the claims of the present disclosure.
Those skilled in the art will readily observe that numerous modifications and alterations of the device and method may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
201910125336.3 | Feb 2019 | CN | national |
This is a continuation application of International Application No. PCT/CN2019/081424 filed on 4 Apr. 2019.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2019/081424 | Apr 2019 | US |
Child | 17383419 | US |