Three-dimensional (3D) registration may be used to align two or more 3D surfaces with one another. Digital representations of full or partial 3D surfaces may be obtained from a variety of sources such as 3D scans of real-world objects, 3D imaging of real-world objects, or computer-aided design models of objects etc.
Various features of the present disclosure will be apparent from the detailed description which follows, taken in conjunction with the accompanying drawings, which together illustrate, features of certain examples, and wherein:
Certain examples described herein allow a 3D registration procedure to be performed to align a first 3D surface with a second 3D surface. In particular, certain examples make use of an intrinsic surface property of the 3D surfaces, that can enable a more robust and accurate alignment of the first 3D surface with the second 3D surface.
In certain examples, the intrinsic surface property of the 3D surfaces may be a Gaussian curvature. This may provide a more robust alignment of the 3D surfaces by filtering surface duplet pairs that are used to compute a pose estimate. As a result, the surface duplet pairs that have similar Gaussian curvatures are used to compute the pose estimate, thus improving the accuracy of the initial alignment.
In certain examples, the Gaussian curvature of a 3D surface may be pre-computed to decrease the computational resources needed to perform the 3D registration procedure. For example, the Gaussian curvature of the first and/or second 3D surface may be pre-computed. In certain examples, a 3D surface may be discretely triangularized in order to increase the efficiency of computing the Gaussian surface.
Performing a robust 3D registration procedure, whereby two 3D surfaces may be accurately aligned, may involve computing a pose estimate for aligning a 3D surface relative to another 3D surface.
Point clouds can be produced by a 3D scanner to digitally represent the shape and appearance of a real-world object. Furthermore, point clouds may be used to create 3D computer-aided design (CAD) models of said objects. A point cloud may comprise a set of orientated points. An orientated point may comprise the location or position of a point in three dimensions and a corresponding surface normal of the point. Herewith, an orientated point will be referred to as a point.
3D point cloud registration or point set registration is a process whereby two or more, complete or partial, point clouds are accurately aligned. For example, a partial point cloud produced by a 3D scanner may be aligned with a complete CAD model. A 3D registration procedure aligns point clouds, or 3D surfaces, by calculating a transformation between them i.e. a transformation that when applied to one point cloud will align it with another point cloud. The transformation to align the 3D surfaces may be referred to as a pose estimate. In many cases, alignment will not be a perfect alignment of surfaces but rather a best effort alignment between the 3D surfaces, since similar 3D surfaces will rarely align perfectly.
A 3D registration procedure may involve aligning a first 3D surface with a second 3D surface by sampling a first pair of points from the first 3D surface and sampling a second pair of points from the second 3D surface. The first pair of points may be referred to as a first surface duplet. Similarly, the second pair of points may be referred to as a second surface duplet.
Further geometric features of the surface duplet 150 may include:
1) the angle αac 140 between the normal na 145 and the line 135 connecting point a 110 and point c 120;
2) the angle βac 150 between the normal nc 155 and the line 135 connecting point a 110 and point c 120; and
3) the angle δac 160 between the normal na and the normal nc around the line 135 connecting point a 110 and point c 120.
The geometric features of a first surface duplet from a first 3D surface, such as those described above, may be compared with the geometric features of a second surface duplet from a second 3D surface to establish a correspondence or match. Surface duplets with matching geometric features may be used to generate a pose estimate for 3D registration.
In some examples, the surface duplet may be characterized by one or more non-geometric features from a possible set of non-geometric features such as the 2D texture or the color of the surface. Surface duplets may be characterized by a combination of both geometric and non-geometric features.
A pose estimate T may be a homogeneous 4×4 transformation matrix that aligns a first 3D surface with a second 3D surface. The pose estimate or transformation matrix may translate and/or rotate a first 3D surface to align the first 3D surface with the second 3D surface. A robust pose estimate may consistently and accurately align a first 3D surface with a second 3D surface, effectively overlapping or superimposing the two 3D surfaces.
In block 210, a first surface duplet from a first 3D surface is randomly sampled. From the pair of points (a 110 and c 120) that comprise the first surface duplet (a,c), geometric features dac 130, αac 140, βac 150 and δac 160 can be determined. After determination of the geometric features, the first surface duplet (a,c) may be inserted into the relation table R1 of the first surface. The position of the first surface duplet (a,c) in the relation table R1 is determined by a relation table index. The relation table index for the first surface duplet (a,c) is calculated as rel(a,c). The geometric features dac 130, αac 140, βac 150 and δac 160 of the first surface duplet (a,c) are input into Equation (1) to calculate rel(a,c) i.e. the position of the first surface duplet (a,c) in the relation table R1.
In block 220, the first surface duplet (a,c) is inserted into the relation table R1 using the relation table index rel(a,c). Accordingly, an evaluation of R1[rel(a,c)] in the relation table R1 will retrieve the first surface duplet (a,c).
In block 230, the relation table R2 of the second 3D surface is inspected in order to identify a geometrically congruent second duplet from the second surface. Using the relation table index rel(a,c) for the first surface duplet, the same position in the second relation R2 for the second surface is inspected or accessed. Hence, when R2[rel(a,c)] is evaluated, a second surface duplet (b,d) may be found.
In block 240, the existence of the second surface duplet (b,d) in the second relation table R2 at position rel(a,c) is evaluated. If a second surface duplet (b,d) exists in relation table R2, the procedure 200 follows a path to block 245. If a second surface duplet does not exist in the relation table R2 at relation table index rel(a,c), then the procedure follows a path to block 250.
In block 245, a pose estimate T is calculated if a geometrically congruent second duplet (b,d) is found. The pose estimate T may be a homogenous 4×4 transformation that aligns the first surface duplet (a,c) with the second surface duplet (b,d). The pose estimate T may bring the duplets (a,c) and (b,d) in contact through rotation and/or translation of one of the surface duplets with respect to the other.
At block 250, the procedure of blocks 210 to 245 is repeated for the second 3D surface. A second surface duplet from the second 3D surface is randomly sampled. From the pair of points (b and d) that comprise the second surface duplet (b,d), the corresponding geometric features dbd, αbd, βbd and δbd can be determined. After calculation of the geometric features, the second surface duplet (b,d) may be inserted into the relation table R2 of the second surface. The position of the second surface duplet (b,d) in the relation table R2 is determined by the relation table index, rel(b,d).
In block 260, the second surface duplet (b,d) is inserted into the relation table R2 using the relation table index rel(b,d). Accordingly, an evaluation of R2[rel(b,d)] will retrieve the second surface duplet (b,d).
In block 270, the relation table R1 of the first 3D surface is inspected in order to identify a geometrically congruent first duplet from the first surface. Using the relation table index rel(b,d) for the second surface duplet, the same position in the first relation R1 for the first surface is inspected or accessed. Hence, when R1[rel(b,d)] is evaluated, a first surface duplet (a,c) may be found.
In block 280, the existence of the first surface duplet (a,c) in the first relation table R1 at position rel(b,d) is evaluated. If a first surface duplet (a,c) exists, the procedure 200 follows a path to block 285. If a first surface duplet is does not exist in the relation table R1 at relation table index rel(b,d), then the procedure follows a return path to block 210.
In block 285, a new pose estimate T is calculated, bringing the duplets (a,c) and (b,d) in contact. After calculation of the pose estimate T, the procedure 200 follows a return path to block 210. The blocks of the procedure 200 are repeated until the calculated pose estimate T satisfies a certain condition. The condition may be that the pose estimate T satisfies a quality condition, for example the first 3D surface and the second 3D surface are aligned by the pose estimate T within a pre-defined margin of error. Alternatively, the blocks of the procedure 200 may repeat until a pre-defined time limit has been exceeded, a pre-defined number of pose calculations have been made. Once the condition for repetition of the blocks of the procedure 200 is satisfied, the final pose estimate T may be utilized to align the first 3D surface with the second 3D surface, completing the 3D registration procedure. The 3D registration procedure as described in relation to
An intrinsic surface property of a 3D surface is a property which is constant regardless of the chosen co-ordinate system, position of a viewer relative to the surface and the chosen parametrization of the surface. One such intrinsic surface property is a Gaussian curvature of the surface. Another intrinsic surface property of a 3D surface that remains constant may be a texture of the surface. The texture may be the two-dimensional value of the texture or the color of the 3D surface.
The Gaussian curvature of a surface is a geometric property that may be used to understand and describe the curvature of the surface. The Gaussian curvature K of a surface at a point may be formally defined as the product of a principle curvature κ1 and a principle curvature κ2 at said point
K=κ
1κ2.
At a given point on a surface, a normal vector is determined to be a vector which is at right angles to the surface. A normal plane is a plane which contains the normal vector. At the intersection of a normal plane and the surface, a curve may be formed which is called a normal section. The curvature of the normal section is defined as a normal curvature. For a given point on the surface, the maximum value of the normal curvature can be referred to as a principle curvature, κ1. Similarly, the minimum value of the normal curvature at the given point on the surface can be referred to as another principle curvature, κ2. The multiplication of the principle curvatures κ1 and κ2 provide the Gaussian curvature. The Gaussian curvature of a surface may be a positive value, a negative value or have a value of zero.
For a point on any surface, if one of the principle curvatures is zero, the Gaussian curvature of the point on the surface will be zero. As a result, the Gaussian curvature of flat planes and cylinders will be zero everywhere.
For a point on a surface, if both principle curvatures are the same sign e.g. both principle curvatures are positive or both principle curvatures are negative, the resulting Gaussian curvature is positive. In other words, the Gaussian curvature of a point on a surface is positive regardless of whether the point is a so-called hill or valley (peak or trough).
For a point on a surface whereby the principle curvatures have different signs, the Gaussian curvature for said point will be negative. As a result, the Gaussian curvatures for hyperboloids or saddle points are negative.
In some examples, in order to efficiently compute the approximate Gaussian curvature of points on a 3D surface, a method of discrete triangularization of the surface is utilized. In the method of discrete triangularization, a mesh of triangles is generated from the point cloud of a 3D surface. This results in the 3D surface being represented approximately by a mesh of triangles which covers the given 3D surface.
The point p 401 on the 3D surface is at the vertex of the triangles 410, 420, 430, 440, 450 and 460. The approximate Gaussian curvature for the point p 401 can be calculated by summing the angles Δ1, Δ2 Δ3, Δ4, Δ5 and Δ6 for the triangles 410, 420, 430, 440, 450 and 460, respectively, and subtracting the summed angles from 2π (or 360°). As a result, the angle Δk 402 is calculated.
In general, the approximate Gaussian curvature for a point p at a vertex of N triangles may be computed as
In other words, the angles Δi of the N triangles surrounding the point p are summed together and subtracted from 2π (or 360°) to calculate the approximate Gaussian curvature of the point p.
The Gaussian curvature K(a) of a point a on a first 3D surface can be compared to the Gaussian curvature K(b) of point b on a second 3D surface. If the Gaussian curvatures K(a) and K(b) are within a pre-determined threshold ξ, the Gaussian curvatures are determined to be equivalent. Thereby satisfying
|K(a)−K(b)|<ξ. Equation (4)
In some examples, the sampling of the duplets from the second surface comprises random sampling. In other examples, sampling the duplets may be pseudo-random or follow a pre-determined sequence or pattern.
In some examples, a mesh of triangles may be generated from a 3D surface prior to the sampling of the surface duplet from the 3D surface. The mesh of triangles may be generated using discrete triangularization of the 3D surface. In other examples, a depth map of a 3D surface may be generated.
In some examples, an intrinsic surface property of each point from a point cloud of a 3D surface may be calculated prior to the sampling of the duplets from the 3D surface. The intrinsic surface property of the 3D surface may be a Gaussian curvature of the 3D surface. The Gaussian curvature of the surface may be calculated using discrete triangularization of the 3D surface or on a depth map of the 3D surface.
In some examples, the Gaussian curvature of the surface may be determined using the ratio of the determinants of the first and second fundamental forms of the 3D surface. The fundamental forms of a 3D surface are quadratic differential forms of the co-ordinates of the 3D surface. The fundamental forms characterize the intrinsic properties of the surface at a given point, and thus can be used to calculate the Gaussian curvature of the surface. The Gaussian curvature may be calculated by using the first and second fundamental terms or by using solely the first fundamental term and its derivatives.
In other examples, the intrinsic surface property of the 3D surface may be a local property of the 3D surface which is invariant under rotation and translation.
In block 530, duplets of the first surface duplets are matched with duplets of the second surface duplet based on at least one geometric feature of the duplets to create a set of first and second surface duplet pairs.
In some example, the duplets of the first surface duplets are matched with duplets of the second surface duplet using at least one relation table. A relation table may be referred to as a hash table.
A first relation table for the first surface may store first surface duplets that may have already been sampled. A second relation table for the second surface may store second surface duplets that may have already been sampled. The position of a duplet in the relation table may be determined by the geometric features of the duplet. As such, two duplets with identical geometrical features may have identical positions in a relation table.
In some examples, a relation table for a 3D surface may be populated prior to sampling the first surface duplet. Computational resources for the 3D registration procedure may decrease by pre-populating the relation table.
A first surface duplet of the first surface may be matched with a second surface duplet of the second surface by inspecting the first relation table and the second relation tables. Matching duplets of the first surface duplets with duplets of the second surface duplets may comprise inserting a first surface duplet into the first relation table and inspecting the same position in the second relation table for the presence of a second surface duplet. If the second surface duplet exists, the first surface duplet and the second surface duplet are geometrically congruent and may be considered to be matched. Together, the first surface duplet and the second surface duplet may be referred to as a first and second surface duplet pair. Matching duplets of the first surface duplets with duplets of the second surface duplets may create a set of surface duplet pairs.
In block 540, the set of first and second surface duplet pairs are filtered by comparing an intrinsic surface property of the first surface duplet and the second surface duplet of the duplet pairs to create a subset of first and second surface duplet pairs. In some examples, the intrinsic surface property may be a Gaussian curvature of the 3D surface.
In block 550, a pose estimate for aligning the first 3D surface with the second 3D surface is computed based on the subset of first and second surface duplet pairs. In some examples, the procedure 500 may be repeated until the pose estimate reaches or exceeds a pre-determined quality criterion. In other examples, the procedure 500 may be repeated until a pre-determined time limit has been exceeded.
While the present disclosure is described in relation to a first 3D surface and a second 3D surface, additional 3D surfaces may be envisaged. For example, when additional 3D surfaces exist, pairs of points from additional 3D surfaces may be sampled to generate additional surface duplets.
In some examples, the 3D registration procedure may initially be performed in order to align the first 3D surface with the second 3D surface. Once the first and second 3D surfaces are aligned, the 3D registration procedure may be performed again to align the additional 3D surface with the already-aligned first and second 3D surfaces.
In other examples, the 3D registration procedure may be performed to align the first 3D surface, the second 3D surface and additional 3D surfaces in parallel. As such, duplets of the additional surface duplets may be initially matched with duplets of the first surface duplets to create a set of first and additional surface duplet pairs. The first and additional surface duplet pairs may then be further matched with duplets of the second surface duplets to create a set of surface triplets. The set of surface triplets comprises matched first, second and additional surface duplets. The set of surface triplets may then be filtered by comparing an intrinsic surface property of the first, second and additional surface duplets of the set of surface triplets to create a subset of surface triplet pairs. A pose estimate may then be computed for aligning the first, second and additional 3D surfaces with each other based on the subset of the surface triplets.
In some examples, pre-computing the Gaussian curvature of a 3D model of an object or shape may decrease the computational resources needed to perform the 3D registration procedure as the computation may only need to be performed once for a particular 3D model. Said 3D model may then be used in multiple 3D registration procedures.
In block 630, a pair of points (a and c) from the first 3D surface is sampled to generate a first surface duplet (a,c). A pair of points (b and d) from a second 3D surface is sampled to generate a second surface duplet (b,d).
In block 640, at least one geometric feature of the first surface duplet F(a,c) may be determined. Similarly, at least one geometric feature of the second surface duplet F(b,d) may be determined. The geometric features of the first surface duplet F(a,c) may then be matched with the geometric features of the second surface duplet F(b,d).
In some examples, the geometric features of the first surface duplet F(a,c) may be matched with the geometric features of the second surface duplet F(b,d) using a relation table. A first relation table may store the geometric features of first surface duplets e.g. F(a,c) that have already been sampled. Similarly, a second relation table may store the geometric features of second surface duplets e.g. F(b,d) that have already been sampled. The location of the sampled surface duplets in the relation table is determined by the geometric features of the surface duplets. Therefore, inspecting equivalent positions in the first relation table and the second relation table allows geometrically congruent surface duplets to be matched e.g. F(a,c)≈F(b,d). This may form a surface duplet pair (a,b,c,d) comprising the geometrically congruent first surface duplet (a,c) and second surface duplet (b,d).
If the geometric features of the first surface duplet F(a,c) are determined to match the geometric features of the second surface duplet F(b,d), then the procedure 600 follows a path to block 650. If the geometric features of the first surface duplet F(a,c) do not match the geometric features of the second surface duplet F(b,d), then the procedure follows a path to block 630. Here, another first surface duplet and/or another second surface duplet may be selected to continue the procedure.
In block 650, the surface duplet pairs (a,b,c,d) are filtered by comparing an intrinsic surface property of the first surface duplet and the second surface duplet. The intrinsic surface property of the duplets may be a Gaussian curvature of the surface.
In some examples, a Gaussian curvature of the first surface duplet (a,c) may be compared to a Gaussian curvature of the second surface duplet (b,d) from the surface duplet pairs (a,b,c,d). The Gaussian curvature of a point a from the first surface duplet (a,c) may be determined to be K(a) as given in Equation 2 above. Similarly, the Gaussian curvature of a point b from the second surface duplet (b,d) can be determined to be K(b). The Gaussian curvatures K(a) and K(b) may be compared, as described in Equation 4 above, to determine if the Gaussian curvatures of point a and point b are equivalent.
Similarly, the Gaussian curvature of point c from the first surface duplet (a,c) may be determined to be K(c) and the Gaussian curvature of point d from the second surface duplet (b,d) can be determined to be K(d). The Gaussian curvatures K(c) and K(d) are compared to determine if the Gaussian curvatures of point c and point d are equivalent.
If the Gaussian curvatures K(a) and K(c) from the first surface duplet are determined to be equivalent to the Gaussian curvatures K(b) and K(d) from the second surface duplet i.e.
|K(a)−K(b)|<ξ and |K(c)−K(d)|<ξ,
then the Gaussian curvature of the first surface duplet is said to be equivalent to the Gaussian curvature of the second surface duplet e.g. K(a,c)≈K(b,d). As a result, the procedure 600 then follows a path to block 660.
If the Gaussian curvature K(a) of the point a from the first surface duplet is determined to not be equivalent to the Gaussian curvature K(b) of the point b from the second surface duplet, and/or if the Gaussian curvature K(c) of the point c from the first surface duplet is determined to not be equivalent to the Gaussian curvature K(d) of the point d from the second surface duplet i.e.
|K(a)−K(b)|=>ξ and/or |K(c)−K(d)|=>ξ,
then the Gaussian curvature of the first surface duplet is said to not be equivalent to the Gaussian curvature of the second surface duplet e.g. K(a,c)≠K(b,d). As a result, the procedure 600 then follows a path that returns to block 630. Here, another first surface duplet and/or another second surface duplet may be selected to continue the procedure from block 630, in search of a surface duplet pair that have equivalent Gaussian curvatures.
In block 660, a pose estimate T is computed using the surface duplet pairs (a,b,c,d) in order to align the first 3D surface with the second 3D surface. The surface duplet pairs have been determined to be geometrically congruent in block 640 and have equivalent Gaussian curvatures in block 650. The pose estimate T may align the surface duplets (a,c) and (b,d), bringing them into contact with each other.
After calculation of the pose estimate T, the procedure 600 may return to block 630. The blocks of the procedure 600 may repeated until the calculated pose estimate T satisfies a certain condition. The condition may be that the pose estimate T satisfies a quality condition, for example the first 3D surface and the second 3D surface are aligned by the pose estimate T within a pre-defined margin of error. Alternatively, the blocks of the procedure 600 may have been repeated until a pre-defined time limit has been exceeded. Once the condition for repetition of the blocks of the procedure 600 is met, the final pose estimate T may be utilized to align the first 3D surface with the second 3D surface, completing the 3D registration procedure.
At block 831 the instructions cause the processor 810 to identify a first dipole from a first 3D surface, wherein a dipole comprises a pair of orientated points from a 3D surface. At block 832 the instructions cause the processor 810 to determine an index for the first dipole based on the geometric features of the first dipole. At block 833 the instructions cause the processor 810 to identify a second dipole from a second 3D surface having the same index as the index of the first dipole. At block 834 the instructions cause the processor 810 to determine if the first and second dipoles have equivalent intrinsic surface properties by comparing the intrinsic surface properties of the first and second dipoles. At block 835 the instructions cause the processor 810 to calculate a pose estimate to align the first and second dipoles in response to determining the first and second dipoles have equivalent intrinsic surface properties.
At block 921 the instructions 920 cause the processor 910 to sample a first duplet comprising a pair of points from a first 3D surface. At block 922 the instructions 920 cause the processor 910 to sample a second duplet comprising a pair of points from a second 3D surface. At block 923 the instructions 920 cause the processor 910 to compare a first feature of the first and second duplets to determine if the first and second duplets match. The first feature of the first and second duplets may be a geometric feature. If the first and second duplets match based on the first feature, then at block 924 the instructions 920 cause the processor 910 to compare a second feature of the first and second duplets to determine if the first and second duplets match. The second feature of the first and second duplets may be a surface property e.g. Gaussian curvature of a duplet. If the first and second duplets match based on the second feature, then at block 925 the instructions 920 cause the processor 910 to compute a pose estimate to align the first and second duplet.
The preceding description has been presented to illustrate and describe examples of the principles described. This description is not intended to be exhaustive or to limit these principles to any precise form disclosed. Features of individual examples may be combined in different configurations, including those not explicitly set out herein. Many modifications and variations are possible in light of the above teaching, for example, using an intrinsic surface property such as the texture of a 3D surface to filter the set of surface duplet pair to create a subset of surface duplet pairs. The texture of a 3D surface may be the 2D texture or the color of the surface.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2018/039370 | 6/25/2018 | WO | 00 |