1. Introduction
Mesh parameterization is the process by which a piecewise linear surface (i.e., triangular mesh) M is mapped with the least possible distortion onto a planar () region, via a bijective continuous function . The mesh M is supposed to be a connected 2-manifold with border (and possibly holes).
Mesh parameterization is central in tool path generation for surface machining, texture mapping, thermoforming of thin layers (metal, leather, plastic, etc.), reverse engineering, finite element remeshing, facial expressions, morphing, etc.
A geodesic curve between two points of a continuous surface is the shortest path within the surface joining the two points. The length of such a path is the geodesic (shortest) distance, embedded in the surface, between those two points.
Given any two points , ideal parameterizations of such a surface seek to map them to so that the geodesic distance between and in M matches the Euclidean 2D distance between and in . On the rare occasions that this goal is possible, M is called a developable surface and is an isometric map. When the distortion in such distances is small, one qualifies M as a quasi-developable surface. This case is sufficiently frequent, since large triangular meshes can be segmented with a goal being that the resulting submeshes are quasi-developable or developable.
It is not convenient, when the mesh has holes or concavities in its boundary, to parameterize the mesh via geodesics. The reason is that mesh points being close neighbors in the surface may be far apart via geodesic curves due to mesh gaps or concavities.
Mesh parameterization algorithms can be classified depending on the type of distortion being minimized, as follows: (a) Area-preserving (authalic) algorithms; (b) angle-preserving (conformal) algorithms; and (c) distance-preserving (isometric) algorithms. The remainder of this section discusses a summary of recent mesh parameterization algorithms already present in the literature (Detailed surveys on mesh parameterization algorithms are presented in [
1,
2,
3]).
1.1. Area-Preserving Mesh Parameterization
Area-preserving (authalic) parameterization algorithms rely on the minimization of an area preserving continuous cost function. Zou et al. [
4] solved a Lie advection problem on the mesh
M. The gradient of the scalar Lie advection field was then added to an initial parameterization
of
M, resulting in an authalic parameterization. Zhao et al. [
5] solved an optimal mass transport problem from the mesh
M to its parameterization
. The optimal mass transport poses a partial differential equation in which the parameterization
locally preserves the area at every point
. Since most optimal transport methods only parameterize meshes with a connected boundary (i.e., without holes), Su et al. [
6] introduced additional boundary conditions to allow authalic parameterizations of meshes with more complex topologies.
1.2. Angle-Preserving Mesh Parameterization
Angle-preserving (conformal) optimization aims to minimize the parameterization angle distortion. Since this objective can be achieved by collapsing all triangles to a single point, these algorithms rely on constraining the parameterized boundary to a region in
. Disk geometries are usually used in this context [
7,
8] however, other geometries such as squared domains have also been proposed [
9,
10]. The imposed boundary restrictions in these constrained optimization algorithms induce additional distortion in the resulting parameterization.
Free boundary algorithms allow unrestricted boundary parameterizations, producing less distorted maps. Sawhney and Crane [
11] presented an algorithm in which the mesh boundary is mapped to
according to its shape. The parameterized boundary is then used as a constraint to produce a boundary-free parameterization. Starting from a disk parameterization, Bright et al. [
12] performed nonlinear optimization while unconstraining the boundary edges of the parameterized mesh. The resulting parameterization allows the (initially mapped to disk) boundary to move freely in the parameter space. Smith and Schaefer [
13] presented a mesh parameterization method which introduced a barrier function in its optimization process. The introduced barrier function penalizes nonadjacent triangle overlaps, which guarantees global bijectiveness in the resulting parameterization.
Dimensionality reduction is a superset of mesh parameterization, in which a
d-manifold embedded in a higher dimensional space
, is parameterized to its corresponding
domain. As a consequence, these algorithms have been applied successfully in mesh parameterization applications. Such algorithms include Laplacian Eigenmaps [
14] and Hessian Locally Linear Embedding [
15].
1.3. Distance-Preserving Mesh Parameterization
By definition, a distance-preserving (isometric) mapping is a function that simultaneously preserves areas and angles. Mejia et al. [
16] presented a nonlinear minimization algorithm for area-angle (isometry) preservation. The minimization function is a linear combination of area and angle distortion, and the weighting parameters for each distortion term are adjusted by the user. The authors pointed out that the algorithm performs better when the angle-preserving term is preponderant over the area-preserving one. Similarly, Yu et al. [
17] used polar factorization to introduce area-angle preserving mappings, in which area distortion increases as angle distortion decreases. ARAP (As Rigid As Possible) algorithms divide the parameterization into two optimization steps—local parameterization and global parameterization—performing these steps iteratively one after another until convergence [
18,
19,
20]. These algorithms produce different bijective parameterizations, but since the weighting parameters are nonoptimized (as they are user-defined), the resulting parameterization is rarely the optimal distance-preserving map.
Ruiz et al. [
14] used a dimensionality-reduction geodesic-based algorithm (Isomap) for the computation of isometric parameterization of quasi-developable meshes. However, in addition to the classic nonconvex parameterization problems, such algorithms estimate geodesics using shortest-path graph algorithms which introduce additional distortions in the resulting parameterization. Li et al. [
21] presented a geodesic approximation approach in which cutting planes are intersected with the mesh to estimate geodesic paths. This approach solves the problem of nonconvex surfaces and distortion errors induced by mesh graph approximation. However, the method is limited to geodesic curves embedded in
(i.e., the cutting plane).
1.4. Conclusions of the Literature Review
Most of the distance-preserving parameterization algorithms rely on weighting angle vs. area distortion. Such a weighting is defined by the user and drastically changes the resulting parameterization, not providing the optimal isometric mapping. Geodesic-based parameterization algorithms solve this problem by directly minimizing the distance distortion. However, current geodesic-based algorithms rely on shortest-path graph algorithms for geodesics estimation, introducing unnecessary distortion in the resulting parameterization. In addition, estimation of geodesics fails when the surface is nonconvex (such as surfaces with holes and boundary concavities).
To overcome these problems, this manuscript presents a novel heat-geodesic mesh parameterization algorithm. Our algorithm computes a set of temperature maps (heat kernels) on the mesh
M, which are then used to retrieve the set of point-to-point geodesic distances on the discrete mesh. Afterwards, a near-isometric parameterization is obtained by minimizing the difference between the parameterization Euclidean distances and their corresponding geodesics. Since our method relies on finite element mesh discretization to estimate the temperature maps and geodesics, our geodesics estimation is unaffected by mesh-graph topology (as opposed to shortest-path graph algorithms). To overcome the nonconvexity problem, our algorithm uses Poisson surface reconstruction [
22], in which the surface holes and boundary concavities are temporarily filled for parameterization. The resulting parameterization for the Poisson reconstructed surface is trimmed with the original boundary of
M, producing a trimmed surface. The implementation and integration of these different techniques provide a novel geodesic-based mesh parameterization algorithm which is (1) unaffected by mesh holes and/or concavities and (2) less sensitive to mesh graph topology.
2. Methodology
Consider (with point set and triangle set ), a connected 2-manifold with border (and possibly holes) embedded in . The problem of mesh parameterization consists of finding a set of points such that is the image of under the image of a homeomorphism (i.e., ). The function must satisfy the following conditions:
Continuity: If and () are adjacent triangles in M, then and are adjacent in .
Local bijectiveness: All mapped triangles share the same orientation in .
Global bijectiveness: Triangles in
do not overlap each other. This can happen even if all triangles share the same orientation as illustrated in [
13].
In addition, define as the geodesic distance function in M. If (), then is an isometric mapping (i.e., preserves geodesic distances) and M is a developable surface.
As most of the surfaces are not developable in practice, we aim to find the discrete mapping
that minimizes the difference between these two distances as follows:
where the restriction
indicates that the parameterization is mean centered, i.e., the center of mass of the parameterization points is
. Such a restriction is introduced to obviate all the possible translations of the same solution.
2.1. Algorithm Overview
Our mesh parameterization algorithm aims to retrieve a parameterization
which highly preserves the geodesic distances of
M as Euclidean distances. In order to estimate the geodesic distances
g in
M, the heat-based geodesics algorithm presented in [
23] is implemented. Afterwards, we use classic multidimensional scaling to retrieve the 2D coordinates of the parameterization
from the computed geodesic distances. In the case that
M presents holes or concavities, our algorithm applies Poisson surface reconstruction [
22] and computes a parameterization on a trimmed surface instead. A summary of the algorithm is presented in
Figure 1.
The remainder of this section details the steps to solve Equation (
1), and the details of our mesh parameterization algorithm. The algorithm was implemented in MATLAB
® [
24], except for the Poisson Surface Fills which were implemented in C++ using the PCL library [
25]. Figures including triangular meshes, scalar fields, vector fields, and 2D parameterizations were produced in MATLAB
®. Figures including texture maps on the surface were produced using MeshLab [
26].
2.2. Mesh Heat Kernels
A heat kernel of a point
is a function
that satisfies the following partial differential equation [
27]:
where
is the Laplace–Beltrami operator,
is the temperature distribution (heat kernel) associated to the source point
,
are the spatial and time coordinates, respectively, and
is the simulation time. The term
corresponds to the Neumann boundary condition (no boundary heat flux). Finally, the term
corresponds to Dirac delta initial conditions, i.e.,
The above initial conditions dictate initial infinite temperature at vertex
and 0 everywhere else. After some timem
has passed, heat dissipates from
as illustrated in
Figure 2.
Equation (
2) can be solved using a Finite Element discretization scheme, as follows:
where
is the time step,
is the vector of temperatures values (
), and
L and
B are the
Laplace–Beltrami and mass (sparse and symmetric) matrices, respectively. For a given edge
, the Laplace–Beltrami matrix
L is defined as follows:
where
are the two opposite angles to the edge
, and
is the index set of all incident edges to the vertex
. The entries
of the matrix
L are known as cotangent weights [
28].
Similarly, the mass matrix
B is defined as follows:
where
are the pair of triangles adjacent to the edge
and
is the area of the triangle
(
).
For each vertex
, Equation (
4) is solved for
using a sparse Cholesky linear solver. It is worth noting that for every
and
, the matrices
and
B are the same. As a consequence, these matrices are prefactored only once using Cholesky factorization, which speeds up the computation of the heat kernels.
Finally, the simulation parameters
are chosen according to [
23]:
with
computed as the magnitude of the largest edge in
M, and
T is equal to
. These values have provided better results in our parameterization experiments than other values.
2.3. Heat-Based Geodesic Distance
The vector field
(∇: gradient operator on
M) describes the heat flux on
M for the respective heat kernel
. The normalized heat flux vector field
is defined as follows:
It is worth noting that the magnitude of the vector field
is 1 everywhere (
). In addition, as illustrated in
Figure 3, the temperature contours are perpendicular to the geodesic paths from
, and the corresponding vector field points in the same direction as such paths.
The geodesic field
satisfies the following differential equation [
23]:
where
is the divergence field of the normalized heat flux. Similar to Equation (
2), Equation (
9) is discretized using the same Finite Element scheme, as follows:
where
is the vector of geodesic distances
and
is the divergence field of the normalized gradient
[
23].
Figure 4 plots the estimated geodesic distance field
for the vertex
.
2.4. Multidimensional Scaling (MDS)
After the geodesic field
has been estimated on
M, the minimization problem in Equation (
1) can be solved. Classic multidimensional scaling poses an equivalent minimization problem [
29]:
Let
C be the symmetric, semidefinite positive matrix whose entries contain the mean centered squared geodesics (i.e.,
). In matrix form,
C is equivalent to
where
,
are the
identity and all-ones matrices, respectively, and
is the
symmetric matrix whose entries contain the squared geodesic distances in
M, i.e.,
. Then, Equation (
11) becomes:
with
as the (squared) Frobenius norm of
A.
Finally, Equation (
13) can be solved by an eigendecomposition of
C as follows [
29]. Let
and
be the largest positive eigenvalues of
C, with respective
eigenvectors
and
. The near-isometric parameterization of
M becomes
where
are the discrete
u-coordinates and
are the discrete
v-coordinates of the parameterization
.
Figure 5 plots the resulting parameterization using MDS on the estimated geodesic fields
G.
2.5. Poisson Mesh Reconstruction
In the case that
M is nonconvex (i.e., it has holes or concavities), we seek to compute an underlying extending surface
. Such a surface contains the points in
M, and fills the holes and concavities by extending
M in such areas (
). As an example, a geodesic path in a nonconvex
M circles a given hole (
Figure 6a). On the other hand, the same geodesic path in the extended surface
crosses through the hole (
Figure 6b).
To compute the surface
, our parameterization algorithm uses Poisson surface reconstruction [
22] from the PCL library [
25]. Define
as an indicator function such that
if
is “inside” the solid defined by
; and
if
x is “outside” such solid. The surface
is composed by the points in between, as follows [
22]:
The indicator function
is computed by solving the following partial differential equation in
[
22]:
where
and ∇ are the
Euclidean Laplacian and gradient operators, respectively. It is worth noting that these Laplacian and gradient operators are different from the 2-manifold version presented in
Section 2.2 and
Section 2.3.
is a vector field in
whose value
is the normal vector to the original surface
M if
, and
everywhere else.
To solve Equation (
16), the PCL library uses a hierarchical 3D spatial discretization and a Finite Differences approach [
25].
Figure 7 plots the Poisson surface filling
for a given nonconvex mesh
M. The resulting geodesic field (
Figure 8) is distributed along the original mesh
M and its extents
. The corresponding parameterization of the underlying Poisson surface
(
Figure 9a) is finally trimmed in order to retrieve the final parameterization
of
M (
Figure 9b).
Figure 10 plots the chessboard texture maps for both parameterization without Poisson filling (
Figure 10a) and parameterization with Poisson surface filling (
Figure 10b). As illustrated, using Poisson filling reduces parameterization distortions close to mesh holes and boundary concavities.
3. Results
To test our mesh parameterization algorithm, we run tests with several parameterizable surfaces.
Section 3.1 presents a comparison of our mesh parameterization algorithm without Poisson surface filling vs. Poisson surface filling, for quasi-developable nonconvex meshes.
Section 3.2 presents parameterization results for some challenging, strongly nondevelopable data sets. Finally,
Section 3.3 presents the application of our parameterization algorithm for the reverse engineering of a scanned cow vertebra.
3.1. Nonfilling vs. Poisson Filling Parameterization
Figure 11 plots the parameterization results (2D
coordinates and 3D texture map) for the Mask data set. Without using Poisson surface reconstruction, the resulting parameterization is bijective with relatively low distortion, except for the eye holes (
Figure 11a). However, such a parameterization is improved by applying the Poisson reconstruction, reducing the distortion close to mesh holes and boundary concavities (
Figure 11b).
A more extreme case is illustrated in
Figure 12, with the S-trimmed-on-cone data set from [
14]. Since the S shape is trimmed on a cone,
M is a fully developable surface. Yet, the heat-geodesic parameterization on
M fails to compute a bijective parameterization (
Figure 12a). Application of Poisson (extended underlying surface
) filling (
Figure 12b) solves this issue, resulting in a nondistorted bijective parameterization. This case illustrates (a) the vulnerability of geodesic-based parameterizations in the presence of mesh holes or concavities at mesh borders, (b) the capacity of the underlying Poisson extended surface to prevent (a), (c) the natural manner in which geodesic curves isometrically parameterize a developable surface.
3.2. Parameterization of Strongly Nondevelopable Meshes
In this section, the public data sets Foot, Gargoyle, and Cow are parameterized with our heat-based geodesics algorithm. These benchmark datasets contain an artificially introduced border [
30], which allows their parameterization.
Figure 13a,b plot the parameterization results for the seam Foot and Gargoyle, respectively. The resulting parameterization is bijective, with some noticeable distortion (e.g., in the Gargoyle head).
Figure 13c plots our parameterization results for the seamed Cow, which is not bijective in the head, legs, and tail.
It is worth noting that although parameterizable, these benchmark data sets are strongly nondevelopable without a proper mesh presegmentation. This fact is illustrated in the next section.
3.3. Reverse Engineering of Cow Vertebra
For this section, the vertebra of a cow is scanned using a 3D optical scanner. The scanned mesh is closed and therefore accepts no (bijective) parameterization. The closed mesh is segmented into quasi-developable meshes using a heat-based segmentation approach [
31].
Figure 14 plots the parameterization results for the segmented mesh. Each submesh bijective parameterization presents low distortion, enabling further reverse engineering operations such as NURBs reparameterization [
14], finite element analysis, structural optimization, and/or dimensional inspection [
31].
4. Conclusions
This article presents the implementation of a novel application of heat propagation in 2-manifolds used for mesh parameterization. The temperature contours for the heat kernels computed on the mesh are perpendicular at each point to the geodesic curves in the surface. This principle permits determination of geodesic maps in the mesh and in particular vertex-to-vertex geodesic distances. Although Finite Element methods produce better results as the mesh resolution increases (higher polygon count), the geodesics estimation method still produces robust results for low polygon count meshes as each geodesic path traverses across the mesh faces (contrary to graph algorithms which traverse the mesh graph). A quasi-isometric bijective function (i.e., the parameterization) is synthesized to map the 3D mesh to the parameter (2D) space. This parameterization is near isometric in the sense that geodesic distance on the mesh between any two points on the mesh approximates the Euclidean distance between their images in the parametric space. This approach is obviously limited to meshes that are quasi-developable or developable, since mesh developability is necessary for the existence of an isometric parameterization for it.
Our approach circumvents the weakness of geodesic maps in the presence of mesh interruptions (boundary concavities and mesh holes) by devising an underlying continuous Poisson surface that approximates the input mesh but contains no such interruptions. This underlying surface allows for geodesic maps to be computed on it, which are also valid in the input mesh. In this manner, the parameterization computed for the Poisson surface is valid for the input mesh. Finally, the boundaries of the input mesh are explicitly marked on the parameterization to obtain a trimmed surface or FACE in the Boundary Representation jargon.
Future work is required in these aspects—(a) to eliminate redundant computation that is present in the construction of heat-based geodesic maps and (b) to use failures in the bijectiveness of the computed parameterizations to force mesh segmentation, when the input mesh is strongly nondevelopable.