A Parallel Two-Phase Flow Solver on Unstructured Mesh in 3D
Two-phase flow problem plays an important role in many scientific and engineering processes. The problem can be described by a phase-field model consisting of the coupled Cahn-Hilliard and Navier-Stokes equations with the generalized Navier boundary condition. Accurate simulation of the interface and contact line motion requires very fine meshes, and the computation in 3D is even more challenging. Thus, the use of high performance computers and scalable parallel algorithms are indispensable. In this paper, we introduce a finite element method on unstructured 3D meshes with a semi-implicit time integration scheme, and a highly parallel solution strategy using different solvers for different components of the discretization. More precisely, we apply a restricted additive Schwarz preconditioned GMRES method to solve the systems arising from implicit discretization of the Cahn-Hilliard equation and the velocity equation, and an algebraic multigrid preconditioned CG method to solve the pressure Poisson system. Numerical experiments show that the strategy is efficient and scalable for 3D problems with complex geometry and on a supercomputer with a large number of processors.
- S. Balay, S. Abhyankar, M.F. Adams, J. Brown, P. Brune, K. Buschelman, L. Dalcin, V. Eijkhout, W.D. Gropp, D. Kaushik, M.G. Knepley, L.C. McInnes, K.R., B.F. Smith, S. Zampini, H. Zhang, PETSc Users Manual, Technical Report, ANL-95/11 - Revision 3.7, Argonne National Laboratory, 2016Google Scholar
- G. Karypis, V. Kumar, METIS – Unstructured graph partitioning and sparse matrix ordering system, V2.0, Technical Report, 1995Google Scholar
- B.S. Kirk, J.W. Peterson, R.H. Stogner, G.F. Carey, libMesh: A C++ library for parallel adaptive mesh refinement/coarsening simulations. Eng. Comput. 22 (3–4), 237–254 (2006)Google Scholar
- S. Shin, J. Chergui, D. Juric, A solver for massively parallel direct numerical simulation of three-dimensional multiphase flows (2014), arXiv:1410.8568Google Scholar