Abstract
We aim to accelerate the linear equation solver for crack growth simulation based on the phase field model. As a first step, we analyze the properties of the coefficient matrices and prove that they are symmetric positive definite. This justifies the use of the conjugate gradient method with the efficient incomplete Cholesky preconditioner. We then parallelize this preconditioner using so-called block multi-color ordering and evaluate its performance on multicore processors. The experimental results show that our solver scales well and achieves an acceleration of several times over the original solver based on the diagonally scaled CG method.
Keywords:
crack growth simulation; phase field model; conjugate gradient method; incomplete Cholesky factorization; parallelization; block red-black ordering; performance evaluation MSC:
15A06; 35F61; 65F08; 65M60; 74R99; 74S05
1. Introduction
Crack growth is a ubiquitous phenomenon that affects the strength and functions of materials and structures. Since cracks can grow very quickly, simulation is a useful tool to study their growth process in detail. Simulation can also be used to predict the generation of cracks under given stresses or other conditions. In the conventional method of crack growth simulation, the finite element method (FEM) is used and the mesh is regenerated at every time step so that the mesh boundary conforms to the crack boundary. However, this incurs huge computational cost. Moreover, to determine the direction of crack growth, it is usually necessary to evaluate the total energy for various possible scenarios. This also adds to the computational cost.
To resolve these problems, a crack growth simulation method based on the phase field model has been proposed [1,2,3,4]. In this model, a new continuous dependent variable called the phase field [5,6] is introduced in addition to the displacement . This variable expresses the degree of the crack at each point: z≃0 if there is no crack and z≃1 if there is a crack. Moreover, a partial differential equation (PDE) describing the time evolution of is also derived along with that of . This makes it possible to determine the direction of crack growth without the total energy evaluations. Hence, the method is a promising candidate for real-time three-dimensional crack growth simulation. Takaishi et al. implemented a crack growth simulation program based on this method and showed that it works well in various examples. For evaluation purposes, a two-dimensional FreeFEM code based on the method is also available.
When implementing this method, the time-discretization of the PDEs both for and is usually done with the semi-implicit method to ensure numerical stability. In that case, the time taken to solve the resulting linear simultaneous equations is often dominant in the total computation time. Takaishi et al.’s simulation program uses the conjugate gradient (CG) method with a diagonal scaling preconditioner for both of the equations for and , which is a simple preconditioner applicable to a wide class of matrices but is not very efficient. The reason for using this preconditioner is that the properties of the coefficient matrices have not been fully understood yet.
In this paper, we aim to accelerate this linear equation solver by employing a more powerful preconditioner. This will help to speed up the linear equation solution that accounts for a large part of the computing time and open a way to solve larger scale and more realistic problems. To this end, we make the following contributions. First, we analyze the properties of the coefficient matrices obtained by applying semi-implicit time discretization and space discretization by FEM to the PDEs for and . We show that, under appropriate boundary conditions, both of these coefficient matrices become symmetric positive definite (SPD). This justifies the use of the incomplete Cholesky (IC) preconditioner, which is more powerful than diagonal scaling. Second, we show that the IC preconditioner can be parallelized efficiently using the block multi-color ordering proposed by Iwashita et al. [7,8]. In fact, our numerical experiments suggest that the number of CG iterations increases only slightly, if at all, by this parallelization method compared to the sequential case. Finally, we optimize several performance parameters such as the block division scheme and show that the resulting parallel solver is several times faster than the diagonally scaled CG solver on multicore processors. Our results will be applicable to crack growth simulation in a variety of fields in science and engineering, such as the prediction of cracking in buildings and bridges and the analysis of solder cracking in circuit boards [2].
The rest of this paper is structured as follows. In Section 2, we briefly describe the crack simulation method based on the phase field model and its space and time discretization. In Section 3, the properties of the coefficient matrices arising from the discretization are analyzed, and their symmetric positive definiteness is proved under certain conditions. Section 4 describes the parallelization of the IC preconditioner using block multi-color ordering. Numerical results are given in Section 5. Finally, Section 6 concludes the paper.
2. Crack Growth Simulation Based on the Phase Field Model
In this section, we briefly explain the crack growth simulation method based on the phase field model, which was proposed by Takaishi and Kimura [3]. We begin with the two-dimensional case and then proceed to the three-dimensional case.
2.1. The Two-Dimensional Case
Let us consider crack growth in a thin panel as shown in Figure 1. Here, we focus on the so-called mode 3 crack, in which the displacement of the panel is in the direction perpendicular to the panel. Thus, we treat the problem as two-dimensional and denote the displacement at a point by a scalar variable . We denote the region by , its boundary by , and the crack, which is modeled as a curve on , by . Hence, is discontinuous across . In the example shown in Figure 1, the Dirichlet boundary condition is imposed on , while the Neumann boundary condition is imposed on .
Figure 1.
A two-dimensional region and crack .
The basic idea of the crack growth simulation method to be described below goes back to Griffith [9]. He proposed the expression of the total energy of the system as a sum of the elasticity energy and the surface energy due to the existence of a crack. Both of these energies depend on the crack , as well as on , so we denote them as and . Griffith assumed that crack growth occurs if the total energy decreases due to that factor. In the two-dimensional case, and can be written as follows [1]:
where is fracture toughness at and is one of Lamé’s constants. Equation (1) means that the elasticity energy is expressed as an integral of over the entire region , excluding the crack . This is because the difference of u across does not contribute to the elasticity energy. On the other hand, the surface energy (2) is expressed as a line integral along the crack.
While in principle (1) and (2) can be used to study the development of crack , they are not convenient for numerical computation because the regions of the integral depend on and change from step to step. To resolve this problem, Bourdin et al. [10] introduced a phase field variable that expresses the degree of crack at : z≃0 if there is no crack and z≃1 if there is a crack. is assumed to be a smooth function of , and the transition between and is assumed to occur across a narrow region of width , where is a regularization parameter [11]. Under these assumptions, Bourdin et al. propose the use of the following regularized total energy functional instead of :
In this formulation, the region of the integral is the entire region for both the elasticity and surface energies, which greatly simplifies the numerical procedure.
For the efficient computation of and based on (3), Takaishi and Kimura [3] proposed the use of the gradient flow
where is a virtual time parameter and and are time constants. It can easily be shown that if and evolve according to (4), the total energy functional (3) decreases monotonically. Thus we can expect that the (local) minimum of is reached as . Furthermore, if and are sufficiently large, and are expected to reach the minimizer of for given external conditions such as the boundary conditions and external forces (if any) very quickly. Thus, we can regard and determined by (4) as instantaneous reactions to the external conditions and (4) as approximately describing the time evolution of and . By computing and explicitly, we obtain the following set of PDEs:
where we changed to t and set for simplicity. denotes the Dirichlet boundary condition that causes the development of the crack. The symbol in the second equation means , which expresses the fact that a crack does not vanish once it is created [12]. See [13] for the treatment of partial differential equations with such terms. denotes the partial derivative in the direction of the outgoing normal vector.
Crack growth simulation based on (5) has the following advantages:
- The direction of crack growth is automatically determined by the PDEs. Hence, total energy evaluation under multiple possible scenarios, which is needed in simulation methods based directly on (3), is not necessary;
- By introducing the phase field variable and the regularization parameter , the divergence of the stress at the tip of the crack is kept to a level manageable by numerical methods;
- It is not necessary to regenerate the mesh at every time step to conform to the crack boundary.
Our theoretical analysis and numerical experiments in the two-dimensional case are based on these PDEs.
2.2. The Three-Dimensional Case
In the three-dimensional case, the displacement becomes a vector field variable , where . The phase field variable is still a scalar field variable. Using the same idea as in the previous subsection, we can derive the set of PDEs corresponding to (5). In the following, we assume isotropic materials for simplicity. First, let us define the strain tensor and the stress tensor . These tensors are connected by Hooke’s law, which has the following form in the case of isotropic materials:
where and are Lamé’s constants and is Kronecker’s delta. We also write the stress tensor as
Using these tensors, the elasticity energy density , which corresponds to in the two-dimensional case, can be defined as follows:
Using this, the regularized total energy functional is defined as
which has the same form as (3) except that is replaced with . Note that now is a three-dimensional region and denotes a volume integral. By considering the gradient flow as in (4), we obtain the following set of PDEs after some calculations [2]:
Here,
and
where denotes the unit normal vector. Note that the first equation of (10) can also be written as
This can be verified directly using the definitions of , and . The fourth equation of (10) is often expressed as
and is known as the stress-free boundary condition.
2.3. Temporal Discretization
For the temporal discretization of (5) and (10), we use a semi-implicit method. More specifically, to compute the solution at time from at time t, we replace u and z in the right-hand side of the equation for by and , respectively. Similarly, in the right-hand side of the equation for , we replace u and z by and , respectively. Thus, in the two-dimensional case, we obtain the following set of equations, which are linear both in and :

Here, (17) corresponds to taking In the numerical simulation; we set , which corresponds to assuming that the displacement responds to the changes of and the boundary conditions instantaneously.
The equations for the three-dimensional case are as follows:

We set also in this case. Using expression (13), Equation (18) can also be written as
where is the jth column of the stress tensor at time .
3. Properties of the Coefficient Matrices Arising from Phase Field-Based Crack Growth Simulation
In this section, we study the properties of the coefficient matrices arising from the finite element discretization of the basic equations for the phase field-based crack growth simulation. In particular, we prove that these matrices become symmetric positive definite under certain assumptions. This is important to be able to apply the efficient incomplete Cholesky preconditioner to these matrices.
3.1. The Two-Dimensional Case
- The weak forms
We start with the time-discretized Equation (15) with . This is a Poisson equation for with variable coefficient , and it is well known that its weak form can be written as follows:
where is a test function with on . Finding satisfying (15) with is equivalent to finding satisfying (22) for arbitrary test functions .
Next, we derive the weak form for (16). By multiplying (16) by a test function , integrating over , using a slight extension of Green’s identity (see Lemma 1),
with , and , and noting that on , we obtain
Equations (17), (22) and (24) constitute the weak forms for the two-dimensional case.
- Properties of the coefficient matrix for
Now, we consider the properties of the matrix obtained by applying the finite element discretization to the weak form (22). Let be a function satisfying the boundary condition () and be basis functions that are zero on . We approximate by , which is a linear combination of these functions:
Inserting this into (22) and choosing the test function as , we obtain
By defining the matrix and the vector by
and letting , (26) can be written as follows.
Since from (27), it is clear that C is a symmetric matrix. Moreover, for an arbitrary nonzero vector , we have
Noting that is not identically zero from the linear independence of , we know that the integral in the right-hand side is positive as long as , . Hence, C is positive definite, and we obtain the following theorem.
Theorem 1.
If , , then the coefficient matrix C of the equation for is symmetric positive definite.
- Properties of the coefficient matrix for
For the phase field variable , the boundary condition consists of only the Neumann boundary condition. We therefore choose the basis functions and approximate by the following function:
Inserting this into (24) and choosing the test function as gives
By defining the matrix and the vector by
and letting , we have the following linear simultaneous equation.
Since from (33), E is symmetric. Furthermore, the first term of , which is , is a Gram matrix and is therefore positive definite if is linearly independent. It is also clear that the remaining parts of are also symmetric positive semidefinite. Thus, we arrive at the following theorem.
Theorem 2.
The coefficient matrix E of the equation for is symmetric positive definite.
3.2. The Three-Dimensional Case
We next consider the three-dimensional case described by (18) through (21). First, we prepare the following lemma.
Lemma 1.
Let Ω be a bounded region in the three-dimensional space, Γ its boundary, and the outward normal vector on Γ. Additionally, let , and be scalar fields and be a vector field defined in a region containing Ω. Then, the following equations hold:
where denotes the surface integral on Γ.
Proof.
- The weak forms
We derive the weak form for by considering a vector test function that becomes on , computing its inner product with both sides of (21), assuming , and integrating the results over (this is equivalent to deriving a weak form for each component of (18) by multiplying it by a scalar test function and integrating the result over . This is because if we choose a special vector test function with its y and z components identical to zero, we obtain the same result as if we multiply the x component of (18) by a scalar test function). By letting , and () in (36) and summing both sides over q, we have
where, in the second equality, we use the fact that on and on and therefore the surface integral on vanishes. By equating the right-hand side of (39) to zero, we obtain the weak form for .
The weak form for is exactly the same as (24) for the two-dimensional case, except that is replaced with .
- Properties of the coefficient matrix for
For finite element discretization of the weak form for , we approximate each component () of as a linear combination of a function satisfying the boundary condition on and basis functions that become zero on :
Now, we choose as the test function a function whose ith element is and whose other elements are 0. Thus, . Inserting this along with (40) and the definition of into the weak form for gives
By moving the terms containing the unknowns to the left-hand side and the other terms to the right-hand side, we have
Equations (39) for and constitute linear simultaneous equations of order in . Let us write this equation as
where C is a coefficient matrix, is a -dimensional unknown vector and is a -dimensional right-hand side vector. To investigate the positive definiteness of C, we compute , where is a nonzero -dimensional vector. To this end, we replace with in the left-hand side of (41), multiply the result with and sum over i and k. Then, after some calculations, we obtain
It is clear from the expression in the middle that C is symmetric, since interchanging and leaves it invariant. Furthermore, if , , we have from the last expression, so C is also positive semidefinite.
Finally, we investigate whether can occur for some . By writing and , we can rewrite (43) as
For the right-hand side to be zero, under the assumption that , , must be identically zero for . This means that the strain tensor computed from can have only a rotational component. However, if the target solid is fixed at three or more points, no such rotation is possible, and therefore the vector field must be identical to zero, implying that . Thus, we arrive at the following theorem.
Theorem 3.
If , , then the coefficient matrix C of the equation for is symmetric positive definite.
- Properties of the coefficient matrix for
The weak form for in the three-dimensional case is identical to that of the two-dimensional case except that is replaced with . Since is nonnegative as well as , by repeating the same argument that led to Theorem 2, we obtain the following theorem:
Theorem 4.
The coefficient matrix of the equation for is symmetric positive definite.
So far, we have assumed that both and are constants over . However, a close examination of the derivation of Theorems 3 and 4 reveals that they are valid even when and are continuous functions of . In some applications, and might have discontinuities. In such a case, we can approximate them with smooth functions of , by using sufficiently fine mesh around the discontinuities.
4. Application of the Incomplete Cholesky Preconditioner and Its Parallelization
Now that we have established that the coefficient matrices are symmetric positive definite, we can apply the IC preconditioner, which is more effective than diagonal scaling. In this section, we first describe the IC conditioner briefly and then explain how to parallelize it using the block multicolor ordering proposed by Iwashita et al.
4.1. The Incomplete Cholesky Preconditioner
Let be a sparse symmetric positive definite matrix and consider solving a linear simultaneous equation by the conjugate gradient (CG) method. In the preconditioned conjugate gradient method, one applies the CG method to the modified equation , whose coefficient matrix is again SPD. Here, is a nonsingular matrix designed so that has a smaller condition number than A. Thus, the convergence of the CG method is accelerated. The diagonal scaling preconditioner uses as K. This preconditioner is simple and applicable to a wide class of matrices but not as effective in reducing the number of iterations of the CG method.
In this study, we use a more powerful preconditioner based on the incomplete Cholesky decomposition without fill-ins (the IC(0) decomposition). In this decomposition, we compute the Cholesky decomposition of A approximately by allowing the element of the approximate Cholesky factor to be nonzero only when . Thus, fill-ins in the Cholesky decomposition are suppressed, and the computational cost and the memory requirement are reduced. The algorithm of the IC(0) decomposition is shown as Algorithm 1. Here, in the sums and , zero terms are skipped to reduce the computational work.
| Algorithm 1: IC(0) decomposition |
| 1: for to n do 2: 3: for to n if do 4: 5: end for 6: end for |
In the incomplete Cholesky preconditioner, computed by Algorithm 1 is used as K. While satisfies only an approximate relation , it is often a sufficiently good approximation to the true Cholesky factor to make much better conditioned than A.
For a sparse matrix A arising in the finite element method, a simplified IC(0) decomposition is sometimes used instead of Algorithm 1. In this variant, the off-diagonal elements are not updated and the fourth line of Algorithm 1 is replaced with . We use this variant in this study.
4.2. Parallelization by the Block Multi-Color Ordering
The IC(0) decomposition algorithm inherits the sequential nature of the original Cholesky decomposition. Suppose that and . Then, since depends on by line 2 of Algorithm 1 and depends on by line 4, depends on . In the finite element method using triangular (or tetrahedral) elements and piecewise linear basis functions, the matrix element is nonzero if and only if the nodes i and j belongs to the same element. The dependency thus caused gives rise to a difficulty in parallelizing the IC(0) decomposition.
One of the techniques to resolve this problem is multi-color ordering [14]. In this ordering strategy, we assign colors to the nodes in such a way that nodes belonging to the same element have different colors and the number of required colors is minimal. Then, we renumber the nodes so that the nodes with color 1 are numbered first, those with color 2 are numbered next, and so on. Then, if nodes i and j have the same color, they do not belong to the same element, and therefore . Thus, the computation of and can be done in parallel.
However, it has been pointed out that this reordering can degrade the quality of the IC(0) preconditioner, thereby increasing the number of CG iterations. Consult [15] for more details about this phenomenon. As a remedy, Iwashita et al. proposed block multi-color ordering [7,8], which partitions the set of nodes into blocks and applies the multi-color ordering to the blocks rather than to the individual nodes. It is known that this modification is effective in retaining the quality of the IC(0) preconditioner, since the ordering within each block can be made the same as the natural ordering. The block multi-color ordering applied to a two-dimensional triangular mesh and the nonzero pattern of the resulting matrix are depicted in Figure 2 and Figure 3, respectively. Here, , and thus the matrix has a block structure. Each of the four diagonal blocks has a block diagonal structure, reflecting the fact that there are two blocks of each color. Thus, the IC(0) decomposition of these two (small) diagonal blocks can be performed in parallel. We use this ordering strategy in our numerical experiments.
Figure 2.
Block multi-color ordering for a two-dimensional triangular mesh.
Figure 3.
The coefficient matrix ordered by block multi-color ordering.
5. Numerical Results
In this section, we apply the conjugate gradient method with the IC(0) preconditioner to the linear simultaneous equations to compute the time evolution of and in the phase field-based crack growth simulation. We parallelize the IC(0) preconditioner using the block red-black ordering and evaluate its parallel performance, as well as the convergence acceleration effect compared with the diagonal scaling preconditioner. Both two and three-dimensional problems are used as test problems.
5.1. The Two-Dimensional Case
We used the 2-D phase field-based crack growth simulation code developed by Takaishi et al. as a basis and replaced its linear equation solver, which uses the CG method with diagonal scaling, with our solver. Our solver is based on the CG method with IC(0) preconditioning and is thread-parallelized using multi-color ordering. We used four colors, as in Figure 2, and set the number of blocks equal to four times the number of threads. The program was written in C and OpenMP, and all computations were performed in double precision arithmetic. In the numerical experiments in this subsection, we used an Intel Xeon processor E5-2660 v2, which has 10 cores, and Intel C Compiler Ver. 16.0.0.109 with the -O3 option.
The computational region used in the numerical experiments is as shown in Figure 1. It is a square region (panel) with the initial crack running from the left edge to the center. The Dirichlet boundary conditions, which represent the forces to widen the crack, are applied to the upper and lower edges. More specifically, the problem is defined as follows.
- Computational region: .
- Dirichlet boundary: .
- Neumann boundary: .
- Time step: .
- Parameters: .
- Initial conditions: , where .
- Convergence criterion of the CG method: relative residual .
We first checked the positive definiteness of the coefficient matrix C for (see (27)) using a small problem with to mesh. Note that the matrix E for (see (33)) is obviously positive definite because it is an perturbation of the positive definite Gram matrix. It was confirmed by the numerical experiment that the smallest eigenvalue of C is always positive, and thus the matrix C is positive definite. The smallest eigenvalue and the largest eigenvalue of C for each mesh before, during and after crack growth are shown in Table 1. We also show the change of the condition number of C as the crack grows in Figure 4. It can be seen that the condition number leaps up suddenly around , where the crack grows rapidly. It seems that this is because the area of is widened, causing the near-singularity of C, as can be inferred from (30).
Table 1.
The smallest and the largest eigenvalues of C for each mesh.
Figure 4.
Time evolution of the condition number of C.
The time evolution of for this problem is shown in Figure 5. Here, the mesh size is and the period of simulation is from to . Until , does not change significantly and only along the line connecting and , showing that the crack exists only in this region. As time passes, the region of extends to the right edge of the region, meaning that the panel has broken into two pieces. The evolution of for other initial conditions, which was computed using a FreeFEM code, is shown in Appendix A.
Figure 5.
Time evolution of the phase-field variable .
We next evaluated the parallel acceleration of our linear equation solver by varying the number of threads from 1 to 10. The results for and meshes are shown in Figure 6 and Figure 7, respectively. The number of blocks in the and directions, which we denote by and , are shown in Table 2. These numbers were determined experimentally to achieve the best performance in each case, under the condition that equals four times the number of threads. It can be seen that the solution of the linear simultaneous equations for and z achieves an acceleration of up to 5 and 4 times, respectively, using 10 threads.
Figure 6.
Parallel acceleration for the mesh.
Figure 7.
Parallel acceleration for the mesh.
Table 2.
Optimal combinations of and .
Finally, we compare the execution time of our solver with that of the original solver using the diagonal scaling preconditioner. The results are shown in Figure 8 and Figure 9. Compared with the original solver, our solver achieved an acceleration of 7.2 and 7.4 times for the and meshes, respectively.
Figure 8.
Execution time for the mesh.
Figure 9.
Execution time for the mesh.
5.2. The Three-Dimensional Case
For the three-dimensional case, we again used Takaishi et al.’s code and replaced its linear equation solver with our parallel CG solver with IC(0) preconditioning and multi-color ordering. We used a semi-structured mesh as shown in Figure 10, which is unstructured in the plane and is structured in the direction, sliced it horizontally into 2× (number of threads) panels, and colored them in an alternating manner using two colors. Then, each pair of panels was allocated to one thread for parallel execution. In the numerical experiments in this subsection, we used an Intel Xeon Gold 6148 Processor with 20 cores (1 node of the Grand Chariot supercomputer at the Hokkaido University Information Initiative Center) and Intel C Compiler Ver. 18.0.3 with the -O3 option.
Figure 10.
Semi-structured mesh for the 3-D simulation and its ordering.
The test problem is crack growth in a rectangular parallelepiped region, defined as follows.
- Computational region: ;
- Dirichlet boundary: ;
- Dirichlet boundary: ;
- Neumann boundary: ;
- Time step: ;
- Parameters: ;
- Initial conditions: , where ;
- Convergence criterion of the CG method: relative residual .
The parallel acceleration of our solver for the and meshes is shown in Figure 11 and Figure 12, respectively. For the latter mesh, the solution of the linear system for and z was accelerated by up to 6.7 and 4.4 times, respectively. We also show the acceleration of each component of our solver and the breakdown of the execution time in Figure 13, Figure 14, Figure 15 and Figure 16. Our solver consists of a matrix-vector product, forward and backward substitutions corresponding to the application of and , respectively, and other parts such as vector additions, dot products and computation of norms. Figure 13 and Figure 15 show that the matrix-vector product and the forward/backward substitutions are reasonably well accelerated, but Figure 14 and Figure 16 reveal that the other parts are not accelerated at all. The latter are difficult to parallelize efficiently because they are vector operations with small computational work and a relatively large amount of data transfer. If this part could be improved, our solver could achieve further acceleration.
Figure 11.
Parallel acceleration for the mesh.
Figure 12.
Parallel acceleration for the mesh.
Figure 13.
Parallel acceleration of each component for the mesh.
Figure 14.
Breakdown of the execution time for the mesh.
Figure 15.
Parallel acceleration of each component for the mesh.
Figure 16.
Breakdown of the execution time for the mesh.
Finally, we compare the execution time of our solver with that of the original solver in Figure 17 and Figure 18. Thanks to the use of the IC(0) preconditioner with multi-color ordering, our solver attains an acceleration of 6.1 and 8.3 for the and meshes, respectively.
Figure 17.
Execution time for the mesh.
Figure 18.
Execution time for the mesh.
6. Conclusions
In this paper, we accelerated the linear equation solution part in phase field-based crack growth simulation using the conjugate gradient method with IC(0) preconditioning. To this end, we first analyzed the properties of the coefficient matrices both for the displacement and the phase field and proved that they are symmetric positive definite under certain conditions. Thus, the use of the IC(0) preconditioning is justified. Then, we parallelized the IC(0) preconditioner using the block multi-color ordering and evaluated its performance on multicore processors. The experimental results show that our solver scales well both for the two and three-dimensional problems and achieves an acceleration of several times over the original solver based on the diagonally scaled CG method. Our future work will include the distributed-memory parallelization of our solver and its application to real-world crack growth problems.
Author Contributions
Conceptualization, T.T. and Y.Y.; theoretical analysis, G.I. and Y.Y.; coding, G.I. and T.T.; parallelization and optimization, G.I.; numerical experiments, G.I. All authors have read and agreed to the published version of the manuscript.
Funding
This study is partially supported by JSPS KAKENHI Grant Numbers 17H02828, 17K19966 and 19KK0255.
Institutional Review Board Statement
Not applicable.
Informed Consent Statement
Not applicable.
Data Availability Statement
The parallel ICCG solver developed in this work, as well as the FreeFEM code used in the Appendix A, is available from the authors upon request. Some of these programs are also downloadable from the following URL: https://github.com/yusakuyamamoto/Crack-growth-simulation, accessed on 20 August 2021.
Acknowledgments
The authors thank Takaharu Yaguchi of Kobe University and Shuhei Kudo of The University of Electro-Communications for valuable discussion. They are also grateful to Takeshi Fukaya of Hokkaido University for providing computational environments for the three-dimensional problem. Part of our numerical experiments were performed on the Grand Chariot supercomputer at Hokkaido University Information Initiative Center.
Conflicts of Interest
The authors declare no conflict of interest.
Appendix A. Two-Dimensional Crack Growth Simulation for Various Initial Conditions
Here, we present the results of the two-dimensional crack growth simulation for various initial conditions. The computational region is the same as that used in Section 5.1, and a FreeFEM [16] code was used for the simulation. The initial conditions used are as follows:
- 1.
- 2.
- 3.
Here, the function is as defined in Section 5.1 and the initial condition for u is the same as that used in Section 5.1. Cases 1 and 2 correspond to the case of two initial cracks: one at the left and another at the right. The vertical distance between the cracks is small for case 1 and large for case 2. Case 3 corresponds to the case of three initial cracks: two at the left and one at the right. The time evolution of for these cases is shown in Figure A1, Figure A2, Figure A3 as contour maps. We used a mesh for cases 1 and 2. For case 3, it turned out that this mesh is too coarse, so we used a mesh. It can be seen that all of the simulations give physically plausible results.
Figure A1.
Time evolution of the phase-field variable (Case 1).
Figure A2.
Time evolution of the phase-field variable (Case 2).
Figure A3.
Time evolution of the phase-field variable (Case 3).
References
- Francfort, G.A.; Marigo, J.-J. Revisiting Brittle Fracture as an Energy Minimization Problem. J. Mech. Phys. Solids 1998, 46, 1319–1342. [Google Scholar] [CrossRef]
- Kimura, M.; Takaishi, T.; Alfat, S.; Nakano, T.; Tanaka, Y. Irreversible phase field models for crack growth in industrial applications: Thermal stress, viscoelasticity, hydrogen embrittlement. SN Appl. Sci. 2021, 3, 781. [Google Scholar]
- Takaishi, T.; Kimura, M. Phase field model for mode III crack growth. Kybernetika 2009, 45, 605–614. [Google Scholar]
- Takaishi, T. Numerical simulations of a phase field model for mode III crack growth. Trans. Jpn. Soc. Ind. Appl. Math. 2009, 19, 351–369. (In Japanese) [Google Scholar]
- Kobayashi, R. Modeling and numerical simulations of dendritic crystal growth. Phys. D 1998, 63, 410–423. [Google Scholar] [CrossRef]
- Provatas, N.; Elder, K. Phase-Field Methods in Materials Science and Engineering; Wiley-VCH: Weinheim, Germany, 2010. [Google Scholar]
- Iwashita, T.; Nakashima, H.; Takahashi, Y. Algebraic block multi-color ordering method for parallel multi-threaded sparse triangular solver in ICCG method. In Proceedings of the 2012 IEEE 26th International Parallel and Distributed Processing Symposium, Shanghai, China, 21 May 2012; pp. 474–483. [Google Scholar]
- Iwashita, T.; Li, S.; Fukaya, T. Hierarchical block multi-color ordering: A new parallel ordering method for vectorization and parallelization of the sparse triangular solver in the ICCG method. CCF Trans. High. Perform. Comput. 2020, 2, 84–97. [Google Scholar] [CrossRef]
- Griffith, A.A. The Phenomena of Rupture and Flow in Solids. Phil. Trans. R. Soc. Lond. 1921, A221, 163–198. [Google Scholar]
- Bourdin, B.; Francfort, G.A.; Marigo, J.-J. Numerical Experiments in Revisited Brittle Fracture. J. Mech. Phys. Solids 2000, 48, 797–826. [Google Scholar] [CrossRef]
- Ambrosio, L.; Tortorelli, V.M. On the approximation of free discountinuity problems. Boll. Un. Mat. Ital. 1992, 7, 105–123. [Google Scholar]
- Akagi, G.; Kimura, M. Unidirectional evolution equations of diffusion type. J. Differ. Equ. 2019, 266, 1–43. [Google Scholar] [CrossRef] [Green Version]
- Visintin, A. Models of Phase Transitions; Birkhaeuser: Basle, Switzerland, 1996. [Google Scholar]
- Saad, Y. Iterative Methods for Sparse Linear Systems; SIAM: Philadelphia, PA, USA, 2003. [Google Scholar]
- Iwashita, T.; Nakanishi, Y.; Shimasaki, M. Comparison criteria for parallel orderings in ILU preconditioning. SIAM J. Sci. Comput. 2005, 26, 1234–1260. [Google Scholar] [CrossRef]
- FreeFEM. Available online: https://freefem.org/ (accessed on 20 August 2021).
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations. |
© 2021 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (https://creativecommons.org/licenses/by/4.0/).