Abstract

Smoothing is one of the basic procedures for improvement of mesh quality. In this paper, a novel and efficient smoothing approach for planar and surface mesh based on element geometric deformation is developed. The presented approach involves two main stages. The first stage is geometric deformation of all the individual elements through a specially designed two-step stretching-shrinking operation (SSO), which is performed by moving the vertices of each element according to a certain rule in order to get better shape of the element. The second stage is to determine the position of each node of the mesh by a weighted average strategy according to quality changes of its adjacent elements. The suggested SSO-based smoothing algorithm works efficiently for triangular mesh and can be naturally expanded to quadrilateral mesh, arbitrary polygonal mesh, and mixed mesh. Combined with quadratic error metric (QEM), this approach may be also applied to improve the quality of surface mesh. The proposed method is simple to program and inherently very suitable for parallelization, especially on graphic processing unit (GPU). Results of numerical experiments demonstrate the effectiveness and potential of this method.

1. Introduction

As an elementary technique, mesh quality improvement has been widely used in many applications, such as mesh generation [15], mesh simplification [68], dynamic grid or mesh deformation [914], and other mesh processing procedures. Due to its importance, mesh quality improvement technique has received a lot of attention and great progress has already been made in recent years [1534]. Mesh improvement approach can be basically divided into two main categories, topological optimization and smoothing (also called geometrical optimization). Topological optimization changes the topology of a mesh, that is, the node-element connectivity relationship, while smoothing or geometrical optimization improves mesh quality by simply moving or adjusting node positions without changing the topology of mesh. This paper will focus on the latter, smoothing.

Theoretically the optimization-based smoothing procedure [16, 21, 22, 29] would lead to better results. However, the capacity of improvements is limited when applying such kind of computationally expensive procedure to practical problem. In many works, for example, in [18], smoothing was commonly performed by Laplacian smoothing technique, that is, simply shifting each interior node (free vertex) to the centroid of the surrounding polygon or polyhedron. Although it is computationally inexpensive and easy to implement, however, it may produce occasionally invalid or illegal elements that are unacceptable in numerical analysis. Chen and Xu [25] presented the concept of optimal Delaunay triangulation and developed a quality smoothing scheme for triangular mesh [26] by minimizing the interpolation error among all triangulations with the same number of vertices in the local patch. This optimization-based smoothing method [2628] could solve the corresponding optimization problem explicitly and thus the computational cost is as low as that of Laplacian smoothing. However, this method is only suitable for triangular mesh and cannot be expanded to other types of mesh.

Recently Vartziotis et al. [33, 34] developed a novel smoothing method named GETMe (geometric element transformation method) for triangular and quadrilateral mesh based on element geometric transformation. This method first improves element shape by two-step geometric transformation and then updates positions of moved nodes to achieve the purpose of smoothing. It is not necessary to construct or solve optimization problem, so high efficiency of the method is expected. Test results show that the method achieves excellent performance in effect of smoothing and algorithm efficiency. Unfortunately, it is unsuccessful to expand this approach to polygonal elements with more than four edges (e.g., pentagon and hexagon).

Inspired by the work of Vartziotis et al. [33, 34], this paper proposes a new and efficient smoothing approach for planar and surface mesh based on element geometric deformation. The approach includes two main stages. In the first stage, for each individual element, all vertices are moved by a purposely designed two-step stretching-shrinking operation (SSO) in order to get better shape of the element. The second stage is to determine the position of each node of the mesh by a weighted average strategy according to quality changes of its adjacent elements. The proposed SSO-based smoothing approach has the universal scheme and can be conveniently expanded from triangular mesh to quadrilateral mesh, arbitrary polygonal mesh, and mixed mesh. Combined with QEM, this approach may be also applied to improve the quality of surface mesh. Furthermore, the suggested method is simple to program and inherently very suitable for parallelization, especially on GPU.

In the rest of this paper we first review the idea and basic procedures of GETMe [33, 34] and then the two-step SSO and the corresponding smoothing approach for planar mesh are presented. Next the smoothing approach for surface mesh is proposed by introducing QEM. Finally, some numerical experiments are given to demonstrate the effectiveness and feasibility of the method.

Recently a novel smoothing approach named GETMe (geometric element transformation method) for triangular and quadrilateral mesh was proposed by Vartziotis et al. [33, 34]. This approach first improves element shape by two-step geometric transformation and then updates positions of moved nodes to achieve the purpose of smoothing. It is not necessary to construct or solve optimization problem, so high efficiency of the method is expected.

The method first operates on a counterclockwise oriented triangle with pairwise disjoint vertices , . Taking the edge of the triangle, for example, rotating it by an angle clockwise with as the center, then a new vertex defined as the intersection of two subsidiary lines (the perpendicular of in and the edge rotated clockwise by angle with as the center) is obtained bywhere and complex numbers are used to simplify notation.

Applying the same procedure to the other two edges, a clockwise rotated new triangle with the vertices , , and is obtained. To avoid the rotational effect, a similar counterclockwise transformation with angle by is applied to get a new triangle with the vertices , , and .

It is proved that such geometric element transformations preserve the element centroid, and an arbitrary triangle will gradually converge to an equilateral triangle after enough successive transformations [33].

The above transformations usually enlarge the size of the original triangle. In the event that the element does not have any boundary nodes, scaling is applied so that the new element preserves its original perimeter. If an edge of the element belongs to a boundary, the element is scaled according to the length of this edge and is moved so that the nodes belonging to this edge return to their original positions [33].

This geometric transformation can be generalized leading to an additional degree of freedom in controlling the speed in which an element becomes regular [34]. For quadrilateral elements, similar transformation can be also conducted [34]. After successively performing such transformation, an arbitrary quadrilateral will become a regular square.

In [33], the authors suggested a sequential GETMe approach based on successively improving elements with the lowest quality to complete smoothing of the mesh. Initially, the poor quality elements are rated. During the sequential process, the transformation algorithm is applied to the “worst” element, until the mesh quality reaches the desired level or termination criteria are met. After each transformation, all the affected elements are updated. Alternatively, a simultaneous GETMe approach [34] was presented for smoothing mixed planar meshes. It is based on transforming all elements simultaneously. Updated node positions are obtained as weighted means of the transformed element nodes.

Testing shows that the method achieves excellent performance in the effect of smoothing and algorithm efficiency. Unfortunately, it is unsuccessful to expand this approach to polygonal elements with more than four edges (e.g., pentagon and hexagon).

3. Smoothing Algorithm for Planar Mesh

A new and universal smoothing approach for planar triangular mesh based on element geometric deformation is first proposed in this section. The presented approach includes two main stages. The first stage is geometric deformation of all the individual triangles. For each triangle, the vertices are moved by a specially designed two-step stretching-shrinking operation (SSO) in order to get better shape of the element. The second stage is to determine the position of each node of the mesh by a weighted average strategy according to the quality changes of its adjacent triangles. Next, the geometric deformation operation for triangle is first proposed and then is followed by its natural extensions to quadrilateral and arbitrary polygon.

3.1. Geometric Deformation of Single Triangles

As for the algorithm in the first stage, geometric deformation of each individual triangle can be performed by two operations, stretching and shrinking. The stretching operation will enlarge the size of the original triangle but change the element towards regular shape. In order to preserve its original size, a scaling or shrinking operation must be applied to the enlarged triangle with better shape. The detail of SSO is given as follows.

For a counterclockwise oriented triangle with pairwise disjoint vertices , , the stretching operation is performed by pulling each vertex out along the perpendicular direction of its opposite edge (see Figure 1).

Then we get an enlarged new triangle with the vertices calculated bywhere can be intuitively understood as a stretching factor to control the degree of geometric stretching. Large value of means more significant improvement for element shape or quality. There are many choices to define . Here, the following expression in terms of the average length of the original element and the quality measurement   , takes the value of 1 for regular element and 0 for degenerated element) is adopted to reflect the fact that only small stretching is needed when the element approaches to regular shape ( gets close to 1):

In (4), the quality measurement for triangle can be taken as , where and represent the radius of incircle and circumcircle of the triangle, respectively.

After preforming the stretching operation, the shape or quality of the original poor triangle can be significantly improved. This procedure, however, will usually enlarge the size of the original triangle. In order to preserve its original size, a scaling or shrinking operation shown in Figure 2 must be applied to the enlarged triangle with better shape.

The shrinking operation does not change the shape of the element. In general, there are two ways for shrinking, keeping perimeter or area of the element unchanged. In practice, test results show that there is no big difference between these two ways. In this paper, for the reason of computational cost, we keep the perimeter (the average length) of the element unchanged before and after deformation. In addition, the shrinking operation needs to keep the position of centroid unchanged for each element. Thus, we obtain the shrinking triangle with new vertices ofwhere and represent the centroid of the triangle before and after stretching, respectively. The shrinking factor is defined as the ratio of the average length of the element before and after stretching.

Stretching and shrinking operations make up a complete geometric element deformation process. The final shape of the triangle is only determined by the stretching factor and the shrinking factor together, which can be easily calculated by coordinates of the vertices.

Figure 3 shows the geometric deformation process of a triangle. A poor shape triangle gradually becomes regular after 5 successive cycles of SSO.

The proposed SSO is numerically efficient and is more simple to implement compared with the GETMe method. More important, the approach has the universal scheme and can be conveniently expanded to quadrilateral elements and arbitrary polygonal elements.

3.2. Geometric Deformation of Single Quadrilaterals

The SSO for quadrilaterals is a natural extension of the above procedure. For a counterclockwise oriented quadrilateral with four vertices , , shown in Figure 4, stretching operation is performed by pulling each vertex out along the perpendicular direction of the diagonal which links its two adjacent vertices. This operation will usually enlarge the size of the original element; in the meantime, the shape or quality of the original poor element can be significantly improved. Similarly, a shrinking operation is also applied to the enlarged element with better shape to preserve its original size.

The complete SSO is formulated bywhere , denote the stretching and shrinking factor and and represent the centroid of the element before and after deformation, respectively. Also the stretching factor is used to control the degree of geometric stretching. For quadrilateral elements, the stretching factor takes the same expression in (4) but replacing by a quality measurement for quadrilaterals.

Figure 5 shows the geometric deformation process of a quadrilateral. A poor shape quadrilateral gradually becomes regular after 5 successive cycles of SSO.

3.3. Geometric Deformation of Arbitrary Polygonal Elements

In accordance with the deformation of quadrilateral elements, the extension of SSO to arbitrary polygonal elements is quite straightforward. For instance, the sketch of stretching deformation for a pentagon is illustrated in Figure 6. One can easily derive the deformation formulation similar to (6).

For such kind of mesh smoothing approach discussed in the following subsection, each element is deformed individually in the first stage, and the only thing we need to do is to perform SSO for each element independently without caring about the connection with its neighbor elements. Therefore, the proposed algorithm has the inherent advantage of dealing with mixed mesh.

3.4. SSO-Based Smoothing Algorithm

This subsection gives the algorithm to complete smoothing approach based on SSO. The weighted average strategy is selected in the second stage to determine the position of each node of the mesh according to the quality changes of its adjacent elements. This strategy is aimed at improving the average quality of the whole mesh, while the quality of bad elements can be also improved. Before updating the positions of nodes, each element needs to conduct SSO independently in the first stage to get the temporary vertices (the vertices of the deformed element with better shape). Then the position of node can be updated by where and denote the corresponding temporary vertex and quality change of the adjacent element , respectively. According to (7), the element with larger change in quality accounts for larger weight in determining the final position of the node, which leads to more emphasis on the transformed nodes of low quality elements.

The main procedure of the SSO-based smoothing algorithm for planar mesh is described as follows.

Algorithm 1 (SSO-based smoothing algorithm for planar mesh). (1)For each node of the mesh, find all of its adjacent elements.(2)For each element, conduct geometric deformation independently by SSO and save the coordinates of all temporary vertices.(3)For each node of the mesh, calculate the weighted average of the corresponding temporary vertices by (7) to get the position of this node.(4)If the mesh quality reaches the desired level or termination criteria are met, stop; otherwise, return to step for next cycle.

The proposed smoothing procedure has a fast convergence speed; usually 10~20 cycles will achieve quite good result. In addition, the main calculations, including SSO for elements and position updating for nodes with the time complexity of , have very good parallelizability inherently. Therefore, it is suitable for developing parallel scheme of the method, especially on GPU. Actually, a GPU implementation is completed by the authors. Some test results given in Section 5 show remarkable speedup gained by GPU parallel technology.

4. Smoothing Algorithm for Surface Mesh

The SSO-based smoothing algorithm can be also applied to surface mesh. Different from planar mesh, we must consider an important issue; that is, the movement of the node is not allowed to deviate from the original surface too much. In this section, we introduce the quadratic error metric (QEM) [6] which has been widely used in surface simplification to control the moving distance of the nodes away from the original surface in the process of geometric deformation.

4.1. The Basic Idea of QEM [6]

It is easy to observe that, in original surface mesh, each node is the solution of the intersection of a set of planes, . Then the QEM of node , , is defined as the sum of squared distances to its planes:

In (8)  , , , represent the coefficients of the plane defined by the equation with ; denotes the augmented coordinate vector of node .

The QEM can be used to describe the deviation degree of a node away from the original surface. Note that the initial value of QEM for each node is 0, since each node in original mesh lies in the planes of all its incident elements. In smoothing of surface mesh, we need to control the value of QEM to ensure that the element geometric deformation is acceptable.

4.2. SSO-QEM Based Smoothing for Surface Mesh

Before performing element geometric deformation to surface mesh, the quadratic error matrix in (8) for each node must be calculated in advance. For each element, construct the plane according to the coordinates of its vertices and find the coefficients of , , , , and then calculate the matrix for each element according to (8). By using the relationship between nodes and faces of the mesh, for each node, find all of its adjacent elements, and then add the matrix of its adjacent elements up to get the error matrix . With the aid of the quadratic error matrix , we can easily calculate the error of the node by (8) when the node is moved during smoothing process. Please note that the quadratic error matrix only needs to be calculated once.

The SSO for element geometric deformation needs to be revised to meet the requirement of surface mesh. For simplicity, we take triangular surface mesh as an example. Figure 7 is a local region of a triangular surface mesh, and the element will be deformed by the geometric transformation. The deformation is restrained in the original plane during the stretching and shrinking operations; namely, the position of each vertex only changes in the original plane of the element.

The stretching operation is exactly the same as that in planar case. The stretching factor is taken as the same expression in (4). The three vertices of the element, respectively, move along the direction normal to their opposite edge. The new positions of can be calculated by (3).

In the scaling or shrinking process, the basic principle remains to keep the centroid of the element unchanged as that in planar case, but the shrinking factor is no longer the same in (5). Representing the three vertices after shrinking with , , and , the total quadratic error due to element deformation can be formulated as

Recalling the SSO formulation in (3) and (5), one can see that the total quadratic error is only decided by the stretching factor and shrinking factor ; that is, Since the stretching factor is given in terms of the average length of the original element and the quality measurement , the total quadratic error of the element is only the function of shrinking factor . The remaining thing we need to do is to find the optimal value of by minimizing the total quadratic error , which can be easily solved by analytical or numerical manner. With the optimal value of obtained, the new positions of can be calculated by (5).

The main procedure of so-called SSO-QEM based smoothing algorithm for surface mesh is summarized as follows.

Algorithm 2 (SSO-QEM based smoothing algorithm for surface mesh). (1)For each element, formulate the equation of the plane according to the coordinates of its vertices, and calculate the matrix according to (8).(2)For each node of the mesh, find all of its adjacent elements; then add the matrix of its adjacent elements up to get the error matrix .(3)For each element, project the coordinates of its vertices to the plane, and then conduct geometric deformation independently by stretching operation; find the optimal value of the shrinking factor by minimizing the total quadratic error ; conduct shrinking operation independently and save the coordinates of all temporary vertices.(4)For each node of the mesh, calculate the weighted average of the corresponding temporary vertices by (7) to get the position of this node.(5)If the mesh quality reaches the desired level or termination criteria are met, stop; otherwise, return to step for next cycle.

With the aid of QEM to control the moving distance of the nodes away from the original surface, the proposed SSO-QEM based smoothing algorithm is able to improve the quality of surface mesh while maintaining the shape of surface as much as possible.

5. Experimental Results

Several examples are selected to demonstrate the effectiveness and efficiency of the proposed approach. Both examples are tested on Windows 7 system with Intel (R) Xeon (R) CPU (2.67 GHz) and 24 GB memory.

First a triangular mesh with 7229 nodes and 13942 elements is tested (see Figure 8). The quality of initial mesh is very poor. Several smoothing methods, including Laplacian method, GETMe method, and the proposed SSO-based method, are conducted to improve the quality of mesh. The experimental results are listed in Table 1. From the results, it can be seen that the proposed SSO-based method has slight advantages over GETMe method in average quality and gives much better result in quality of the worst element. In this test, Laplacian method even gives negative value of the quality, which means invalid or illegal elements are produced.

The second example is a planar quadrilateral mesh shown in Figure 9, with the boundary nodes fixed. The mesh contains 1089 nodes and 1024 elements, and the initial quality is also very poor. The experimental results are listed in Table 2. In this test the performances of the proposed method and GETMe method are almost the same. Both of them give better results in quality of the worst element compared with Laplacian method.

In the following two surface meshes of dragon and bunny [35] (Figure 10) are tested by the proposed SSO-QEM based smoothing approach. The dragon mesh consists of 50000 nodes and 19994 triangular surface elements, while the bunny mesh contains 34835 nodes and 7996 triangular surface elements. Table 3 lists the smoothing results. It can be seen that the proposed SSO-QEM algorithm has obviously improved the quality of each mesh while the surface is well maintained. Here, the geometric error in Table 3, defined as the ratio of Hausdorff distance [7] and the average size of the mesh, is adopted to measure the difference between the new and original surface meshes.

Finally, an example for testing the performance of GPU implementation of the proposed method is given. The code is realized on the platform CUDA 4.0. The type of GPU used for this test is Tesla C2050 (1.15 GHz) with 3034 MB memory. The testing planar mesh consists of 445182 nodes and 887622 triangles. In order to compare the efficiency, 50 cycles or iterations are run on CPU and GPU, respectively (actually it does not need that much of iterations to reach convergence). Table 4 gives the comparison of smoothing result and running time. More than 300 times speedup is gained by GPU implementation which displays great superiority and potential of the proposed method in the aspect of computational efficiency.

6. Conclusions

This paper presents a novel and efficient smoothing algorithm for 2D planar and surface mesh based on element geometric deformation. The main features of the proposed method are summarized as follows.(1)The smoothing of mesh involves two main stages, namely, geometric deformation of all the elements and updating positions of all the nodes. These two stages can be performed independently.(2)The element geometric deformation consists of two operations: stretching and shrinking. The stretching operation changes the shape and improves the quality of the element, while the shrinking operation preserves the centroid and size of the element. These operations mainly involve two parameters, the stretching factor and shrinking factor. As for the algorithm in this paper, the stretching factor is decided by the size and quality of the element, while the shrinking factor for planar mesh is defined as the ratio of the average length of the element before and after stretching. Single elements will converge to regular shape after successively geometric deformations.(3)In the stage of node updating, the final position of each node is calculated by taking weighted average of the corresponding temporary nodes obtained from element stretching and shrinking operations. The element with larger change in quality accounts for larger weight in determining the final position of the node, which leads to more emphasis on the transformed nodes of low quality elements.(4)The proposed SSO-based smoothing approach has the universal scheme and can be conveniently expanded from triangular mesh to quadrilateral mesh, arbitrary polygonal mesh, and mixed mesh. Moreover, each element is deformed individually in the geometric deformation stage without caring about the connection with its neighbor elements; therefore, the proposed algorithm has the inherent advantage of dealing with mixed mesh.(5)The main computation efforts, including SSO for elements and position updating for nodes, have very good parallelizability inherently. It is very suitable for developing parallel scheme of the proposed method, especially on GPU. Some test results show remarkable speedup gained by GPU parallel technology, which is very important for dealing with large scale meshes.(6)For smoothing surface mesh, quadratic error metric (QEM) is introduced to element geometric deformation to control the moving distance of the nodes away from the original surface. The SSO for element geometric deformation only needs slight revision by shifting the shrinking factor, which can be solved by minimizing the total quadratic error due to element deformation.

To conclude, the proposed method has the universal scheme and very simple formulation. It works efficiently for smoothing triangular mesh, quadrilateral mesh, arbitrary polygonal mesh, and mixed mesh. It can be also applied to improve quality of surface mesh by incorporating with QEM. Moreover, it is very suitable for developing parallel implementation. Results of numerical experiments demonstrate the effectiveness and potential of this method. Further study will focus on extensions of the method to mixed volume meshes.

Conflict of Interests

The authors declare that there is no conflict of interests regarding the publication of this paper.

Acknowledgments

The authors would like to thank the support of National Basic Research Program of China (2010CB731503), the National Natural Science Foundation of China (11172004, 10772004), and Beijing Municipal Natural Science Foundation (1102020).