Parallel Computation of Finite Element Navier-Stokes Codes Using MUMPS Solver

Total Page:16

File Type:pdf, Size:1020Kb

Parallel Computation of Finite Element Navier-Stokes Codes Using MUMPS Solver IJCSI International Journal of Computer Science Issues, Vol. 4, No. 2, 2009 20 ISSN (Online): 1694-0784 ISSN (Print): 1694-0814 Parallel Computation of Finite Element Navier-Stokes codes using MUMPS Solver Mandhapati P. Raju 1 Mechanical Engineering, Case Western Reserve University, Cleveland, Ohio 44106 [email protected] Abstract is to use direct solvers in a distributed computing The study deals with the parallelization of 2D and 3D finite environment. element based Navier-Stokes codes using direct solvers. The system of non-linear equations obtained from the Development of sparse direct solvers using multifrontal solvers discretization of Navier-Stokes equations is usually solved has significantly reduced the computational time of direct using a Newton or a Picard algorithm. Newton algorithms solution methods. Although limited by its stringent memory are known for their quadratic convergence behavior. requirements, multifrontal solvers can be computationally efficient. First the performance of MUltifrontal Massively When the initial guess is close to the final solution, Parallel Solver (MUMPS) is evaluated for both 2D and 3D codes Newton achieves quadratic convergence. In this paper, in terms of memory requirements and CPU times. The scalability only the Newton algorithm is used. In using direct solvers, of both Newton and modified Newton algorithms is tested. factorization of the left hand side matrix is the most time Key words: finite element, MUMPS solver, distributed consuming step. To avoid factorization during every computing, Newton method. iteration, a modified Newton is used in which the factorization is done only during the first iteration. The left side matrix evaluated for the first iteration is retained and 1. Introduction is not changed during the subsequent iterations. Only the right hand side matrix is updated during each iteration Discretization of Navier-Stokes equations involves a large step. The right hand side vector is appropriately modified set of non-linear equations, requiring high computing to give the final converged solution. Since the power in terms of speed and memory. The resulting set factorization is done only during the first iteration, the of weak form (algebraic) equations in such problems may subsequent iterations are extremely cheap. It usually be solved either using a direct solver or an iterative solver. requires more number of iterations to obtain the overall The direct solvers are known for their generality and convergence. So there is a tradeoff between the robustness. The direct solution methods generally involve computational time per iteration and the number of the use of frontal algorithms [1] in finite element iterations to obtain the final convergence. Although the applications. The advent of multifrontal solvers [2] has convergence rate is lower compared to the Newton greatly increased the efficiency of direct solvers for sparse iteration, the savings in computational time per iteration is systems. They make full use of the high computer so high that it can more than compensate the decrease in architecture by invoking level 3 Basic Linear Algebra the convergence rate. Subprograms (BLAS) library. Thus the memory MUMPS [11-13] and SUPERLU [14] are amongst the requirement is greatly reduced and the computing speed fastest parallel general sparse direct solvers that are greatly enhanced. Multifrontal solvers have been available under public domain software. A detailed successfully used both in the context of finite volume description of the various features and algorithms problems [3-5], finite element problems [6] and in power employed in these packages can be found in [15]. system simulations [7-9]. The disadvantage of using direct MUMPS is found to be much faster compared to solvers is that the memory size increases much more SUPERLU, although its scalability is low compared to that rapidly than the problem size itself [6]. To circumvent this of SUPERLU. In this paper, parallelization is achieved problem, out-of-core multifrontal solvers [10] have been using a MUltifrontal Massively Parallel Solver (MUMPS) developed which has the capability of storing the factors on a distributed environment using MPI. The linear system on the disk during factorization. Another viable alternative of equations is evaluated on different processors IJCSI IJCSI International Journal of Computer Science Issues, Vol. 4, No. 2, 2009 21 corresponding to the local grid assigned to the processor. calculations, instead of the primitive u,v,w,p formulation, The right hand side vector is assembled on the host penalty approach is used to reduce the memory processor and is input to the MUMPS solver. On exit from requirements. the MUMPS solver, the solution is assembled centrally on ∂uvw∂∂ + +=0, (7) the host processor. This solution is then broadcast to all ∂∂∂xyz the processors. In the context of modified Newton algorithm, the LU factors evaluated during the first ∂∂∂2 ∂∂∂∂∂∂⎛⎞uvw⎛⎞2 u iteration are reused and the solution of the linear system ()uuvuw++() () =λ ⎜⎟ +++⎜⎟ ∂∂∂xyz ∂∂∂∂∂∂ xxyzxxRe with the new right hand side vector is solved. The ⎝⎠⎝⎠ ∂ ⎛⎞11⎛⎞∂∂uv ∂⎛∂∂⎞⎛⎞ uw performance of the solver in terms of scalability and ++++⎜⎟⎜⎟⎜⎟⎜⎟, memory issues for both two-dimensional and three- ∂∂∂∂∂∂yyxzzx⎝⎠Re⎝⎠⎝⎠ Re ⎝⎠ dimensional problems are discussed in detail. (8) 2. Mathematical Formulation ∂∂∂2 ∂∂∂∂∂∂∂⎛⎞⎛⎞uvw⎛⎞1 uv ()uv++() v() vw =λ ⎜⎟⎜⎟ +++⎜⎟ + ∂∂∂x yz ∂∂∂∂∂∂∂ yxyzxyx⎝⎠⎝⎠⎝⎠Re The governing equations for laminar flow through a two- ∂∂∂⎛⎞21vvw⎛⎞ ⎛ ∂∂ ⎞ dimensional rectangular duct are presented below in the +++⎜⎟⎜⎟ ⎜ ⎟, non-dimensional form. ∂∂∂∂∂yyzzy⎝⎠Re⎝⎠ Re ⎝ ⎠ ∂∂uv +=0, (1) (9) ∂∂xy and ∂ ∂∂ ∂∂∂∂∂⎛∂∂⎞⎛⎞uvw1 ⎛⎞ uw uw++= vw w2 λ +++ + ∂∂2 ∂∂∂∂∂∂pu⎛⎞21⎛⎞⎛⎞ uv () () () ⎜⎟⎜⎟⎜⎟ ()uuv+=−++() ⎜⎟⎜⎟⎜⎟ +, ∂∂∂x yz ∂∂∂∂∂∂∂ zxyzxzx⎝⎠⎝⎠Re ⎝⎠ ∂∂xy ∂∂∂∂∂∂ xxxyyx⎝⎠Re Re ⎝⎠⎝⎠ ∂∂∂∂∂⎛⎞12⎛⎞vw⎛⎞ w (2) +++⎜⎟⎜⎟⎜⎟. ∂∂∂∂∂yzyzz⎝⎠Re⎝⎠⎝⎠ Re (10) and where uvw,, are the x, y and z components of velocity,. ∂∂2 ∂∂∂∂∂∂p ⎛⎞12⎛⎞⎛⎞uv v (3) The bulk flow Reynolds number, Re=ρU0D/µ, U0 being ()uv+=−+++() v ⎜⎟⎜⎟⎜⎟, ∂∂x yyxyxyy ∂∂∂∂∂∂⎝⎠Re⎝⎠⎝⎠ Re the inlet velocity, ρ the density, L the channel length, µ is the dynamic viscosity and λ is the penalty parameter. where uv, are the x and y components of velocity, p is Velocities are non-dimensionalized with respect to U0. The boundary conditions are prescribed as follows: the pressure. The bulk flow Reynolds number, (1) Along the channel inlet: Re=ρU0D/µ, U0 being the inlet velocity, ρ the density, L the channel length, and µ is the dynamic viscosity. uvw= 1;== 0; 0. (11) Velocities are non-dimensionalized with respect to U0, 2 pressure with respect to ρU0 . (2) Along the channel exit : The boundary conditions are prescribed as follows: ∂uvw∂∂ (1) Along the channel inlet: = 0;== 0; 0. (12) ∂∂∂xxx uv==1; 0. (4) (3) Along the walls: (2) Along the channel exit: uvw= 0; ==0; 0. (13) ∂∂uv p ===0; 0; 0. (5) ∂∂xx (3) Along the walls: 4. Newton’s Algorithm uv==0; 0. (6) The set of non-linear equations obtained by the discretization of Galerkin Finite element formulation is The governing equations for laminar flow through a solved using Newton’s iterative algorithm. three-dimensional rectangular duct are presented below in the non-dimensional form. In three-dimensional IJCSI IJCSI International Journal of Computer Science Issues, Vol. 4, No. 2, 2009 22 Let X (k ) be the available vector of field unknowns All these steps can be called separately or as a th% st combination of each other. This can be exploited to save for the k iteration. Then the update for the k +1 () some computational effort during the solution of iteration is obtained as subsequent iterations in the solution of a set of nonlinear XX()kk+1 =+ ()αδ X () k, (14) equations. For example if the structure of the matrix does %% % k not change during every iteration, the analysis step can be where α is an under-relaxation factor, and δ X ( ) is the % skipped after evaluating once. Similarly, if the left hand correction vector obtained by solving the linearized matrix does not change, both the analysis and the system factorization steps can be skipped. ()k (k ) . (15) []JX{δ } =−{} RX %% Here, [J] is the Jacobian matrix, 6. Parallel Implementation ()k ∂RX . (16) []J = k The MUMPS solver is implemented using the MPI library, ∂X% () which makes the code very portable and usable on both, and ()k is the residual% vector. Newton’s iteration is {}RX shared and distributed memory parallel computers. The continued% till the infinity norm of the correction vector parallelization is done internally in the code. The calling δ X (k ) converges to a prescribed tolerance of 10−6 . program should also be in a parallel environment to call the code. In the present formulation, each element is The% modified Newton’s algorithm employs the jacobian assigned to particular processor such the elements are calculated during the first iteration repeatedly for all the equally (or almost equally) distributed amongst all the successive iterations. The jacobian is not updated. This processors. The computation of the matrix coefficients and would reduce the rate of convergence of the Newton the right hand side vector are done in parallel algorithm. Since the jacobian is not updated, factorization corresponding to the set of local elements. Evaluation of can be skipped during all the subsequent iterations. the Jacobian matrix and the right hand side vector in a parallel environment is crucial for problems, which 5. MUMPS Solver consume lot of time for the evaluation of matrix coefficients. The most time consuming part is the solution of the set During the progress of overall iterations, the different set of linear equations. To solve these linear systems, we use a of linear equations obtained during every iteration is robust parallel solver MUMPS. It employs multifrontal solved by successive calls to the MUMPS. For the techniques to solve the set of linear equations on parallel modified Newton’s algorithm, the left hand matrix computers on a distributed environment using MPI. It remains the same (numerically).
Recommended publications
  • MUMPS Users' Guide
    MUltifrontal Massively Parallel Solver (MUMPS 5.4.1) Users’ guide * August 3, 2021 Abstract This document describes the Fortran 95 and C user interfaces to MUMPS5.4.1, a software package to solve sparse systems of linear equations, with many features. For some classes of problems, the complexity of the factorization and the memory footprint of MUMPS can be reduced thanks to the Block Low-Rank (BLR) feature. We describe in detail the data structures, parameters, calling sequences, and error diagnostics. Basic example programs using MUMPS are also provided. Users are allowed to save to disk MUMPS internal data before or after any of the main steps of MUMPS (analysis, factorization, solve) and then restart. *Information on how to obtain updated copies of MUMPS can be obtained from the Web page http://mumps-solver.org/ 1 Contents 1 Introduction 5 2 Notes for users of other versions of MUMPS 6 2.1 ChangeLog........................................7 2.2 Binary compatibility....................................7 2.3 Upgrading between minor releases............................7 2.4 Upgrading from MUMPS 5.3.5 to MUMPS 5.4.1 ...................8 2.5 Upgrading from MUMPS 5.2.1 to MUMPS 5.3.5 ...................8 2.6 Upgrading from MUMPS 5.1.2 to MUMPS 5.2.1 ...................8 2.7 Upgrading from MUMPS 5.0.2 to MUMPS 5.1.2 ...................9 2.7.1 Changes on installation issues...........................9 2.7.2 Selective 64-bit integer feature..........................9 2.8 Upgrading from MUMPS 4.10.0 to MUMPS 5.0.2 .................. 10 2.8.1 Interface with the Metis and ParMetis orderings................
    [Show full text]
  • Arxiv:2105.11220V1 [Cs.DC] 24 May 2021 the Motion of Particles Is Described by a Set of Convection-Diffusion-Reaction Equations
    Towards Parallel CFD computation for the ADAPT framework Imad Kissamiy∗, Christophe Ceriny, Fayssal Benkhaldoun∗, and Gilles Scarella∗ Universit´ede Paris 13 y LIPN, ∗ LAGA, 99, avenue Jean-Baptiste Cl´ement, 93430 Villetaneuse, France [email protected] Abstract. In order to run Computational Fluid Dynamics (CFD) codes on large scale infrastructures, parallel computing has to be used because of the computational intensive nature of the problems. In this paper we investigate the ADAPT platform where we couple flow Partial Differ- ential Equations and a Poisson equation. This leads to a linear system which we solve using direct methods. The implementation deals with the MUMPS parallel multi-frontal direct solver and mesh partitioning meth- ods using METIS to improve the performance of the framework. We also investigate, in this paper, how the mesh partitioning methods are able to optimize the mesh cell distribution for the ADAPT solver. The ex- perience gained in this paper facilitates the move to the 3D version of ADAPT and the move to a Service Oriented view of ADAPT as future work. Keywords: Unstructured mesh, Mesh partitioning, Parallel direct solver, Multi-frontal method, MUMPS, METIS, Multi-physics, Multi-scale and Multilevel Algorithms. 1 Introduction and context of the work In the last recent decades CFD (Computational Fluid Dynamics) used to play an important role in industrial designs, environmental impact assessments and academic studies. The aim of our work is to fully parallelize an unstructured adaptive code for the simulation of 3D streamer propagation in cold plasmas. As a matter of fact, the initial sequential version of the Streamer code needs up to one month for running typical benchmarks.
    [Show full text]
  • Multifrontal Massively Parallel Solver (MUMPS 4.8.4) Users' Guide
    MUltifrontal Massively Parallel Solver (MUMPS 4.8.4) Users’ guide ∗ December 15, 2008 Abstract This document describes the Fortran 90 and C user interface to MUMPS 4.8.4 We describe in detail the data structures, parameters, calling sequences, and error diagnostics. Example programs using MUMPS are also given. A preliminary out-of-core functionality (with limited support) is included in this version. ∗Information on how to obtain updated copies of MUMPS can be obtained from the Web pages http://mumps.enseeiht.fr/ and http://graal.ens-lyon.fr/MUMPS/ 1 Contents 1 Introduction 4 2 Main functionalities of MUMPS 4.8.4 5 2.1 Inputmatrixstructure . ....... 5 2.2 Preprocessing ................................... .... 5 2.3 Post-processingfacilities . .......... 6 2.4 Solvingthetransposedsystem. ......... 6 2.5 Reduce/condense a problem on an interface (Schur complement and reduced/condensed right-handside) .................................... 7 2.6 Arithmeticversions .... ............. ............. ...... 8 2.7 Theworkinghostprocessor . ....... 8 2.8 Sequentialversion..... ............. ............. ...... 8 2.9 Sharedmemoryversion . ..... 8 2.10 Out-of-corefacility . ........ 8 3 Sequence in which routines are called 8 4 Input and output parameters 11 4.1 Versionnumber ................................... 11 4.2 Control of the three main phases: Analysis, Factorization,Solve ............. 11 4.3 Controlofparallelism . ....... 12 4.4 Matrixtype ...................................... 13 4.5 Centralized assembled matrix input: ICNTL(5)=0 and ICNTL(18)=0 .......... 13 4.6 Element matrix input: ICNTL(5)=1 and ICNTL(18)=0 . ............. 14 4.7 Distributed assembled matrix input: ICNTL(5)=0 and ICNTL(18)=0 .......... 14 4.8 Scaling.........................................6 . 15 4.9 Givenordering:ICNTL(7)=1 . ....... 15 4.10 Schur complement with reduced (or condensed) right-hand side: ICNTL(19) and ICNTL(26) .......................................
    [Show full text]
  • Python Interface Release 5.4.1
    Python Interface Release 5.4.1 Luis Saavedra Jul 22, 2021 Contents 1 Introduction 1 2 Installation 3 3 Preliminary 5 4 Python GetFEM interface7 4.1 Introduction........................................7 4.2 Parallel version.......................................7 4.3 Memory Management...................................8 4.4 Documentation.......................................8 4.5 Python GetFEM organization...............................8 5 Examples 11 5.1 A step-by-step basic example............................... 11 5.2 Another Laplacian with exact solution (source term)................... 14 5.3 Linear and non-linear elasticity.............................. 16 5.4 Avoiding the model framework.............................. 19 5.5 Other examples....................................... 20 6 How-tos 23 6.1 Import gmsh mesh..................................... 23 7 API reference 25 7.1 ContStruct......................................... 25 7.2 CvStruct.......................................... 27 7.3 Eltm............................................ 28 7.4 Fem............................................. 28 7.5 GeoTrans.......................................... 31 7.6 GlobalFunction....................................... 32 7.7 Integ............................................ 33 7.8 LevelSet.......................................... 35 7.9 Mesh............................................ 36 7.10 MeshFem.......................................... 44 7.11 MeshIm........................................... 50 7.12 MeshImData.......................................
    [Show full text]
  • DEPARTMENT of INFORMATICS Configuration of a Linear Solver For
    DEPARTMENT OF INFORMATICS TECHNISCHE UNIVERSITÄT MÜNCHEN Master’s Thesis in Computational Science and Engineering Configuration of a linear solver for linearly implicit time integration and efficient data transfer in parallel thermo-hydraulic computations Ravil Dorozhinskii DEPARTMENT OF INFORMATICS TECHNISCHE UNIVERSITÄT MÜNCHEN Master’s Thesis in Computational Science and Engineering Configuration of a linear solver for linearly implicit time integration and efficient data transfer in parallel thermo-hydraulic computations Konfiguration eines Lösers für linear-implizite Zeitintegration und effizienter Datentransfer in parallelen thermohydraulischen Berechnungen Author: Ravil Dorozhinskii Supervisor: Prof. Dr. Thomas Huckle Advisors: Dr. rer. nat. Tim Steinhoff, Dr. rer. nat. Tobias Neckel Submission Date: 07 March 2019 I confirm that this master’s thesis is my own work and I have documented all sources and material used. Munich, 07 March 2019 Ravil Dorozhinskii Abstract Key words. numerical time integration, direct sparse linear methods, multifrontal methods, MUMPS, BLAS, parallel performance, distributed-memory computations, multi-threading, MPI, OpenMP, non-blocking communication An application of linearly implicit methods for time integration of stiff systems of ODEs results in solving sparse systems of linear equations. An optimal selection and configuration of a parallel linear solver can considerably accelerate the time integration process. A comparison of iterative and direct sparse linear solvers has shown that direct ones are the most suitable for this purpose because of their natural robustness to ill-conditioned linear systems that can occur during numerical time integration. Testing of different direct sparse solvers applied to systems generated by ATHLET software has revealed that MUMPS, an implementation of the multifrontal method, performs better than the others in terms of the overall parallel execution time.
    [Show full text]
  • Combinatorial Problems in Solving Linear Systems Iain
    COMBINATORIAL PROBLEMS IN SOLVING LINEAR SYSTEMS IAIN S. DUFF and BORA UC¸AR Technical Report: No: TR/PA/09/60 CERFACS 42 av. Gaspard Coriolis, 31057 Toulouse, Cedex 1, France. Available at http://www.cerfacs.fr/algor/reports/ Date: August 7, 2009. COMBINATORIAL PROBLEMS IN SOLVING LINEAR SYSTEMS∗ IAIN S. DUFFy z AND BORA UC¸ARx Abstract. Numerical linear algebra and combinatorial optimization are vast subjects; as is their interaction. In virtually all cases there should be a notion of sparsity for a combinatorial problem to arise. Sparse matrices therefore form the basis of the interaction of these two seemingly disparate subjects. As the core of many of today's numerical linear algebra computations consists of the solution of sparse linear system by direct or iterative methods, we survey some combinatorial problems, ideas, and algorithms relating to these computations. On the direct methods side, we discuss issues such as matrix ordering; bipartite matching and matrix scaling for better pivoting; task assignment and scheduling for parallel multifrontal solvers. On the iterative method side, we discuss preconditioning techniques including incomplete factorization preconditioners, support graph preconditioners, and algebraic multigrid. In a separate part, we discuss the block triangular form of sparse matrices. Key words. Combinatorial scientific computing, graph theory, combinatorial optimization, sparse matrices, linear system solution 1. Introduction. In this short review paper, we examine the interplay between the solution of sparse linear systems and combinatorics. Most of this strong associa- tion comes from the identification of sparse matrices with graphs so that most algo- rithms dealing with sparse matrices have a close or exact analogue to an algorithm on a graph.
    [Show full text]
  • A Bibliography of Publications of Iain S. Duff
    A Bibliography of Publications of Iain S. Duff Iain S. Duff Rutherford Appleton Laboratory Chilton, Oxon UK Tel: +44-235-445803 FAX: +44-235-446626 E-mail: [email protected] (Internet) 19 March 2021 Version 2.61 Abstract [Duf91b]. 1991 [Ano91, FF93]. 1993 [Duf94a, GW94]. 1994 [MC95]. 1995 This bibliography records publications of Iain [Duf96a, PB96]. 1996 [DGDG97a]. 1997 S. Duff. [Duf98b]. 1999 [Duf00a]. 1st [DFT95, HPP88]. Title word cross-reference 2 [ADD89a, ADD92, DD87a, DD88, DD89, DD90a, DD90b, DD91, Duf88b, DV98a]. 200/VF [DD88, DD89]. 2000 − A 1 [ADLR15]. LU [DD92a, DD90b, DD91]. [ACM00, vdVDE+02]. 2001 QR [ADP94]. LDLT [ADGP07, DHL20]. [Ano01, Duf02a]. 2002 [vdVDE+03]. 2003 LU [DD94a, DD97b]. O(n1=2τ) [DW88]. P 4 [Duf04b]. 2008 [BBD+11, TCJ+10]. 2010 [DAGR87, ADGR90]. P 5 [TBC+11]. 2e [AG80]. 2nd [DAGR87, ADGR90]. QR [ADP96]. [AG80, BBD+11, DR85a]. 1 [DR82a, Duf82b, Duf82c, Duf84g]. 10P 3 [DDP94]. 3090 [ADD89a, ADD92, DD88, DD89]. 11th [ADD89a, ADD92, DD88, DD89, DD90a]. [Duf81i]. 14th [Ame94]. 15th [GW94]. 1978 3090-200 [DD88, DD89]. 3090-200/VF [DS79]. 1979 [GL80]. 1981 [DD88, DD89]. 31-September [ABD+99]. [Hen82, TH82, Wat82]. 1982 [PR83]. 1983 [ESY84, Kow84]. 1984 [DR85a]. 1986 5th [ABD+99, SMMG01, WDPW04]. [IP87, PA88]. 1987 [Duf88c]. 1988 [CRQR89, Duf89f, ES89]. 1989 70th [DW91]. [Ano89, DG89, DMSV90, EJP90]. 1990 1 2 8 [Duf87d, Duf89e, Duf90a]. 80 ALLIANT [DD90a, ADD89a, ADD92, [ADD89a, ADD92, DD90a, DD90b, DD91]. DD90b, DD91, Duf87d, Duf89e, Duf90a]. 818 [DV02a]. 837 [ADD04]. AMD [ADD04]. Analysis [ADLL00, ADLL01c, ADLL01d, ADGS10, ’90 [Sup90, Jap90]. 92-VAPP [BCRT92]. Duf72, Duf81i, Duf86a, Duf88c, Duf89f, ’94 [Ame94, DW94].
    [Show full text]
  • An Interview with IAIN S. DUFF Conducted by Thomas Haigh on 30
    An interview with IAIN S. DUFF Conducted by Thomas Haigh On 30 & 31st August, 2005 In East Hagbourne and Chilton, United Kingdom Interview conducted by the Society for Industrial and Applied Mathematics, as part of grant # DE-FG02-01ER25547 awarded by the US Department of Energy. Transcript and original tapes donated to the Computer History Museum by the Society for Industrial and Applied Mathematics © Computer History Museum Mountain View, California ABSTRACT Iain S. Duff explores the whole of his career to date. Duff grew up in Glasgow, attending The High School before earning a first class degree in Mathematics and Natural Philosophy from the University of Glasgow in 1969. He discusses the mathematical curriculum there, and recounts his early computing experiences as a summer fellow with IBM. Duff won a Carnegie Fellowship for postgraduate work at Oxford, culminating in a D.Phil. conferred in 1972. At Oxford he worked with the numerical analysis group and wrote his thesis on the analysis of sparse systems under the direction of Leslie Fox. While working toward his degree, Duff was already collaborating with Alan Curtis, Michael Powell, and John Reid at the nearby AERE Harwell nuclear power research center. His interest in sparse matrices was cemented by a 1971 visit to IBM’s Yorktown Heights laboratory for a conference, where he first met colleagues such as Alan George, Ralph Willoughby and Fred Gustavson. In 1972, Duff went to the United States on a Harkness postdoctoral fellowship, spending time at SUNY Stony Brook with Reggie Tewarson and Stanford, where he got to know Gene Golub.
    [Show full text]
  • High Performance Computing of Three-Dimensional Finite Element Codes on a 64-Bit Machine
    Journal of Applied Fluid Mechanics, Vol. 5, No. 2, pp. 123-132, 2012. Available online at www.jafmonline.net, ISSN 1735-3572, EISSN 1735-3645. High Performance Computing of Three-Dimensional Finite Element Codes on a 64-bit Machine M.P. Raju1† and S.K. Khaitan2 1 Department of Mechanical Engg., Case Western Reserve University, Cleveland, OH, 44106, USA 2 Department of Electrical Engg., Iowa State University, Ames, IA, 50014, USA †Corresponding Author Email: [email protected] (Received March 8, 2009; accepted March 28, 2009) ABSTRACT Three dimensional Navier-Stokes finite element formulations require huge computational power in terms of memory and CPU time. Recent developments in sparse direct solvers have significantly reduced the memory and computational time of direct solution methods. The objective of this study is twofold. First is to evaluate the performance of various state-of-the-art sequential sparse direct solvers in the context of finite element formulation of fluid flow problems. Second is to examine the merit in upgrading from 32 bit machine to a 64 bit machine with larger RAM capacity in terms of its capacity to solve larger problems. The choice of a direct solver is dependent on its computational time and its in-core memory requirements. Here four different solvers, UMFPACK, MUMPS, HSL_MA78 and PARDISO are compared. The performances of these solvers with respect to the computational time and memory requirements on a 64-bit windows server machine with 16GB RAM is evaluated. Keywords: Multifrontal, UMFPACK, MUMPS, HSL MA78, PARDISO, 64-bit. 1. INTRODUCTION iterative methods like SIMPLE algorithm used in finite volume formulations.
    [Show full text]
  • Short User Documentation Release 4.0
    Short User Documentation Release 4.0 Yves Renard, Julien Pommier March 22, 2010 CONTENTS 1 Introduction 1 2 How to install 3 2.1 Requirements...............................................3 2.2 Download sources............................................3 2.3 Compilling................................................4 3 Linear algebra procedures 7 4 Parallelization of GetFEM++ 9 5 Catch errors 11 6 Build a mesh 13 6.1 Add an element to a mesh........................................ 13 6.2 Remove an element from a mesh.................................... 15 6.3 Simple structured meshes........................................ 15 6.4 Mesh regions............................................... 16 6.5 Methods of the getfem::mesh object................................ 16 6.6 Using dal::bit_vector ....................................... 18 6.7 Face numbering............................................. 19 6.8 Save and load meshes.......................................... 19 7 Build a finite element method on a mesh 23 7.1 First level: manipulating fems on each elements............................ 24 7.2 Examples................................................. 25 7.3 Second level: the optional “vectorization”................................ 25 7.4 Third level: the optional linear transformation (or reduction)...................... 26 7.5 Obtaining generic mesh_fem‘s...................................... 27 7.6 The partial_mesh_fem object...................................... 27 8 Selecting integration methods 29 8.1 Methods of the mesh_im object....................................
    [Show full text]
  • Amesos 2.0 Reference Guide
    SANDIA REPORT SAND2004-4820 Unlimited Release Printed September 2004 Amesos 2.0 Reference Guide Marzio Sala Prepared by Sandia National Laboratories Albuquerque, New Mexico 87185 and Livermore, California 94550 Sandia is a multiprogram laboratory operated by Sandia Corporation, a Lockheed Martin Company, for the United States Department of Energy's National Nuclear Security Administration under Contract DE-AC04-94-AL85000. Approved for public release; further dissemination unlimited. Issued by Sandia National Laboratories, operated for the United States Department of Energy by Sandia Corporation. NOTICE: This report was prepared as an account of work sponsored by an agency of the United States Government. Neither the United States Government, nor any agency thereof, nor any of their employees, nor any of their contractors, subcontractors, or their employees, make any warranty, express or implied, or assume any legal liability or re- sponsibility for the accuracy, completeness, or usefulness of any information, appara- tus, product, or process disclosed, or represent that its use would not infringe privately owned rights. Reference herein to any specific commercial product, process, or service by trade name, trademark, manufacturer, or otherwise, does not necessarily constitute or imply its endorsement, recommendation, or favoring by the United States Govern- ment, any agency thereof, or any of their contractors or subcontractors. The views and opinions expressed herein do not necessarily state or reflect those of the United States Government, any agency thereof, or any of their contractors. Printed in the United States of America. This report has been reproduced directly from the best available copy. Available to DOE and DOE contractors from U.S.
    [Show full text]
  • Amesos 2.0 Reference Guide
    SANDIA REPORT SAND2004-XXXX Unlimited Release Printed October 2004 Amesos 2.0 Reference Guide Marzio Sala Prepared by Sandia National Laboratories Albuquerque, New Mexico 87185 and Livermore, California 94550 Sandia is a multiprogram laboratory operated by Sandia Corporation, a Lockheed Martin Company, for the United States Department of Energy's National Nuclear Security Administration under Contract DE-AC04-94-AL85000. Approved for public release; further dissemination unlimited. Issued by Sandia National Laboratories, operated for the United States Department of Energy by Sandia Corporation. NOTICE: This report was prepared as an account of work sponsored by an agency of the United States Government. Neither the United States Government, nor any agency thereof, nor any of their employees, nor any of their contractors, subcontractors, or their employees, make any warranty, express or implied, or assume any legal liability or re- sponsibility for the accuracy, completeness, or usefulness of any information, appara- tus, product, or process disclosed, or represent that its use would not infringe privately owned rights. Reference herein to any specific commercial product, process, or service by trade name, trademark, manufacturer, or otherwise, does not necessarily constitute or imply its endorsement, recommendation, or favoring by the United States Govern- ment, any agency thereof, or any of their contractors or subcontractors. The views and opinions expressed herein do not necessarily state or reflect those of the United States Government, any agency thereof, or any of their contractors. Printed in the United States of America. This report has been reproduced directly from the best available copy. Available to DOE and DOE contractors from U.S.
    [Show full text]