School of Software, Shandong University, Jinan 250101, China
School of Computer Science and Engineering, Nanyang Technological University, Singapore 639798, Singapore
Internet Graphics Group, Microsoft Research Asia, Beijing 100080, China
School of Computer Science and Technology, Shandong University, Qingdao 266237, China
*Long Ma and Sidan Yao contributed equally to this work.
Show Author Information
Hide Author Information
Graphical Abstract
View original imageDownload original image
Abstract
We present a simple yet effective method for constructing 3D self-supporting surfaces with planar quadrilateral (PQ) elements. Starting with a triangular discretization of a self-supporting surface, we firstcompute the principal curvatures and directions of each triangular face using a new discrete differential geometryapproach, yielding more accurate results than existing methods. Then, we smooth the principal direction field to reduce the number of singularities. Next, we partition all faces into two groups in terms of principalcurvature difference. For each face with small curvature difference, we compute a stretch matrix that turns the principal directions into a pair of conjugate directions. For the remaining triangular faces, we simply keep their smoothed principal directions. Finally, applying a mixed-integer programming solver to the mixed principal and conjugate direction field, we obtain a planar quadrilateral mesh. Experimental results show that our method is computationally efficient and can yield high-quality PQ meshes that well approximate the geometry of the input surfaces and maintain their self-supporting properties.
Block,P.; Ochsendorf,J.Thrust network analysis: A new methodology for three-dimensional equilibrium. Journal of the International Association for Shell and Spatial Structures Vol. 48, No. 3, 167-173, 2007.
Meyer,M.; Desbrun,M.; Schröder,P.; Barr,A. H.Discrete differential-geometry operators for triangulated 2-manifolds. In: Visualization and Mathematics III. Mathematics and Visualization. Hege,H. C.; Polthier,K.Eds.Springer Berlin Heidelberg, 35-57, 2003.
Rusinkiewicz,S.Estimating curvatures and their derivatives on triangle meshes. In: Proceedings of the 2nd International Symposium on 3D Data Processing, Visualization and Transmission, 486-493, 2004.
[24]
Liu,D. C.; Nocedal,J.On the limited memory BFGS method for large scale optimization. Mathematical Programming Vol. 45, Nos. 1-3, 503-528, 1989.
Open Access This article is licensed under a Creative Commons Attribution 4.0 International License, which permits use, sharing, adaptation, distribution and reproduc-tion in any medium or format, as long as you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons licence, and indicate if changes were made.
The images or other third party material in this article are included in the article’s Creative Commons licence, unless indicated otherwise in a credit line to the material. If material is not included in the article’s Creative Commons licence and your intended use is not permitted by statutory regulation or exceeds the permitted use, you will need to obtain permission directly from the copyright holder.
To view a copy of this licence, visit http://creativecommons.org/licenses/by/4.0/.
Other papers from this open access journal are available free of charge from http://www.springer.com/journal/41095. To submit a manuscript, please go to https://www.editorialmanager.com/cvmj.
10.1007/s41095-021-0257-1.F001
Given a self-supporting surface as a triangular mesh, our method converts it into a planar quadrilateral mesh that approximates the input surface faithfully both geometrically and in physical performance.
10.1007/s41095-021-0257-1.F002
Algorithmic pipeline. The input is a 3D self-supporting surface represented by a triangle mesh. First, we compute principal curvatures and principal directions for each triangular face. Then, we group the faces with similar principal curvatures, which are called free faces (green). We compute a smooth cross field on the free faces and generate a pair of conjugate directions by stretching the principal directions. Next, we parameterize the triangle mesh using the mixed principal direction field and conjugate direction field. Finally, we extract the planar quadrilateral mesh from the parameterization.
3.1 Overview
Our method takes a self-supporting surface represented by triangle mesh as input. We first compute the principal curvatures and directions for each triangular face using a new method for computing the curvature tensor on triangle meshes. Then we group the triangular faces whose principal curvature difference is small. We call these faces free faces and the remaining faces fixed faces. Since the principal directions on fixed charts are already conjugate, our goal is to construct a pair of conjugate directions for each free chart. Towards this goal, we compute a stretching matrix that turns the principal directions of free charts into conjugate directions. The principal directions of the fixed charts and the conjugate directions of the free charts induce a conjugate direction field on the input mesh. Applying the mixed integer quadrangulation method [
22
] to the CDF, we parameterize the triangle mesh and extract the planar quadrilateral elements. We present the algorithmic details in Sections 3.2-3.6. We show the algorithmic pipeline of our method in
Fig. 2
and pseudocode in Algorithm 1. To ease reading, we list major notation in
Table 1
.
10.1007/s41095-021-0257-1.T001
Notations
Item
Description
2D domain
Parameters
3D surface
Input 3D triangular mesh
,
Local coordinate axes for each face
Unit normal
Curvature tensor
,
Principal curvatures
,
Principal directions
Stretch matrix
,
Conjugate tangent directions
10.1007/s41095-021-0257-1.F002
Algorithmic pipeline. The input is a 3D self-supporting surface represented by a triangle mesh. First, we compute principal curvatures and principal directions for each triangular face. Then, we group the faces with similar principal curvatures, which are called free faces (green). We compute a smooth cross field on the free faces and generate a pair of conjugate directions by stretching the principal directions. Next, we parameterize the triangle mesh using the mixed principal direction field and conjugate direction field. Finally, we extract the planar quadrilateral mesh from the parameterization.
10.1007/s41095-021-0257-1.F003
Difference between the observation point movement strategy used in Rusinkiewicz’s method [
23
] and our method. (a) In Ref. [
23
], the derivatives are , , and , and are based on mesh vertices. (b) In our method, we define , where and are the centers of the circumscribed circles of and its neighbors.
3.2 Computing principal curvatures and directions
Curvature is the amount by which a curve deviates from a straight line, or a surface deviates from planar. For a smooth 3D surface , the curvature tensor satisfies and , where , are the tangent vectors of and , the partial derivatives of unit normal .
Since we deal with 3D self-supporting surfaces represented by triangle meshes, we need to discretize . The key idea is to consider , as the movement of observation points on the surface. Consider a triangular face and its neighbors , , and . Let , be the normals of , , , and , and be the derivatives of these normals.
10.1007/s41095-021-0257-1.F003
Difference between the observation point movement strategy used in Rusinkiewicz’s method [
23
] and our method. (a) In Ref. [
23
], the derivatives are , , and , and are based on mesh vertices. (b) In our method, we define , where and are the centers of the circumscribed circles of and its neighbors.
Observe that each face normal is the cross product of two edge vectors, and each vertex normal is computed as the weighted average of face normals. Therefore, face normals are usually more accurate than vertex normals on triangle meshes. Our movement strategy is to use the centers and of the circumscribed circles of and its neighbors , , and . We compute the derivatives as
and
for . Since the curvature tensor satisfies , we form an over-constrained linear system:
where and are the axes of the local coordinate system on . Then we compute by solving a linear least squares problem. After that, we can form the curvature tensor :
since is symmetric. The eigenvalues and eigenvectors of are the principal curvatures and directions of face . Algorithm 2 gives pseudocode for computing principal curvatures and directions on triangle meshes.
10.1007/s41095-021-0257-1.F004
Smoothing principal directions. (a) There are many singularities in the principal direction field. (b) The singularities are reduced significantly after smoothing. The red and blue spheres are singularities with index and , respectively.
10.1007/s41095-021-0257-1.F005
Distinguishing fixed and free faces. (a) We compute the quantity from principal curvatures and on each triangular face, . (b) Faces with are marked as fixed (brown) and the remainder are free faces (green).
10.1007/s41095-021-0257-1.F006
Consider a circle (blue) with two perpendicular diameters. Stretching the circle with matrix yields an ellipse and the two perpendicular diameters are conjugate.
10.1007/s41095-021-0257-1.F007
Computing conjugate directions on free faces. (a) Smoothed principal directions. (b) Conjugate directions.
10.1007/s41095-021-0257-1.F008
Comparison with Rusinkiewicz’s method [
23
] in terms of accuracy and convergence plots. We generate sequences of isotropic (first two rows) and anisotropic meshes (last two rows) with increasing number of faces. The heat colour map shows the angle differences between the computed principal directions and the ground-truth; warmer colors are larger errors. For each model, we show our results above and theirs below. is the anisotropy measure and is the face count.
10.1007/s41095-021-0257-1.F009
Discrete geodesic curvatures of the iso-parameter lines.
10.1007/s41095-021-0257-1.F010
Results and comparisons. For each model, the three rows show the triangle mesh produced by Ma et al.’s method and the PQ meshes produced by our method and Liu et al.’s method respectively. We visualize the quality of the results using 3 quantitative measures: normal displacement , stress tensor error , and differential stress . The lower the measures, the higher the quality of the resulting PQ meshes.
10.1007/s41095-021-0257-1.F011
Non-height fields. Row 1: the triangle meshes generated by Ma et al.’s method [
9
]; Rows 2 and 3: the PQ meshes produced by our method and Liu et al.’s method [
15
], respectively.
10.1007/s41095-021-0257-1.T002Evaluation of the physical measures , , and , and planarity measure . For each model, we show the MIQ result above and our result below. For each measure, the lower the value, the higher the quality
Model
Eich (Fig. 10, row 1, right)
1.51
9.64
4.04
2.11
Tea (Fig. 10, row 3, left)
2.09
12.06
3.38
2.56
Oct (Fig. 10, row 4, left)
2.41
2.92
3.11
0.45
10.1007/s41095-021-0257-1.T003Comparison of physical measures , , and , geometric measures and , and running time and . For each model, we show Ma et al.’s result (first row), our result (second row), and Liu et al.’s result (third row). For each quality measure, lower values indicate higher quality. is the number of quadrilateral elements. is the running time (in second) to calculate the CDF and is the running time (in second) to extract the PQ mesh