You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
Salvatore Filippone 67cff859ec Fix lev%free() for sm2a 5 years ago
cbind Improve structure of Makefiles 5 years ago
config Merge branch 'smoothed-parm' of https://github.com/sfilippone/mld2p4-2 into smoothed-parm 5 years ago
docs Fix documentation typo 5 years ago
examples Fix matrix generation. 6 years ago
mlprec Fix lev%free() for sm2a 5 years ago
tests New name VG in matdist. 5 years ago
.gitignore More entries in gitignore 6 years ago
Changelog *** empty log message *** 6 years ago
LICENSE Updated version number in headers. 7 years ago
Make.inc.in Modify Make.inc and configry. 5 years ago
Makefile Improve structure of Makefiles 5 years ago
README.md Take out old html docs 5 years ago
ReleaseNews Updated copyright statement. 7 years ago
autogen.sh mld2p4: 17 years ago
configure Regenerate configure script from latest updates for SuperLU_DIST 5 years ago
configure.ac Fixes for interfacing with multiple versions of SuperLU_DIST 5 years ago
install-sh mld2p4: 17 years ago
missing mld2p4: 17 years ago

README.md

                     MLD2P4  

MultiLevel Domain Decomposition Parallel Preconditioners Package based on PSBLAS (Parallel Sparse BLAS version 3.5)

Salvatore Filippone (Cranfield University, UK) Pasqua D'Ambra (IAC-CNR, Naples, IT) Daniela di Serafino (Univ. of Campania "L. Vanvitelli", Caserta, IT)


MLD2P4 (MultiLevel Domain Decomposition Parallel Preconditioners Package based on PSBLAS) provides parallel Algebraic MultiGrid (AMG) and Domain Decomposition preconditioners, to be used in the iterative solution of linear systems.

The name of the package comes from its original implementation, containing multilevel additive and hybrid Schwarz preconditioners, as well as one-level additive Schwarz preconditioners. The current version extends the original plan by including multilevel cycles and smoothers widely used in multigrid methods. A purely algebraic approach is applied to generate coarse-level corrections, so that no geometric background is needed concerning the matrix to be preconditioned.

MLD2P4 has been designed to provide scalable and easy-to-use preconditioners in the context of the PSBLAS (Parallel Sparse Basic Linear Algebra Subprograms) computational framework and is used in conjuction with the Krylov solvers available from PSBLAS. The package employs object-oriented design techniques in Fortran 2003, with interfaces to additional third party libraries such as MUMPS, UMFPACK, SuperLU, and SuperLU_Dist, which can be exploited in building multilevel preconditioners. The parallel implementation is based on a Single Program Multiple Data (SPMD) paradigm; the inter-process communication is based on MPI and is managed mainly through PSBLAS.

MAIN REFERENCE:

P. D'Ambra, D. di Serafino, S. Filippone, MLD2P4: a Package of Parallel Algebraic Multilevel Domain Decomposition Preconditioners in Fortran 95, ACM Transactions on Mathematical Software, 37 (3), 2010, art. 30, doi: 10.1145/1824801.1824808.

TO COMPILE

  1. Unpack the tar file in a directory of your choice (preferrably outside the main PSBLAS directory).
  2. run configure --with-psblas= adding the options for MUMPS, SuperLU, SuperLU_Dist, UMFPACK as desired. See MLD2P4 User's and Reference Guide (Section 3) for details.
  3. Tweak Make.inc if you are not satisfied.
  4. make;
  5. Go into the test subdirectory and build the examples of your choice.
  6. (if desired): make install

NOTES

  • The single precision version is supported only by MUMPS and SuperLU; thus, even if you specify at configure time to use UMFPACK or SuperLU_Dist, the corresponding preconditioner options will be available only from the double precision version.

  • The preconditioners in MLD2P4 extend those of PSBLAS and are meant to be used with the PSBLAS Krylov solvers; so in an existing program you need to modify the type of the preconditioner object and its settings, but the rest of the application needs not be changed.

The MLD2P4 team.

Project lead: Salvatore Filippone

Contributors: Pasqua D'Ambra Daniela di Serafino Ambra Abdullahi Hassan Alfredo Buttari