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 535d3aa059 Fixed Makefile. 7 years ago
config Fixed configry for both Fortran and C interface to MUMPS. 7 years ago
docs Fix example of use of configure in documentation. 7 years ago
examples Put in new cartesian data partition from PSBLAS. 7 years ago
mlprec Fixed Makefile. 7 years ago
tests Aligned matrix generation with that from base PSBLAS library. 7 years ago
Changelog Summary: updated changelog 8 years ago
LICENSE Updated copyright statement. 7 years ago
Make.inc.in Fixes for new cbind-version of psblas 3.5.0 7 years ago
Makefile Put in new cartesian data partition from PSBLAS. 7 years ago
README Updated copyright statement. 7 years ago
ReleaseNews Updated copyright statement. 7 years ago
autogen.sh mld2p4: 17 years ago
configure Fixed configry for both Fortran and C interface to MUMPS. 7 years ago
configure.ac Fixed configry for both Fortran and C interface to MUMPS. 7 years ago
install-sh mld2p4: 17 years ago
missing mld2p4: 17 years ago
mkdir.sh mld2p4: 17 years ago

README

                         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

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

Contributors

Salvatore  Filippone 
Pasqua     D'Ambra
Daniela    di Serafino
Ambra	   Abdullahi Hassan
Alfredo    Buttari