Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/hpddm/hpddm

A framework for high-performance domain decomposition methods.
https://github.com/hpddm/hpddm

c c-plus-plus domain-decomposition fortran freefem linear-algebra numerical-methods petsc preconditioners python

Last synced: 1 day ago
JSON representation

A framework for high-performance domain decomposition methods.

Awesome Lists containing this project

README

        

## HPDDM — high-performance unified framework for domain decomposition methods [![build](https://github.com/hpddm/hpddm/workflows/CI/badge.svg)](https://github.com/hpddm/hpddm/actions) [![codecov](https://codecov.io/gh/hpddm/hpddm/branch/main/graph/badge.svg)](https://codecov.io/gh/hpddm/hpddm)

#### What is HPDDM?
HPDDM is an efficient implementation of various domain decomposition methods (DDM) such as one- and two-level Restricted Additive Schwarz (RAS) methods, the Finite Element Tearing and Interconnecting (FETI) method, and the Balancing Domain Decomposition (BDD) method. These methods can be enhanced with deflation vectors computed automatically by the framework using:
* Generalized Eigenvalue problems on the Overlap (GenEO), an approach first introduced in a paper by [Spillane et al.](http://link.springer.com/article/10.1007%2Fs00211-013-0576-y#page-1), or
* local Dirichlet-to-Neumann operators, an approach first introduced in a paper by [Nataf et al.](http://epubs.siam.org/doi/abs/10.1137/100796376) and revisited by [Conen et al.](http://www.sciencedirect.com/science/article/pii/S0377042714001800)

This code has been proven to be efficient for solving various elliptic problems such as scalar diffusion equations, the system of linear elasticity, but also frequency domain problems like the Helmholtz equation. A comparison with modern multigrid methods can be found in the thesis of [Jolivet](https://joliv.et/thesis.pdf). The preconditioners may be used with a variety of Krylov subspace methods (which all support right, left, and variable preconditioning).
* [GMRES](http://epubs.siam.org/doi/abs/10.1137/0907058) and [Block GMRES](http://www.sam.math.ethz.ch/~mhg/pub/delhipap.pdf)
* [CG](http://nvlpubs.nist.gov/nistpubs/jres/049/jresv49n6p409_A1b.pdf), [Block CG](http://www.sciencedirect.com/science/article/pii/0024379580902475), and [Breakdown-Free Block CG](http://link.springer.com/article/10.1007/s10543-016-0631-z)
* [GCRO-DR](http://epubs.siam.org/doi/abs/10.1137/040607277) and [Block GCRO-DR](http://dl.acm.org/citation.cfm?id=3014927)

#### How to use HPDDM?
HPDDM is a library written in C++11 with MPI and OpenMP for parallelism. It is available out of the box in the following software:
* [PETSc](http://www.mcs.anl.gov/petsc/), with the option `--download-hpddm`
* [SLEPc](http://slepc.upv.es/), with the option `--download-hpddm`
* [FreeFEM](https://freefem.org/), with the option `--enable-download_hpddm`
* [Feel++](http://www.feelpp.org/), with the appropriate CMake include flag
* [htool](https://github.com/htool-ddm/htool), with the appropriate CMake include flag
* [Code_Aster](https://www.code-aster.org), through PETSc interface

While its interface relies on plain old data objects, it requires a modern C++ compiler: g++ 4.7.2 and above, clang++ 3.3 and above, icpc 15.0.0.090 and above¹, or pgc++ 15.1 and above¹. HPDDM has to be linked against BLAS and LAPACK (as found in [OpenBLAS](http://www.openblas.net/), in the [Accelerate framework](https://developer.apple.com/library/ios/documentation/Accelerate/Reference/AccelerateFWRef/_index.html) on macOS, in [IBM ESSL](http://www-03.ibm.com/systems/power/software/essl/), or in [Intel MKL](https://software.intel.com/en-us/intel-mkl)) as well as a direct solver like [MUMPS](http://mumps-solver.org/), [SuiteSparse](http://faculty.cse.tamu.edu/davis/suitesparse.html), [MKL PARDISO](https://software.intel.com/en-us/articles/intel-mkl-pardiso), or [PaStiX](http://pastix.gforge.inria.fr/). Additionally, an eigenvalue solver is recommended. There are existing interfaces to [ARPACK](http://www.caam.rice.edu/software/ARPACK/) and [SLEPc](http://slepc.upv.es/). Other (eigen)solvers can be easily added using the existing interfaces.
For building robust two-level methods, an interface with a discretization kernel like PETSc [DMPlex](https://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/DMPLEX/index.html), [FreeFEM](https://freefem.org/) or [Feel++](http://www.feelpp.org/) is also needed. It can then be used to provide, for example, elementary matrices, that the GenEO approach requires. As such, preconditioners assembled by HPDDM are not algebraic, unless only looking at one-level methods. Note that for substructuring methods, this is more of a limitation of the mathematical approach than of HPDDM itself.
The list of available options can be found in this [cheat sheet](https://github.com/hpddm/hpddm/raw/main/doc/cheatsheet.pdf). There is also a [tutorial](https://joliv.et/FreeFem-tutorial/) explaining how HPDDM is integrated in FreeFEM.

¹The latest versions of ~~icpc and~~ (this has been fixed since version 16.0.2.181) ~~pgc++~~ (since version 18.7) are not able to compile C++11 properly, if you want to use these compilers, please apply the following patch to the headers of HPDDM `sed -i\ '' 's/type\* = nullptr/type* = (void*)0/g; s/static constexpr const char/const char/g' include/*.hpp examples/*.cpp`.

##### TL;DR
Create a `./Makefile.inc` by copying one from the folder `./Make.inc` and adapt it to your platform. Type `make test` to run C++, C, Python, and Fortran examples (just type `make test_language` with `language = [cpp|c|python|fortran]` if you want to try only one set of examples).

#### May HPDDM be embedded inside C, Python, or Fortran codes?
Yes, as long as you have a modern C++ compiler, cf. the previous paragraph. With Python, [NumPy](http://www.numpy.org/) and [mpi4py](https://bitbucket.org/mpi4py/) must also be available.

#### Who is behind HPDDM?
This project was initiated by [Pierre Jolivet](https://joliv.et/) and [Frédéric Nataf](https://www.ljll.math.upmc.fr/nataf/). [Stefano Zampini](https://www.researchgate.net/profile/Stefano_Zampini) later played an integral role in the development of the PETSc interface.

#### How to cite HPDDM?
If you use this software, please cite the appropriate references from the list below, thank you.
* [Scalable domain decomposition preconditioners for heterogeneous elliptic problems](http://dl.acm.org/citation.cfm?doid=2503210.2503212) (domain decomposition and coarse operator assembly)
* [Block iterative methods and recycling for improved scalability of linear solvers](http://dl.acm.org/citation.cfm?id=3014927) (advanced Krylov methods)
* [KSPHPDDM and PCHPDDM: extending PETSc with advanced Krylov methods and robust multilevel overlapping Schwarz preconditioners](https://www.sciencedirect.com/science/article/abs/pii/S0898122121000055) (interface with PETSc)
* [An introduction to domain decomposition methods: algorithms, theory, and parallel implementation](http://www.siam.org/books/ot144/) (monograph on domain decomposition methods)

#### Acknowledgments
[Centre National de la Recherche Scientifique](http://www.cnrs.fr/index.php), France
[Sorbonne Université](https://www.sorbonne-universite.fr), Paris, France
[Institut de Recherche en Informatique de Toulouse](http://www.irit.fr/?lang=en), France
[Eidgenössische Technische Hochschule Zürich](https://www.ethz.ch/), Switzerland
[Université Grenoble Alpes](https://www.univ-grenoble-alpes.fr), Grenoble, France
[Inria](http://www.inria.fr/en/) Paris, France
[Agence Nationale de la Recherche](https://anr.fr), France
[Grand Equipement National de Calcul Intensif](http://www.genci.fr/en), France
[Fondation Sciences Mathématiques de Paris](http://www.sciencesmaths-paris.fr/en/), France

###### Collaborators/contributors (by alphabetical order)
[Hussam Al Daas](https://www.numerical.rl.ac.uk/people/h_aldaas/)
[Lea Conen](https://de.linkedin.com/in/lea-conen)
[Victorita Dolean](http://www.victoritadolean.com/)
Ryadh Haferssas
[Frédéric Hecht](https://www.ljll.math.upmc.fr/hecht/)
[Pierre Marchand](https://pierremarchand.netlify.app)
[Christophe Prud'homme](https://prudhomm.github.io)
[Nicole Spillane](http://www.cmap.polytechnique.fr/~spillane/)
[Pierre-Henri Tournier](https://www.researchgate.net/profile/Pierre-Henri_Tournier)