docs/pdf/Makefile
 docs/pdf/abstract.tex
 docs/pdf/advanced.tex
 docs/pdf/background.tex
 docs/pdf/bibliography.tex
 docs/pdf/listofroutines.tex
 docs/pdf/methods.tex
 docs/pdf/overview.tex
 docs/pdf/userguide.tex
 docs/pdf/userinterface.tex
 docs/userguide.pdf
 mlprec/mld_caggrmap_bld.f90
 mlprec/mld_cprecset.f90
 mlprec/mld_daggrmap_bld.f90
 mlprec/mld_dprecset.f90
 mlprec/mld_prec_type.f90
 mlprec/mld_saggrmap_bld.f90
 mlprec/mld_sprecset.f90
 mlprec/mld_zaggrmap_bld.f90
 mlprec/mld_zprecset.f90
 test/fileread/cf_sample.f90
 test/fileread/df_sample.f90
 test/fileread/sf_sample.f90
 test/fileread/zf_sample.f90
 test/pargen/Makefile
 test/pargen/ppde.f90
 test/pargen/spde.f90

Merged docs and minor fixes from Daniela.
stopcriterion
Salvatore Filippone 17 years ago
parent 2241c6af30
commit fc0b2cfbbe

@ -87,7 +87,6 @@ TOPFILE = userguide.tex
SECFILE = title.tex abstract.tex overview.tex conventions.tex distribution.tex \ SECFILE = title.tex abstract.tex overview.tex conventions.tex distribution.tex \
building.tex background.tex gettingstarted.tex userinterface.tex \ building.tex background.tex gettingstarted.tex userinterface.tex \
errors.tex bibliography.tex license.tex errors.tex bibliography.tex license.tex
# advanced.tex listofroutines.tex
FIGDIR = figures FIGDIR = figures
XPDFFLAGS = XPDFFLAGS =

@ -12,10 +12,15 @@ context of the PSBLAS (Parallel Sparse Basic Linear Algebra Subprograms)
computational framework and can be used in conjuction with the Krylov solvers computational framework and can be used in conjuction with the Krylov solvers
available in this framework. MLD2P4 enables the user to easily specify different aspects available in this framework. MLD2P4 enables the user to easily specify different aspects
of a generic algebraic multilevel Schwarz preconditioner, thus allowing to search of a generic algebraic multilevel Schwarz preconditioner, thus allowing to search
for the ``best'' preconditioner for the problem at hand. The package has been designed for the ``best'' preconditioner for the problem at hand.
employing object-oriented techniques, using Fortran 95 and MPI, with interfaces to
additional third party libraries such as UMFPACK, SuperLU and SuperLU\_Dist, that The package has been designed employing object-oriented techniques,
can be exploited in building multi-level preconditioners. using Fortran 95, with interfaces to additional third party libraries
such as UMFPACK, SuperLU and SuperLU\_Dist, that
can be exploited in building multi-level preconditioners. The parallel
implementation is based on a Single Program Multiple Data (SPMD)
paradigm for distributed-memory architectures; the inter-process data
communication is based on MPI and is managed mainly through PSBLAS.
This guide provides a brief description of the functionalities and This guide provides a brief description of the functionalities and
the user interface of MLD2P4. the user interface of MLD2P4.

@ -1,12 +0,0 @@
\section{Advanced Use}\label{sec:advanced}
- MLD2P4 software architecture \\
- preconditioner data structure (descrizione "dettagliata") + possibilita' di settare singolarmente
i vari livelli (possibilita' accennata solamente nella precedente descrizione di precset) \\
- descrizione routine medium level (con introduzione sulle potenzialita' di ampliamento (?), offerte
da queto strato software) \\
%%% Local Variables:
%%% mode: latex
%%% TeX-master: "userguide"
%%% End:

@ -5,7 +5,7 @@
\emph{Domain Decomposition} (DD) preconditioners, coupled with Krylov iterative \emph{Domain Decomposition} (DD) preconditioners, coupled with Krylov iterative
solvers, are widely used in the parallel solution of large and sparse linear systems. solvers, are widely used in the parallel solution of large and sparse linear systems.
These preconditioners are based on the divide and conquer technique: the matrix These preconditioners are based on the divide and conquer technique: the matrix
to be preconditioned is divided into submatrices, a ``local linear system'' to be preconditioned is divided into submatrices, a ``local'' linear system
involving each submatrix is (approximately) solved, and the local solutions are used involving each submatrix is (approximately) solved, and the local solutions are used
to build a preconditioner for the whole original matrix. This process to build a preconditioner for the whole original matrix. This process
often corresponds to dividing a physical domain associated to the original matrix often corresponds to dividing a physical domain associated to the original matrix
@ -61,7 +61,7 @@ starting from the original matrix. The algebraic approach is based on the \emph{
aggregation} algorithm \cite{BREZINA_VANEK,VANEK_MANDEL_BREZINA}. A decoupled version aggregation} algorithm \cite{BREZINA_VANEK,VANEK_MANDEL_BREZINA}. A decoupled version
of this algorithm is implemented, where the smoothed aggregation is applied locally of this algorithm is implemented, where the smoothed aggregation is applied locally
to each submatrix \cite{TUMINARO_TONG}. In the next two subsections we provide to each submatrix \cite{TUMINARO_TONG}. In the next two subsections we provide
a brief description of the multi-level Schwarz preconditioners and on the smoothed a brief description of the multi-level Schwarz preconditioners and of the smoothed
aggregation technique as implemented in MLD2P4. For further details the user aggregation technique as implemented in MLD2P4. For further details the user
is referred to \cite{para_04,aaecc_07,apnum_07,dd2_96}. is referred to \cite{para_04,aaecc_07,apnum_07,dd2_96}.
@ -203,7 +203,7 @@ One more variant of two-level hybrid preconditioner is obtained by applying
the smoother before and after the coarse-level correction. In this case, the the smoother before and after the coarse-level correction. In this case, the
preconditioner is symmetric if $A$, $M_{1L}$ and $M_{C}$ are symmetric. preconditioner is symmetric if $A$, $M_{1L}$ and $M_{C}$ are symmetric.
As previously noted, on parallel computers the number of sumatrices usually matches As previously noted, on parallel computers the number of submatrices usually matches
the number of available processors. When the size of the system to be preconditioned the number of available processors. When the size of the system to be preconditioned
is very large, the use of many processors, i.e.\ of many small submatrices, often is very large, the use of many processors, i.e.\ of many small submatrices, often
leads to a large coarse-level system, whose solution may be computationally expensive. leads to a large coarse-level system, whose solution may be computationally expensive.
@ -220,7 +220,7 @@ For a detailed descrition of them, the reader is
referred to \cite[Chapter 3]{dd2_96}. referred to \cite[Chapter 3]{dd2_96}.
The algorithm for the application of a multi-level hybrid The algorithm for the application of a multi-level hybrid
post-smoothed preconditioner $M$ to a vector $v$, i.e.\ for the post-smoothed preconditioner $M$ to a vector $v$, i.e.\ for the
computation of $w=M^{-1}v$ is reported, for computation of $w=M^{-1}v$, is reported, for
example, in Figure~\ref{fig:mlhpost_alg}. Here the number of levels example, in Figure~\ref{fig:mlhpost_alg}. Here the number of levels
is denoted by $nlev$ and the levels are numbered in increasing order starting is denoted by $nlev$ and the levels are numbered in increasing order starting
from the finest one, i.e.\ the finest level is level 1; the coarse matrix from the finest one, i.e.\ the finest level is level 1; the coarse matrix

@ -28,12 +28,13 @@ in Scientific Computing, Lecture Notes in Computer Science,
Springer, 2005, 593--602. Springer, 2005, 593--602.
% %
\bibitem{aaecc_07} A.~Buttari, P.~D'Ambra, D.~di~Serafino, S.~Filippone, \bibitem{aaecc_07} A.~Buttari, P.~D'Ambra, D.~di~Serafino, S.~Filippone,
{\em 2LEV-D2P4: a package of high-performance preconditioners}, {\em 2LEV-D2P4: a package of high-performance preconditioners
for scientific and engineering applications},
Applicable Algebra in Engineering, Communications and Computing, Applicable Algebra in Engineering, Communications and Computing,
18, 3, May, 2007, 223--239. 18, 3, 2007, 223--239.
%Published online: 13 February 2007, {\tt http://dx.doi.org/10.1007/s00200-007-0035-z} %Published online: 13 February 2007, {\tt http://dx.doi.org/10.1007/s00200-007-0035-z}
% %
\bibitem{apnum_07} P.~D'Ambra, S.~Filippone, D.~Di~Serafino, \bibitem{apnum_07} P.~D'Ambra, S.~Filippone, D.~di~Serafino,
{\em On the Development of PSBLAS-based Parallel Two-level Schwarz Preconditioners}, {\em On the Development of PSBLAS-based Parallel Two-level Schwarz Preconditioners},
Applied Numerical Mathematics, Elsevier Science, Applied Numerical Mathematics, Elsevier Science,
57, 11-12, 2007, 1181-1196. 57, 11-12, 2007, 1181-1196.
@ -105,8 +106,8 @@ BIT Numerical Mathematics, 43, 2003, 945--959.
% %
\bibitem{PSBLASGUIDE} \bibitem{PSBLASGUIDE}
S.~Filippone, A.~Buttari, S.~Filippone, A.~Buttari,
{\em PSBLAS-2.1 User's Guide. A Reference Guide for the Parallel Sparse BLAS Library}, {\em PSBLAS-2.3 User's Guide. A Reference Guide for the Parallel Sparse BLAS Library},
xxxxx. available from \texttt{http://www.ce.uniroma2.it/psblas/}.
% %
\bibitem{psblas_00} \bibitem{psblas_00}
S.~Filippone, M.~Colajanni, S.~Filippone, M.~Colajanni,
@ -114,7 +115,8 @@ S.~Filippone, M.~Colajanni,
Computation on Sparse Matrices}, Computation on Sparse Matrices},
ACM Transactions on Mathematical Software, 26, 4, 2000, 527--550. ACM Transactions on Mathematical Software, 26, 4, 2000, 527--550.
\bibitem{SUPERLUDIST} \bibitem{SUPERLUDIST}
X.~S.~Li, J.~W.~Demmel, {\em SuperLU\_DIST: A Scalable Distributed-memory Sparse Direct Solver for Unsymmetric Linear Systems}, X.~S.~Li, J.~W.~Demmel, {\em SuperLU\_DIST: A Scalable Distributed-memory
Sparse Direct Solver for Unsymmetric Linear Systems},
ACM Transactions on Mathematical Software, 29, 2, 2003, 110--140. ACM Transactions on Mathematical Software, 29, 2, 2003, 110--140.
% %
%\bibitem{KIVA3PSBLAS} %\bibitem{KIVA3PSBLAS}
@ -177,7 +179,7 @@ in J. Donnelley, editor, Proceedings of SuperComputing 2000, Dallas, 2000.
\bibitem{VANEK_MANDEL_BREZINA} \bibitem{VANEK_MANDEL_BREZINA}
P.~Van{\v e}k, J.~Mandel and M.~Brezina, P.~Van{\v e}k, J.~Mandel and M.~Brezina,
{\em Algebraic Multigrid by Smoothed Aggregation for Second and Fourth Order Elliptic Problems}, {\em Algebraic Multigrid by Smoothed Aggregation for Second and Fourth Order Elliptic Problems},
Computing, 1996, 56, 179-196. Computing, 56, 1996, 179-196.
% %
\end{thebibliography} \end{thebibliography}

@ -1,10 +0,0 @@
\section{List of Routines}\label{sec:routines}
Elenco (ordine alfabetico) di tutte le routine, con rinvio (ipertestuale e num. pag.) alla descrizione
di ciascuna in qualche paragrafo precedente
(una specie di indice analitico, che rimanda alle routine descritte precedentemente nei rispettivi paragrafi)
%%% Local Variables:
%%% mode: latex
%%% TeX-master: "userguide"
%%% End:

@ -1,607 +0,0 @@
\section{Iterative Methods}
\label{sec:methods}
\markboth{\underline{MLD2P4 User's and Reference Guide}}
{\underline{\ref{sec:methods} Iterative Methods}}
In this chapter we provide routines for preconditioners and iterative
methods. The interfaces for Krylov subspace methods are available in
the module \verb|mld_krylov_mod|. The installation process of MLD2P4
ensures that these may be used as a drop-in replacement for the PSBLAS
methods; they are accessible under the PSBLAS names (see the PSBLAS
documentation),
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% Krylov Methods driver routine
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\subroutine{mld\_krylov \label{krylov}}{Krylov Methods Driver Routine}
This subroutine is a driver that provides a general interface for all
the Krylov-Subspace family methods.
The stopping criterion is the normwise backward error, in the infinity
norm, i.e. the iteration is stopped when
\[ err = \frac{\|r_i\|}{(\|A\|\|x_i\|+\|b\|)} < eps \]
or the 2-norm residual reduction
\[ err = \frac{\|r_i\|}{\|b\|_2} < eps \]
according to the value passed through the istop argument (see
later). In the above formulae, $x_i$ is the tentative solution and
$r_i=b-Ax_i$ the corresponding residual at the $i$-th iteration.
\syntax{call psb\_krylov}{method,a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,irst,istop}
\begin{description}
\item[Type:] Synchronous.
\item[\bf On Entry]
\item[method] a string that defines the iterative method to be
used. Supported values are:
\begin{description}
\item[CG]: the Conjugate Gradient method;
\item[CGS]:the Conjugate Gradient Stabilized method;
\item[BICG]: the Bi-Conjugate Gradient method;
\item[BICGSTAB]: the Bi-Conjugate Gradient Stabilized method;
\item[BICGSTABL]: the Bi-Conjugate Gradient Stabilized method with restarting;
\item[RGMRES]: the Generalized Minimal Residual method with restarting.
\end{description}
\item[a] the local portion of global sparse matrix
$A$. \\
Scope: {\bf local} \\
Type: {\bf required}\\
Intent: {\bf in}.\\
Specified as: a structured data of type \spdata.
\item[prec] The data structure containing the preconditioner.\\
Scope: {\bf local} \\
Type: {\bf required}\\
Intent: {\bf in}.\\
Specified as: a structured data of type \precdata.
\item[b] The RHS vector. \\
Scope: {\bf local} \\
Type: {\bf required}\\
Intent: {\bf in}.\\
Specified as: a rank one array.
\item[x] The initial guess. \\
Scope: {\bf local} \\
Type: {\bf required}\\
Intent: {\bf inout}.\\
Specified as: a rank one array.
\item[eps] The stopping tolerance. \\
Scope: {\bf global} \\
Type: {\bf required}\\
Intent: {\bf in}.\\
Specified as: a real number.
\item[desc\_a] contains data structures for communications.\\
Scope: {\bf local} \\
Type: {\bf required}\\
Intent: {\bf in}.\\
Specified as: a structured data of type \descdata.
\item[itmax] The maximum number of iterations to perform.\\
Scope: {\bf global} \\
Type: {\bf optional}\\
Intent: {\bf in}.\\
Default: $itmax = 1000$.\\
Specified as: an integer variable $itmax \ge 1$.
\item[itrace] If $>0$ print out an informational message about
convergence every $itrace$ iterations.\\
Scope: {\bf global} \\
Type: {\bf optional}\\
Intent: {\bf in}.\\
\item[irst] An integer specifying the restart parameter.\\
Scope: {\bf global} \\
Type: {\bf optional}.\\
Intent: {\bf in}.\\
Values: $irst>0$. This is employed for the BiCGSTABL or RGMRES
methods, otherwise it is ignored.
\item[istop] An integer specifying the stopping criterion.\\
Scope: {\bf global} \\
Type: {\bf optional}.\\
Intent: {\bf in}.\\
Values: 1: use the normwise backward error, 2: use the scaled 2-norm
of the residual. Default: 1.
\item[\bf On Return]
\item[x] The computed solution. \\
Scope: {\bf local} \\
Type: {\bf required}\\
Intent: {\bf inout}.\\
Specified as: a rank one array.
\item[iter] The number of iterations performed.\\
Scope: {\bf global} \\
Type: {\bf optional}\\
Intent: {\bf out}.\\
Returned as: an integer variable.
\item[err] The convergence estimate on exit.\\
Scope: {\bf global} \\
Type: {\bf optional}\\
Intent: {\bf out}.\\
Returned as: a real number.
\item[info] Error code.\\
Scope: {\bf local} \\
Type: {\bf required} \\
Intent: {\bf out}.\\
An integer value; 0 means no error has been detected.
\end{description}
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% %
%% % CG
%% %
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% \subroutine{psb\_cg \label{cg}}{CG Iterative Method}
%% This subroutine implements the CG method with restarting. The
%% stopping criterion is the normwise backward error, in the infinity
%% norm, i.e. the iteration is stopped when
%% \[ \frac{\|r\|}{(\|A\|\|x\|+\|b\|)} < eps \]
%% or
%% \[ \frac{\|r_i\|}{\|b\|_2} < eps \]
%% according to the value passed through the istop argument (see later).
%% \syntax{call psb\_cg}{a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,istop}
%% \begin{description}
%% \item[\bf On Entry]
%% \item[a] the local portion of global sparse matrix
%% $A$. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \spdata.
%% \item[prec] The data structure containing the preconditioner.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \precdata.
%% \item[b] The RHS vector. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[x] The initial guess. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[eps] The stopping tolerance. \\
%% Scope: {\bf global} \\
%% Type: {\bf required}\\
%% Specified as: a real number.
%% \item[desc\_a] contains data structures for communications.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \descdata.
%% \item[itmax] The maximum number of iterations to perform.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Default: $itmax = 1000$.\\
%% Specified as: an integer variable $itmax \ge 1$.
%% \item[itrace] If $>0$ print out an informational message about
%% convergence every $itrace$ iterations.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[istop] An integer specifying the stopping criterion.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[\bf On Return]
%% \item[x] The computed solution. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[iter] The number of iterations performed.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: an integer variable.
%% \item[err] The error estimate on exit.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: a real number.
%% \item[info] Error code.\\
%% Scope: {\bf local} \\
%% Type: {\bf required} \\
%% An integer value; 0 means no error has been detected.
%% \end{description}
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% %
%% % CGS
%% %
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% \subroutine{psb\_cgs \label{cgs}}{CGS Iterative Method}
%% This subroutine implements the CGS method with restarting. The
%% stopping criterion is the normwise backward error, in the infinity
%% norm, i.e. the iteration is stopped when
%% \[ \frac{\|r\|}{(\|A\|\|x\|+\|b\|)} < eps \]
%% or
%% \[ \frac{\|r_i\|}{\|b\|_2} < eps \]
%% according to the value passed through the istop argument (see later).
%% \syntax{call psb\_cgs}{a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,istop}
%% \begin{description}
%% \item[\bf On Entry]
%% \item[a] the local portion of global sparse matrix
%% $A$. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \spdata.
%% \item[prec] The data structure containing the preconditioner.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \precdata.
%% \item[b] The RHS vector. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[x] The initial guess. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[eps] The stopping tolerance. \\
%% Scope: {\bf global} \\
%% Type: {\bf required}\\
%% Specified as: a real number.
%% \item[desc\_a] contains data structures for communications.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \descdata.
%% \item[itmax] The maximum number of iterations to perform.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Default: $itmax = 1000$.\\
%% Specified as: an integer variable $itmax \ge 1$.
%% \item[itrace] If $>0$ print out an informational message about
%% convergence every $itrace$ iterations.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[istop] An integer specifying the stopping criterion.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[\bf On Return]
%% \item[x] The computed solution. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[iter] The number of iterations performed.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: an integer variable.
%% \item[err] The error estimate on exit.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: a real number.
%% \item[info] Error code.\\
%% Scope: {\bf local} \\
%% Type: {\bf required} \\
%% An integer value; 0 means no error has been detected.
%% \end{description}
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% %
%% % BiCG
%% %
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% \subroutine{psb\_bicg \label{bicg}}{BiCG Iterative Method}
%% This subroutine implements the BiCG method with restarting. The
%% stopping criterion is the normwise backward error, in the infinity
%% norm, i.e. the iteration is stopped when
%% \[ \frac{\|r\|}{(\|A\|\|x\|+\|b\|)} < eps \]
%% or
%% \[ \frac{\|r_i\|}{\|b\|_2} < eps \]
%% according to the value passed through the istop argument (see later).
%% \syntax{call psb\_bicg}{a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,istop}
%% \begin{description}
%% \item[\bf On Entry]
%% \item[a] the local portion of global sparse matrix
%% $A$. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \spdata.
%% \item[prec] The data structure containing the preconditioner.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \precdata.
%% \item[b] The RHS vector. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[x] The initial guess. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[eps] The stopping tolerance. \\
%% Scope: {\bf global} \\
%% Type: {\bf required}\\
%% Specified as: a real number.
%% \item[desc\_a] contains data structures for communications.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \descdata.
%% \item[itmax] The maximum number of iterations to perform.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Default: $itmax = 1000$.\\
%% Specified as: an integer variable $itmax \ge 1$.
%% \item[itrace] If $>0$ print out an informational message about
%% convergence every $itrace$ iterations.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[istop] An integer specifying the stopping criterion.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[\bf On Return]
%% \item[x] The computed solution. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[iter] The number of iterations performed.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: an integer variable.
%% \item[err] The error estimate on exit.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: a real number.
%% \item[info] Error code.\\
%% Scope: {\bf local} \\
%% Type: {\bf required} \\
%% An integer value; 0 means no error has been detected.
%% \end{description}
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% %
%% % BiCGSTAB
%% %
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% \subroutine{psb\_bicgstab \label{bicgstab}}{BiCGSTAB Iterative Method}
%% This subroutine implements the BiCGSTAB method with restarting. The
%% stopping criterion is the normwise backward error, in the infinity
%% norm, i.e. the iteration is stopped when
%% \[ \frac{\|r\|}{(\|A\|\|x\|+\|b\|)} < eps \]
%% or
%% \[ \frac{\|r_i\|}{\|b\|_2} < eps \]
%% according to the value passed through the istop argument (see later).
%% \syntax{call psb\_bicgstab}{a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,istop}
%% \begin{description}
%% \item[\bf On Entry]
%% \item[a] the local portion of global sparse matrix
%% $A$. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \spdata.
%% \item[prec] The data structure containing the preconditioner.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \precdata.
%% \item[b] The RHS vector. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[x] The initial guess. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[eps] The stopping tolerance. \\
%% Scope: {\bf global} \\
%% Type: {\bf required}\\
%% Specified as: a real number.
%% \item[desc\_a] contains data structures for communications.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \descdata.
%% \item[itmax] The maximum number of iterations to perform.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Default: $itmax = 1000$.\\
%% Specified as: an integer variable $itmax \ge 1$.
%% \item[itrace] If $>0$ print out an informational message about
%% convergence every $itrace$ iterations.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[istop] An integer specifying the stopping criterion.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[\bf On Return]
%% \item[x] The computed solution. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[iter] The number of iterations performed.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: an integer variable.
%% \item[err] The error estimate on exit.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: a real number.
%% \item[info] Error code.\\
%% Scope: {\bf local} \\
%% Type: {\bf required} \\
%% An integer value; 0 means no error has been detected.
%% \end{description}
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% %
%% % BiCGSTAB(L)
%% %
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% \subroutine{psb\_bicgstabl \label{bicgstabl}}{BiCGSTAB-$l$ Iterative Method}
%% This subroutine implements the BiCGSTAB-$l$ method with restarting. The
%% stopping criterion is the normwise backward error, in the infinity
%% norm, i.e. the iteration is stopped when
%% \[ \frac{\|r\|}{(\|A\|\|x\|+\|b\|)} < eps \]
%% or
%% \[ \frac{\|r_i\|}{\|b\|_2} < eps \]
%% according to the value passed through the istop argument (see later).
%% \syntax{call psb\_bicgstab}{a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,irst,istop}
%% \begin{description}
%% \item[\bf On Entry]
%% \item[a] the local portion of global sparse matrix
%% $A$. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \spdata.
%% \item[prec] The data structure containing the preconditioner.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \precdata.
%% \item[b] The RHS vector. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[x] The initial guess. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[eps] The stopping tolerance. \\
%% Scope: {\bf global} \\
%% Type: {\bf required}\\
%% Specified as: a real number.
%% \item[desc\_a] contains data structures for communications.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \descdata.
%% \item[itmax] The maximum number of iterations to perform.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Default: $itmax = 1000$.\\
%% Specified as: an integer variable $itmax \ge 1$.
%% \item[itrace] If $>0$ print out an informational message about
%% convergence every $itrace$ iterations.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[irst] An integer specifying the restarting iteration.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[istop] An integer specifying the stopping criterion.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[\bf On Return]
%% \item[x] The computed solution. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[iter] The number of iterations performed.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: an integer variable.
%% \item[err] The error estimate on exit.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: a real number.
%% \item[info] Error code.\\
%% Scope: {\bf local} \\
%% Type: {\bf required} \\
%% An integer value; 0 means no error has been detected.
%% \end{description}
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% %
%% % GMRES
%% %
%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% \subroutine{psb\_gmres \label{gmres}}{GMRES Iterative Method}
%% This subroutine implements the GMRES method with restarting. The
%% stopping criterion is the normwise backward error, in the infinity
%% norm, i.e. the iteration is stopped when
%% \[ \frac{\|r\|}{(\|A\|\|x\|+\|b\|)} < eps \]
%% or
%% \[ \frac{\|r_i\|}{\|b\|_2} < eps \]
%% according to the value passed through the istop argument (see later).
%% \syntax{call psb\_gmres}{a,prec,b,x,eps,desc\_a,info,itmax,iter,err,itrace,irst,istop}
%% \begin{description}
%% \item[\bf On Entry]
%% \item[a] the local portion of global sparse matrix
%% $A$. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \spdata.
%% \item[prec] The data structure containing the preconditioner.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \precdata.
%% \item[b] The RHS vector. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[x] The initial guess. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[eps] The stopping tolerance. \\
%% Scope: {\bf global} \\
%% Type: {\bf required}\\
%% Specified as: a real number.
%% \item[desc\_a] contains data structures for communications.\\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a structured data of type \descdata.
%% \item[itmax] The maximum number of iterations to perform.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Default: $itmax = 1000$.\\
%% Specified as: an integer variable $itmax \ge 1$.
%% \item[itrace] If $>0$ print out an informational message about
%% convergence every $itrace$ iterations.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[irst] An integer specifying the restart iteration.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[istop] An integer specifying the stopping criterion.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% \item[\bf On Return]
%% \item[x] The computed solution. \\
%% Scope: {\bf local} \\
%% Type: {\bf required}\\
%% Specified as: a rank one array.
%% \item[iter] The number of iterations performed.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: an integer variable.
%% \item[err] The error estimate on exit.\\
%% Scope: {\bf global} \\
%% Type: {\bf optional}\\
%% Returned as: a real number.
%% \item[info] Error code.\\
%% Scope: {\bf local} \\
%% Type: {\bf required} \\
%% An integer value; 0 means no error has been detected.
%% \end{description}
%%% Local Variables:
%%% mode: latex
%%% TeX-master: "userguide"
%%% End:

@ -19,7 +19,8 @@ These preconditioners have the following general features:
\begin{itemize} \begin{itemize}
\item both \emph{additive and hybrid multilevel} variants are implemented, \item both \emph{additive and hybrid multilevel} variants are implemented,
i.e.\ variants that are additive among the levels and inside each level, and variants i.e.\ variants that are additive among the levels and inside each level, and variants
that are multiplicative among the levels and additive inside each level; the basic Additive Schwarz (AS) preconditioners are obtained by considering only one level; that are multiplicative among the levels and additive inside each level;
the basic Additive Schwarz (AS) preconditioners are obtained by considering only one level;
\item a \emph{purely algebraic} approach is used to \item a \emph{purely algebraic} approach is used to
generate a sequence of coarse-level corrections to a basic AS preconditioner, without generate a sequence of coarse-level corrections to a basic AS preconditioner, without
explicitly using any information on the geometry of the original problem (e.g.\ the explicitly using any information on the geometry of the original problem (e.g.\ the
@ -70,7 +71,20 @@ by expert users to build new versions of multi-level Schwarz preconditioners.
We provide here a description of the upper-layer routines, but not of the We provide here a description of the upper-layer routines, but not of the
medium-layer ones. medium-layer ones.
This guide is organized as follows. \textbf{ORGANIZZAZIONE DELLA GUIDA} This guide is organized as follows. The notational conventions used in
the guide and in the naming of the MLD2P4 routines are reported in
Section~\ref{sec:conventions}. Information on the distribution of the source code and the
related license is given in Section~\ref{sec:distribution}, while details on the configuration
and installation of package are given in Section~\ref{sec:building}. A description of
multi-level Schwarz preconditioners based on smoothed aggregation is provided
in Section~\ref{sec:background}, to help the users in choosing among the different preconditioners
implemented in MLD2P4. The basics for building and applying the preconditioners
with the Krylov solvers implemented in PSBLAS are reported in Section~\ref{sec:started}, where the
Fortran 95 codes of a few sample programs are also shown. A reference guide for
the upper-layer routines of MLD2P4, that are the user interface, is provided
in Section~\ref{sec:userinterface}. The error handling mechanism used by the package is briefly described
in Section~\ref{sec:errors}. The copyright terms concerning the distribution and modification
of MLD2P4 are reported in Appendix~\ref{sec:license}.
%%% Local Variables: %%% Local Variables:
%%% mode: latex %%% mode: latex

@ -35,7 +35,7 @@
% /URI (http://ce.uniroma2.it/psblas) % /URI (http://ce.uniroma2.it/psblas)
} }
% \setlength\oddsidemargin{.7in} \setlength\textwidth{1.15\textwidth}
% \setlength\evensidemargin{.7in} % \setlength\evensidemargin{.7in}
% \newlength{\centeroffset} % \newlength{\centeroffset}
% \setlength{\centeroffset}{0.5\oddsidemargin} % \setlength{\centeroffset}{0.5\oddsidemargin}

@ -7,7 +7,7 @@ The basic user interface of MLD2P4 consists of six routines. The four routines \
for the setup and the application of any one-level and multi-level for the setup and the application of any one-level and multi-level
preconditioner implemented in the package. preconditioner implemented in the package.
The routine \verb|mld_precfree| deallocates the preconditioner data structure, while The routine \verb|mld_precfree| deallocates the preconditioner data structure, while
\verb|mld_prec\-descr| prints a description of the preconditioner setup by the user. \verb|mld_precdescr| prints a description of the preconditioner setup by the user.
For each routine, the same user interface is overloaded with For each routine, the same user interface is overloaded with
respect to the real/complex case and the single/double precision; respect to the real/complex case and the single/double precision;
@ -32,8 +32,8 @@ i.e.
provides the constants \verb|psb_spk_| provides the constants \verb|psb_spk_|
= \verb|kind(1.e0)| and \verb|psb_dpk_| = \verb|kind(1.d0)|; = \verb|kind(1.e0)| and \verb|psb_dpk_| = \verb|kind(1.d0)|;
\item real parameters defining the preconditioner must be declared \item real parameters defining the preconditioner must be declared
according to the precision of the previous data structures according to the precision of the sparse matrix and preconditioner
(see Section~\ref{sec:precset}). data structures (see Section~\ref{sec:precset}).
\end{itemize} \end{itemize}
A description of each routine is given in the remainder of this section. A description of each routine is given in the remainder of this section.
@ -122,10 +122,10 @@ can be logically divided into four groups, i.e.\ parameters defining
\item the aggregation algorithm; \item the aggregation algorithm;
\item the coarse-space correction at the coarsest level. \item the coarse-space correction at the coarsest level.
\end{enumerate} \end{enumerate}
A list of the parameters that can be set, along with allowed and A list of the parameters that can be set, along with their allowed and
default values, is given in Tables~\ref{tab:p_type}-\ref{tab:p_coarse}. default values, is given in Tables~\ref{tab:p_type}-\ref{tab:p_coarse}.
For a detailed description of the meaning of the parameters, please For a detailed description of the meaning of the parameters, please
see Section~\ref{sec:background}. refer to Section~\ref{sec:background}.
% %
%Note that the routine allows to set different features of the %Note that the routine allows to set different features of the
%preconditioner at each level through the use of \verb|ilev|. %preconditioner at each level through the use of \verb|ilev|.
@ -144,19 +144,18 @@ see Section~\ref{sec:background}.
\verb|mld_ml_type_| & \verb|character(len=*)| \verb|mld_ml_type_| & \verb|character(len=*)|
& \texttt{'ADD'} \ \ \ \texttt{'MULT'} & \texttt{'ADD'} \ \ \ \texttt{'MULT'}
& \texttt{'MULT'} & \texttt{'MULT'}
& basic multi-level framework: additive or multiplicative & Basic multi-level framework: additive or multiplicative
among the levels (always additive inside a level) \\ among the levels (always additive inside a level). \\ \hline
\verb|mld_smoother_type_|& \verb|character(len=*)| \verb|mld_smoother_type_|& \verb|character(len=*)|
& \texttt{'DIAG'} \ \ \ \texttt{'BJAC'} \ \ \ \texttt{'AS'} & \texttt{'DIAG'} \ \ \ \texttt{'BJAC'} \ \ \ \texttt{'AS'}
& \texttt{'AS'} & \texttt{'AS'}
& basic one-level preconditioner (i.e.\ smoother) of the & Basic one-level preconditioner (i.e.\ smoother): diagonal,
multi-level preconditioner: diagonal, block Jacobi, block Jacobi, AS \\ \hline
AS \\
\verb|mld_smoother_pos_| & \verb|character(len=*)| \verb|mld_smoother_pos_| & \verb|character(len=*)|
& \texttt{'PRE'} \ \ \ \texttt{'POST'} \ \ \ \texttt{'TWOSIDE'} & \texttt{'PRE'} \ \ \ \texttt{'POST'} \ \ \ \texttt{'TWOSIDE'}
& \texttt{'POST'} & \texttt{'POST'}
& ``position'' of the smoother: pre-smoother, post-smoother, & ``Position'' of the smoother: pre-smoother, post-smoother,
pre- and post-smoother \\ pre- and post-smoother. \\
\hline \hline
\end{tabular} \end{tabular}
\end{center} \end{center}
@ -166,7 +165,7 @@ see Section~\ref{sec:background}.
\begin{sidewaystable} \begin{sidewaystable}
\begin{center} \begin{center}
\begin{tabular}{|l|l|p{2.6cm}|l|p{7cm}|} \begin{tabular}{|l|l|p{3.2cm}|l|p{7cm}|}
\hline \hline
\verb|what| & \textsc{data type} & \verb|val| & \textsc{default} & \verb|what| & \textsc{data type} & \verb|val| & \textsc{default} &
\textsc{comments} \\ \hline \textsc{comments} \\ \hline
@ -174,35 +173,35 @@ see Section~\ref{sec:background}.
\verb|mld_sub_ovr_| & \verb|integer| \verb|mld_sub_ovr_| & \verb|integer|
& any integer number $\ge 0$ & any integer number $\ge 0$
& 1 & 1
& Number of overlap layers. \\ & Number of overlap layers. \\ \hline
\verb|mld_sub_restr_| & \verb|character(len=*)| \verb|mld_sub_restr_| & \verb|character(len=*)|
& \texttt{'HALO'} \ \ \ \ \ \texttt{'NONE'} & \texttt{'HALO'} \hspace{2.5cm} \texttt{'NONE'}
& \texttt{'HALO'} & \texttt{'HALO'}
& Type of restriction operator: & Type of restriction operator:
\texttt{'HALO'} for taking into account the overlap, \texttt{'NONE'} \texttt{'HALO'} for taking into account the overlap, \texttt{'NONE'}
for neglecting it. \\ for neglecting it. \\ \hline
\verb|mld_sub_prol_| & \verb|character(len=*)| \verb|mld_sub_prol_| & \verb|character(len=*)|
& \texttt{'SUM'} \ \ \ \ \ \texttt{'NONE'} & \texttt{'SUM'} \hspace{2.5cm} \texttt{'NONE'}
& \texttt{'NONE'} & \texttt{'NONE'}
& Type of prolongator operator: & Type of prolongator operator:
\texttt{'SUM'} for adding the contributions from the overlap, \texttt{'NONE'} \texttt{'SUM'} for adding the contributions from the overlap, \texttt{'NONE'}
for neglecting them. \\ for neglecting them. \\ \hline
\verb|mld_sub_solve_| & \verb|character(len=*)| \verb|mld_sub_solve_| & \verb|character(len=*)|
& \texttt{'ILU'} \ \ \ \ \ \texttt{'MILU'} \ \ \ \ \ \texttt{'ILUT'} \ \ \ \ \ & \texttt{'ILU'} \hspace{2.5cm} \texttt{'MILU'} \hspace{2.5cm} \texttt{'ILUT'}
\texttt{'UMF'} \ \ \ \ \ \texttt{'SLU'} \hspace{2.5cm} \texttt{'UMF'} \hspace{2.5cm} \texttt{'SLU'}
& \texttt{'UMF'} & \texttt{'UMF'}
& Local solver: ILU($p$), MILU($p$), ILU($p,t$), LU from UMFPACK, LU from SuperLU, & Local solver: ILU($p$), MILU($p$), ILU($p,t$), LU from UMFPACK, LU from SuperLU
plus triangular solve. \\ (plus triangular solve). \\ \hline
\verb|mld_sub_fillin_| & \verb|integer| \verb|mld_sub_fillin_| & \verb|integer|
& any integer number $\ge 0$ & Any~int.~num.~$\ge 0$
& 0 & 0
& Fill-in level $p$ of the incomplete LU factorizations. \\ & Fill-in level $p$ of the incomplete LU factorizations. \\ \hline
\verb|mld_sub_thresh_| & \verb|real(|\emph{kind\_parameter}\verb|)| \verb|mld_sub_thresh_| & \verb|real(|\emph{kind\_parameter}\verb|)|
& any real number $\ge 0$ & Any~real~num.~$\ge 0$
& \texttt{0.e0} (or \texttt{0.d0}) & \texttt{0.e0} (or \texttt{0.d0})
& Drop tolerance $t$ in the ILU($p,t$) factorization. \\ & Drop tolerance $t$ in the ILU($p,t$) factorization. \\ \hline
\verb|mld_sub_ren_| & \verb|character(len=*)| \verb|mld_sub_ren_| & \verb|character(len=*)|
& \texttt{'RENUM\_NONE'}, \texttt{'RENUM\_GLOBAL'} %, \texttt{'RENUM_GPS'} & \texttt{'RENUM\_NONE'} \texttt{'RENUM\_GLOBAL'} %, \texttt{'RENUM_GPS'}
& \texttt{'RENUM\_NONE'} & \texttt{'RENUM\_NONE'}
& Row and column reordering of the local submatrices: no reordering, & Row and column reordering of the local submatrices: no reordering,
reordering according to the global numbering of the rows and columns of reordering according to the global numbering of the rows and columns of
@ -216,7 +215,7 @@ see Section~\ref{sec:background}.
\begin{sidewaystable} \begin{sidewaystable}
\begin{center} \begin{center}
\begin{tabular}{|l|l|p{2.6cm}|l|p{7cm}|} \begin{tabular}{|l|l|p{2.3cm}|p{2.6cm}|p{7cm}|}
\hline \hline
\verb|what| & \textsc{data type} & \verb|val| & \textsc{default} & \verb|what| & \textsc{data type} & \verb|val| & \textsc{default} &
\textsc{comments} \\ \hline \textsc{comments} \\ \hline
@ -224,21 +223,25 @@ see Section~\ref{sec:background}.
\verb|mld_aggr_alg_| & \verb|character(len=*)| \verb|mld_aggr_alg_| & \verb|character(len=*)|
& \texttt{'DEC'} & \texttt{'DEC'}
& \texttt{'DEC'} & \texttt{'DEC'}
& Aggregation algorithm. Currently, only the decoupled aggregation is available. \\ & Aggregation algorithm. Currently, only the decoupled aggregation is available. \\ \hline
\verb|mld_aggr_kind_| & \verb|character(len=*)| \verb|mld_aggr_kind_| & \verb|character(len=*)|
& \texttt{'SMOOTH'} \ \ \ \ \ \texttt{'RAW'} & \texttt{'SMOOTH'} \hspace{2.5cm} \texttt{'RAW'}
& \texttt{'SMOOTH'} & \texttt{'SMOOTH'}
& Type of aggregation: smoothed or raw, i.e.\ using the tentative prolongator. \\ & Type of aggregation: smoothed or raw, i.e.\ using the tentative prolongator. \\ \hline
\verb|mld_aggr_thresh_| & \verb|real(|\emph{kind\_parameter}\verb|)| \verb|mld_aggr_thresh_| & \verb|real(|\emph{kind\_parameter}\verb|)|
& any real number $\in [0, 1]$ & Any~real~num. $\in [0, 1]$
& \texttt{0.e0} (or \texttt{0.d0}) & \texttt{0.e0} (or \texttt{0.d0})
& The threshold $\theta$ in the aggregation algorithm. \\ & The threshold $\theta$ in the aggregation algorithm. \\ \hline
\verb|mld_aggr_eig_| & \verb|character(len=*)| \verb|mld_aggr_eig_| & \verb|character(len=*)|
& \texttt{'A\_NORMI'} & \texttt{'A\_NORMI'}
& \texttt{'A\_NORMI'} & \texttt{'A\_NORMI'}
& Estimate of the maximum eigenvalue of $D^{-1}A$ & Estimate of the maximum eigenvalue of $D^{-1}A$
for the smoothed aggregation. Currently, only the infinity norm of for the smoothed aggregation. Currently, only the infinity norm of
the matrix is available. \\ the matrix is available. \\ \hline
\verb|mld_aggr_damp_| & \verb|real(|\emph{kind\_parameter}\verb|)|
& Any~real~num. $>0$
& \texttt{4.e0/3.e0} \hspace{1cm} (or \texttt{4.d0/3.d0})
& The damping parameter $\omega$ in the aggregation algorithm. \\
\hline \hline
\end{tabular} \end{tabular}
\end{center} \end{center}
@ -248,41 +251,41 @@ see Section~\ref{sec:background}.
\begin{sidewaystable} \begin{sidewaystable}
\begin{center} \begin{center}
\begin{tabular}{|l|l|p{2.6cm}|l|p{7cm}|} \begin{tabular}{|l|l|p{3.2cm}|l|p{7cm}|}
\hline \hline
\verb|what| & \textsc{data type} & \verb|val| & \textsc{default} & \verb|what| & \textsc{data type} & \verb|val| & \textsc{default} &
\textsc{comments} \\ \hline \textsc{comments} \\ \hline
%\multicolumn{5}{|c|}{\emph{coarse-space correction at the coarsest level}}\\ \hline %\multicolumn{5}{|c|}{\emph{coarse-space correction at the coarsest level}}\\ \hline
\verb|mld_coarse_mat_| & \verb|character(len=*)| \verb|mld_coarse_mat_| & \verb|character(len=*)|
& \texttt{'DISTR'} \ \ \ \ \ \texttt{'REPL'} & \texttt{'DISTR'} \hspace{2.5cm} \texttt{'REPL'}
& \texttt{'DISTR'} & \texttt{'DISTR'}
& Coarsest matrix: distributed among the processors or replicated on each of them. \\ & Coarsest matrix: distributed among the processors or replicated on each of them. \\ \hline
\verb|mld_coarse_solve_| & \verb|character(len=*)| \verb|mld_coarse_solve_| & \verb|character(len=*)|
& \texttt{'BJAC'} \ \ \ \ \ \texttt{'UMF'} \ \ \ \ \ \ \ \ \texttt{'SLU'} & \texttt{'BJAC'} \hspace{2.5cm} \texttt{'UMF'} \hspace{2.5cm} \texttt{'SLU'}
\ \ \ \ \ \texttt{'SLUDIST'} \hspace{2.5cm} \texttt{'SLUDIST'}
& \texttt{'BJAC'} & \texttt{'BJAC'}
& Solver used at the coarsest level: block Jacobi, sequential LU from UMFPACK, & Solver used at the coarsest level: block Jacobi, sequential LU from UMFPACK,
sequential LU from SuperLU, or distributed LU from SuperLU\_Dist. sequential LU from SuperLU, distributed LU from SuperLU\_Dist.
If the coarsest matrix is distributed, only \texttt{'BJAC'} and \texttt{'SLUDIST'} If the coarsest matrix is distributed, only \texttt{'BJAC'} and \texttt{'SLUDIST'}
can be chosen; if it is replicated, only \emph{'BJAC'} or \texttt{'SLUDIST'} can can be chosen; if it is replicated, only \texttt{'BJAC'} or \texttt{'SLUDIST'} can
be selected. \\ be selected. \\ \hline
\verb|mld_coarse_subsolve_| & \verb|character(len=*)| \verb|mld_coarse_subsolve_| & \verb|character(len=*)|
& \texttt{'ILU'} \ \ \ \ \ \ \ \texttt{'MILU'} \ \ \ \ \ \ \ \ \texttt{'ILUT'} & \texttt{'ILU'} \hspace{2.5cm} \texttt{'MILU'} \hspace{2.5cm} \texttt{'ILUT'}
\ \ \ \ \ \ \ \texttt{'UMF'} \ \ \ \ \ \ \ \texttt{'SLU'} \hspace{2.5cm} \texttt{'UMF'} \hspace{2.5cm} \texttt{'SLU'}
& \texttt{'UMF'} & \texttt{'UMF'}
& Solver for the diagonal blocks of the coarse matrix, in case the block Jacobi solver & Solver for the diagonal blocks of the coarse matrix, in case the block Jacobi solver
is chosen as coarsest-level solver: ILU($p$), MILU($p$), ILU($p,t$), LU from UMFPACK, is chosen as coarsest-level solver: ILU($p$), MILU($p$), ILU($p,t$), LU from UMFPACK,
LU from SuperLU, plus triangular solve. \\ LU from SuperLU, plus triangular solve. \\ \hline
\verb|mld_coarse_sweeps_|& \verb|integer| \verb|mld_coarse_sweeps_|& \verb|integer|
& any integer number $> 0$ & Any~int.~num.~$> 0$
& \texttt{4} & \texttt{4}
& Number of Block-Jacobi sweeps when 'BJAC' is used as coarsest-level solver. \\ & Number of Block-Jacobi sweeps when 'BJAC' is used as coarsest-level solver. \\
\verb|mld_coarse_fillin_| & \verb|integer| \verb|mld_coarse_fillin_| & \verb|integer|
& any integer number $\ge 0$ & Any~int.~num.~$\ge 0$
& \texttt{0} & \texttt{0}
& Fill-in level $p$ of the incomplete LU factorizations. \\ & Fill-in level $p$ of the incomplete LU factorizations. \\ \hline
\verb|mld_coarse_thresh_| & \verb|real(|\emph{kind\_parameter}\verb|)| \verb|mld_coarse_thresh_| & \verb|real(|\emph{kind\_parameter}\verb|)|
& any real number $\ge 0$ & Any~real.~num.~$\ge 0$
& \texttt{0.d0} (or \texttt{0.e0}) & \texttt{0.d0} (or \texttt{0.e0})
& Drop tolerance $t$ in the ILU($p,t$) factorization. \\ & Drop tolerance $t$ in the ILU($p,t$) factorization. \\
\hline \hline
@ -395,6 +398,7 @@ This routine deallocates the preconditioner data structure.
\subsection{Subroutine mld\_precdescr\label{sec:precdescr}} \subsection{Subroutine mld\_precdescr\label{sec:precdescr}}
\begin{center} \begin{center}
\verb|mld_precdescr(p,info)|\\
\verb|mld_precdescr(p,info,iout)|\\ \verb|mld_precdescr(p,info,iout)|\\
\end{center} \end{center}

File diff suppressed because one or more lines are too long

@ -47,8 +47,11 @@
! build the coarse-level matrix. ! build the coarse-level matrix.
! !
! The aggregation algorithm is a parallel version of that described in ! The aggregation algorithm is a parallel version of that described in
! M. Brezina and P. Vanek, A black-box iterative solver based on a ! * M. Brezina and P. Vanek, A black-box iterative solver based on a
! two-level Schwarz method, Computing, 63 (1999), 233-263. ! two-level Schwarz method, Computing, 63 (1999), 233-263.
! * P. Vanek, J. Mandel and M. Brezina, Algebraic Multigrid by Smoothed
! Aggregation for Second and Fourth Order Elliptic Problems, Computing, 56
! (1996), 179-196.
! For more details see ! For more details see
! P. D'Ambra, D. di Serafino and S. Filippone, On the development of ! P. D'Ambra, D. di Serafino and S. Filippone, On the development of
! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math. ! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math.

@ -91,7 +91,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
info = 3111 info = 3111
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
return return
endif endif
nlev_ = size(p%baseprecv) nlev_ = size(p%baseprecv)
@ -110,7 +110,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
info = 3111 info = 3111
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
return return
endif endif
@ -162,13 +162,16 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case default case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
end select end select
endif endif
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
@ -204,7 +207,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
do ilev_=1,max(1,nlev_-1) do ilev_=1,max(1,nlev_-1)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -215,7 +218,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
do ilev_=2,nlev_-1 do ilev_=2,nlev_-1
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -224,7 +227,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
case(mld_coarse_mat_) case(mld_coarse_mat_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
& ': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' & ': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -232,28 +235,29 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
case(mld_coarse_solve_) case(mld_coarse_solve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case(mld_bjac_) case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_ilu_n_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
case default & p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
end select end select
endif endif
case(mld_coarse_subsolve_) case(mld_coarse_subsolve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
end if end if
@ -262,7 +266,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -270,7 +274,7 @@ subroutine mld_cprecseti(p,what,val,info,ilev)
case(mld_coarse_fillin_) case(mld_coarse_fillin_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -355,7 +359,7 @@ subroutine mld_cprecsetc(p,what,string,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -427,7 +431,7 @@ subroutine mld_cprecsetr(p,what,val,info,ilev)
end if end if
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -439,7 +443,7 @@ subroutine mld_cprecsetr(p,what,val,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -480,16 +484,24 @@ subroutine mld_cprecsetr(p,what,val,info,ilev)
case(mld_fact_thrs_) case(mld_fact_thrs_)
do ilev_=1,nlev_ do ilev_=1,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
p%baseprecv(ilev_)%rprcparm(what) = val p%baseprecv(ilev_)%rprcparm(what) = val
end do end do
case(mld_coarse_fthrs_)
ilev_=nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1
return
endif
p%baseprecv(ilev_)%rprcparm(mld_fact_thrs_) = val
case(mld_aggr_damp_) case(mld_aggr_damp_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -498,7 +510,7 @@ subroutine mld_cprecsetr(p,what,val,info,ilev)
case(mld_aggr_thresh_) case(mld_aggr_thresh_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif

@ -47,8 +47,11 @@
! build the coarse-level matrix. ! build the coarse-level matrix.
! !
! The aggregation algorithm is a parallel version of that described in ! The aggregation algorithm is a parallel version of that described in
! M. Brezina and P. Vanek, A black-box iterative solver based on a ! * M. Brezina and P. Vanek, A black-box iterative solver based on a
! two-level Schwarz method, Computing, 63 (1999), 233-263. ! two-level Schwarz method, Computing, 63 (1999), 233-263.
! * P. Vanek, J. Mandel and M. Brezina, Algebraic Multigrid by Smoothed
! Aggregation for Second and Fourth Order Elliptic Problems, Computing, 56
! (1996), 179-196.
! For more details see ! For more details see
! P. D'Ambra, D. di Serafino and S. Filippone, On the development of ! P. D'Ambra, D. di Serafino and S. Filippone, On the development of
! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math. ! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math.

@ -91,7 +91,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
info = 3111 info = 3111
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
return return
endif endif
nlev_ = size(p%baseprecv) nlev_ = size(p%baseprecv)
@ -110,7 +110,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
info = 3111 info = 3111
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
return return
endif endif
@ -162,13 +162,16 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case default case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
end select end select
endif endif
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
@ -204,7 +207,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
do ilev_=1,max(1,nlev_-1) do ilev_=1,max(1,nlev_-1)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -215,7 +218,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
do ilev_=2,nlev_-1 do ilev_=2,nlev_-1
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -224,7 +227,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
case(mld_coarse_mat_) case(mld_coarse_mat_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
& ': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' & ': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -232,28 +235,29 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
case(mld_coarse_solve_) case(mld_coarse_solve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case(mld_bjac_) case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_ilu_n_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
case default & p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
end select end select
endif endif
case(mld_coarse_subsolve_) case(mld_coarse_subsolve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
end if end if
@ -262,7 +266,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -270,7 +274,7 @@ subroutine mld_dprecseti(p,what,val,info,ilev)
case(mld_coarse_fillin_) case(mld_coarse_fillin_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -355,7 +359,7 @@ subroutine mld_dprecsetc(p,what,string,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -426,7 +430,7 @@ subroutine mld_dprecsetr(p,what,val,info,ilev)
end if end if
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -438,7 +442,7 @@ subroutine mld_dprecsetr(p,what,val,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -479,7 +483,7 @@ subroutine mld_dprecsetr(p,what,val,info,ilev)
case(mld_fact_thrs_) case(mld_fact_thrs_)
do ilev_=1,nlev_ do ilev_=1,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -488,7 +492,7 @@ subroutine mld_dprecsetr(p,what,val,info,ilev)
case(mld_coarse_fthrs_) case(mld_coarse_fthrs_)
ilev_=nlev_ ilev_=nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -496,7 +500,7 @@ subroutine mld_dprecsetr(p,what,val,info,ilev)
case(mld_aggr_damp_) case(mld_aggr_damp_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -505,7 +509,7 @@ subroutine mld_dprecsetr(p,what,val,info,ilev)
case(mld_aggr_thresh_) case(mld_aggr_thresh_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif

@ -334,28 +334,28 @@ module mld_prec_type
! !
! Character constants used by mld_file_prec_descr ! Character constants used by mld_file_prec_descr
! !
character(len=19), parameter, private :: &
& smooth_names(1:3)=(/'pre-smoothing ','post-smoothing ',&
& 'pre/post-smoothing'/)
character(len=15), parameter, private :: & character(len=15), parameter, private :: &
& smooth_names(1:3)=(/'Pre-smoothing ','Post-smoothing',& & aggr_kinds(0:2)=(/'no smoother ','omega smoother',&
& 'Smooth both '/) & 'bizr. smoother'/)
character(len=15), parameter, private :: & character(len=15), parameter, private :: &
& aggr_kinds(0:2)=(/'No smoother ','Omega smoother',& & matrix_names(0:1)=(/'distributed ','replicated '/)
& 'Bizr. smoother'/)
character(len=15), parameter, private :: &
& matrix_names(0:1)=(/'Distributed ','Replicated '/)
character(len=18), parameter, private :: & character(len=18), parameter, private :: &
& aggr_names(0:4)=(/'Local aggregation ','Sym. local aggr. ',& & aggr_names(0:4)=(/'local aggregation ','sym. local aggr. ',&
& 'Global aggregation', 'New local aggr. ','New global aggr. '/) & 'global aggregation', 'new local aggr. ','new global aggr. '/)
character(len=6), parameter, private :: & character(len=6), parameter, private :: &
& restrict_names(0:4)=(/'None ','Halo ',' ',' ',' '/) & restrict_names(0:4)=(/'none ','halo ',' ',' ',' '/)
character(len=12), parameter, private :: & character(len=12), parameter, private :: &
& prolong_names(0:3)=(/'None ','Sum ','Average ','Square root'/) & prolong_names(0:3)=(/'none ','sum ','average ','square root'/)
character(len=15), parameter, private :: & character(len=15), parameter, private :: &
& ml_names(0:3)=(/'None ','Additive ','Multiplicative',& & ml_names(0:3)=(/'none ','additive ','multiplicative',&
& 'New ML '/) & 'new ML '/)
character(len=15), parameter, private :: & character(len=15), parameter, private :: &
& fact_names(0:6)=(/'None ','ILU(n) ',& & fact_names(0:6)=(/'none ','ILU(n) ',&
& 'MILU(n) ','ILU(T) ',& & 'MILU(n) ','ILU(t,n) ',&
& 'Sparse SuperLU','UMFPACK Sp. LU',& & 'SuperLU ','UMFPACK LU ',&
& 'SuperLU_Dist '/) & 'SuperLU_Dist '/)
! !
@ -428,6 +428,8 @@ contains
val = psb_sum_ val = psb_sum_
case('AVG') case('AVG')
val = psb_avg_ val = psb_avg_
case('FACT_NONE')
val = mld_f_none_
case('ILU') case('ILU')
val = mld_ilu_n_ val = mld_ilu_n_
case('MILU') case('MILU')
@ -462,7 +464,7 @@ contains
val = mld_pre_smooth_ val = mld_pre_smooth_
case('POST') case('POST')
val = mld_post_smooth_ val = mld_post_smooth_
case('TWOSIDE','BOTH') case('TWOSIDE')
val = mld_twoside_smooth_ val = mld_twoside_smooth_
case('NOPREC') case('NOPREC')
val = mld_noprec_ val = mld_noprec_
@ -703,62 +705,98 @@ contains
! Subroutine: mld_file_prec_descr ! Subroutine: mld_file_prec_descr
! Version: real ! Version: real
! !
! This routine prints to a file a description of the preconditioner. ! This routine prints a description of the preconditioner to the standard
! output or to a file. It must be called after the preconditioner has been
! built by mld_precbld.
! !
! Arguments: ! Arguments:
! p - type(mld_dprec_type), input. ! p - type(mld_dprec_type), input.
! The preconditioner data structure to be printed out. ! The preconditioner data structure to be printed out.
! iout - integer, input. ! info - integer, output.
! error code.
! iout - integer, input, optional.
! The id of the file where the preconditioner description ! The id of the file where the preconditioner description
! will be printed. ! will be printed. If iout is not present, then the standard
! output is condidered.
! !
subroutine mld_file_prec_descr(p,iout) subroutine mld_file_prec_descr(p,info,iout)
use psb_base_mod, only : psb_cd_get_context, psb_info
! Arguments ! Arguments
type(mld_dprec_type), intent(in) :: p type(mld_dprec_type), intent(in) :: p
integer, intent(out) :: info
integer, intent(in), optional :: iout integer, intent(in), optional :: iout
! Local variables ! Local variables
integer :: ilev integer :: ilev, nlev
integer :: ictxt, me, np
character(len=20), parameter :: name='mld_file_prec_descr' character(len=20), parameter :: name='mld_file_prec_descr'
integer :: iout_ integer :: iout_
info = 0
if (present(iout)) then if (present(iout)) then
iout_ = iout iout_ = iout
else else
iout_ = 6 iout_ = 6
end if end if
if (iout_ < 0) iout_ = 6
write(iout_,*) 'Preconditioner description'
if (allocated(p%baseprecv)) then if (allocated(p%baseprecv)) then
if (size(p%baseprecv)>=1) then ictxt = psb_cd_get_context(p%baseprecv(1)%desc_data)
call psb_info(ictxt,me,np)
!
! The preconditioner description is printed by processor psb_root_.
! This agrees with the fact that all the parameters defining the
! preconditioner have the same values on all the procs (this is
! ensured by mld_precbld).
!
if (me==psb_root_) then
write(iout_,*) 'Preconditioner description'
nlev = size(p%baseprecv)
if (nlev >= 1) then
!
! Print description of base preconditioner
!
write(iout_,*) ' '
if (nlev > 1) then
write(iout_,*) ' Multilevel Schwarz'
write(iout_,*) ' Base preconditioner (smoother) details'
endif
ilev = 1 ilev = 1
write(iout_,*) 'Base preconditioner'
select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_)) select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_))
case(mld_noprec_) case(mld_noprec_)
write(iout_,*) ' No preconditioning' write(iout_,*) ' No preconditioning'
case(mld_diag_) case(mld_diag_)
write(iout_,*) ' Diagonal scaling' write(iout_,*) ' Diagonal scaling'
case(mld_bjac_) case(mld_bjac_)
write(iout_,*) 'Block Jacobi with: ',& write(iout_,*) ' Block Jacobi with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
case(mld_as_) case(mld_as_)
write(iout_,*) 'Additive Schwarz with: ',& write(iout_,*) ' Additive Schwarz with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
@ -771,19 +809,40 @@ contains
write(iout_,*) ' Prolongation: ',& write(iout_,*) ' Prolongation: ',&
& prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_)) & prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_))
end select end select
end if end if
if (size(p%baseprecv)>=2) then
do ilev = 2, size(p%baseprecv) if (nlev > 1) then
!
! Print multilevel details
!
write(iout_,*) ' Multilevel details'
do ilev = 2, nlev
if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then
write(iout_,*) 'Inconsistent MLPREC part!' info = 3111
write(iout_,*) ' ',name,': error: inconsistent MLPREC part, should call MLD_PRECINIT'
return return
endif endif
end do
write(iout_,*) ' Number of levels: ',nlev
!
! Currently, all the preconditioner parameters must have the same value at levels
! 2,...,nlev-1, hence only the values at level 2 are printed
!
write(iout_,*) 'Multilevel: Level No', ilev ilev=2
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Multilevel type: ',& write(iout_,*) ' Multilevel type: ',&
& ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_)) & ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_))
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then write(iout_,*) ' Smoother position: ',&
write(iout_,*) 'Multilevel aggregation: ', & & smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
write(iout_,*) ' Aggregation: ', &
& aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_)) & aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_))
write(iout_,*) ' Aggregation smoothing: ', & write(iout_,*) ' Aggregation smoothing: ', &
& aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_)) & aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_))
@ -792,86 +851,157 @@ contains
if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then
write(iout_,*) ' Damping omega: ', & write(iout_,*) ' Damping omega: ', &
& p%baseprecv(ilev)%rprcparm(mld_aggr_damp_) & p%baseprecv(ilev)%rprcparm(mld_aggr_damp_)
write(iout_,*) 'Multilevel smoother position: ',&
& smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
end if end if
write(iout_,*) 'Coarse matrix: ',& endif
!
! Coarse matrices are different at levels 2,...,nlev-1, hence related
! info is printed separately
!
do ilev = 2, nlev-1
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev
if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) ' Size of coarse matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', &
& p%baseprecv(ilev)%nlaggr(:)
end if
end if
end do
!
! Print coarsest level details
!
ilev = nlev
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev,' (coarsest)'
write(iout_,*) ' Coarsest matrix: ',&
& matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_)) & matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_))
if (allocated(p%baseprecv(ilev)%nlaggr)) then if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) ' Size of coarsest matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', & write(iout_,*) ' Sizes of aggregates: ', &
& sum( p%baseprecv(ilev)%nlaggr(:)),' : ',p%baseprecv(ilev)%nlaggr(:) & p%baseprecv(ilev)%nlaggr(:)
end if end if
write(iout_,*) 'Factorization type: ',& if (p%baseprecv(ilev)%iprcparm(mld_coarse_mat_) == mld_distr_mat_ .and. &
& p%baseprecv(ilev)%iprcparm(mld_sub_solve_) /= mld_sludist_) then
write(iout_,*) ' Coarsest matrix solver: block Jacobi with ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
write(iout_,*) ' Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
else
write(iout_,*) ' Coarsest matrix solver: ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
end if
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
write(iout_,*) 'Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
end if end if
end do
end if end if
endif
else else
write(iout_,*) trim(name),': Error: No Base preconditioner available, something is wrong!'
write(iout_,*) trim(name),': Error: no base preconditioner available, something is wrong!'
info = -2
return return
endif endif
end subroutine mld_file_prec_descr end subroutine mld_file_prec_descr
subroutine mld_sfile_prec_descr(p,iout) subroutine mld_sfile_prec_descr(p,info,iout)
use psb_base_mod, only : psb_cd_get_context, psb_info
! Arguments ! Arguments
type(mld_sprec_type), intent(in) :: p type(mld_sprec_type), intent(in) :: p
integer, intent(out) :: info
integer, intent(in), optional :: iout integer, intent(in), optional :: iout
! Local variables ! Local variables
integer :: ilev integer :: ilev, nlev
integer :: ictxt, me, np
character(len=20), parameter :: name='mld_file_prec_descr' character(len=20), parameter :: name='mld_file_prec_descr'
integer :: iout_ integer :: iout_
info = 0
if (present(iout)) then if (present(iout)) then
iout_ = iout iout_ = iout
else else
iout_ = 6 iout_ = 6
end if end if
if (iout_ < 0) iout_ = 6
write(iout_,*) 'Preconditioner description'
if (allocated(p%baseprecv)) then if (allocated(p%baseprecv)) then
if (size(p%baseprecv)>=1) then ictxt = psb_cd_get_context(p%baseprecv(1)%desc_data)
call psb_info(ictxt,me,np)
!
! The preconditioner description is printed by processor psb_root_.
! This agrees with the fact that all the parameters defining the
! preconditioner have the same values on all the procs (this is
! ensured by mld_precbld).
!
if (me==psb_root_) then
write(iout_,*) 'Preconditioner description'
nlev = size(p%baseprecv)
if (nlev >= 1) then
!
! Print description of base preconditioner
!
write(iout_,*) ' '
if (nlev > 1) then
write(iout_,*) ' Multilevel Schwarz'
write(iout_,*) ' Base preconditioner (smoother) details'
endif
ilev = 1 ilev = 1
write(iout_,*) 'Base preconditioner'
select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_)) select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_))
case(mld_noprec_) case(mld_noprec_)
write(iout_,*) ' No preconditioning' write(iout_,*) ' No preconditioning'
case(mld_diag_) case(mld_diag_)
write(iout_,*) ' Diagonal scaling' write(iout_,*) ' Diagonal scaling'
case(mld_bjac_) case(mld_bjac_)
write(iout_,*) 'Block Jacobi with: ',& write(iout_,*) ' Block Jacobi with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
case(mld_as_) case(mld_as_)
write(iout_,*) 'Additive Schwarz with: ',& write(iout_,*) ' Additive Schwarz with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
@ -884,19 +1014,40 @@ contains
write(iout_,*) ' Prolongation: ',& write(iout_,*) ' Prolongation: ',&
& prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_)) & prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_))
end select end select
end if end if
if (size(p%baseprecv)>=2) then
do ilev = 2, size(p%baseprecv) if (nlev > 1) then
!
! Print multilevel details
!
write(iout_,*) ' Multilevel details'
do ilev = 2, nlev
if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then
write(iout_,*) 'Inconsistent MLPREC part!' info = 3111
write(iout_,*) ' ',name,': error: inconsistent MLPREC part, should call MLD_PRECINIT'
return return
endif endif
end do
write(iout_,*) ' Number of levels: ',nlev
!
! Currently, all the preconditioner parameters must have the same value at levels
! 2,...,nlev-1, hence only the values at level 2 are printed
!
ilev=2
write(iout_,*) 'Multilevel: Level No', ilev if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Multilevel type: ',& write(iout_,*) ' Multilevel type: ',&
& ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_)) & ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_))
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then write(iout_,*) ' Smoother position: ',&
write(iout_,*) 'Multilevel aggregation: ', & & smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
write(iout_,*) ' Aggregation: ', &
& aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_)) & aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_))
write(iout_,*) ' Aggregation smoothing: ', & write(iout_,*) ' Aggregation smoothing: ', &
& aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_)) & aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_))
@ -905,39 +1056,80 @@ contains
if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then
write(iout_,*) ' Damping omega: ', & write(iout_,*) ' Damping omega: ', &
& p%baseprecv(ilev)%rprcparm(mld_aggr_damp_) & p%baseprecv(ilev)%rprcparm(mld_aggr_damp_)
write(iout_,*) 'Multilevel smoother position: ',&
& smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
end if end if
write(iout_,*) 'Coarse matrix: ',& endif
!
! Coarse matrices are different at levels 2,...,nlev-1, hence related
! info is printed separately
!
do ilev = 2, nlev-1
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev
if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) ' Size of coarse matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', &
& p%baseprecv(ilev)%nlaggr(:)
end if
end if
end do
!
! Print coarsest level details
!
ilev = nlev
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev,' (coarsest)'
write(iout_,*) ' Coarsest matrix: ',&
& matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_)) & matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_))
if (allocated(p%baseprecv(ilev)%nlaggr)) then if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) ' Size of coarsest matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', & write(iout_,*) ' Sizes of aggregates: ', &
& sum( p%baseprecv(ilev)%nlaggr(:)),' : ',p%baseprecv(ilev)%nlaggr(:) & p%baseprecv(ilev)%nlaggr(:)
end if end if
write(iout_,*) 'Factorization type: ',& if (p%baseprecv(ilev)%iprcparm(mld_coarse_mat_) == mld_distr_mat_ .and. &
& p%baseprecv(ilev)%iprcparm(mld_sub_solve_) /= mld_sludist_) then
write(iout_,*) ' Coarsest matrix solver: block Jacobi with ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
write(iout_,*) ' Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
else
write(iout_,*) ' Coarsest matrix solver: ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
end if
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
write(iout_,*) 'Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
end if end if
end do
end if end if
endif
else else
write(iout_,*) trim(name),': Error: No Base preconditioner available, something is wrong!'
write(iout_,*) trim(name),': Error: no base preconditioner available, something is wrong!'
info = -2
return return
endif endif
end subroutine mld_sfile_prec_descr end subroutine mld_sfile_prec_descr
function mld_prec_short_descr(p) function mld_prec_short_descr(p)
type(mld_dprec_type), intent(in) :: p type(mld_dprec_type), intent(in) :: p
character(len=20) :: mld_prec_short_descr character(len=20) :: mld_prec_short_descr
@ -958,28 +1150,57 @@ contains
! The id of the file where the preconditioner description ! The id of the file where the preconditioner description
! will be printed. ! will be printed.
! !
subroutine mld_zfile_prec_descr(p,iout) subroutine mld_zfile_prec_descr(p,info,iout)
use psb_base_mod, only : psb_cd_get_context, psb_info
! Arguments ! Arguments
type(mld_zprec_type), intent(in) :: p type(mld_zprec_type), intent(in) :: p
integer, intent(out) :: info
integer, intent(in), optional :: iout integer, intent(in), optional :: iout
! Local variables ! Local variables
integer :: ilev integer :: ilev, nlev
integer :: ictxt, me, np
character(len=20), parameter :: name='mld_file_prec_descr' character(len=20), parameter :: name='mld_file_prec_descr'
integer :: iout_ integer :: iout_
info = 0
if (present(iout)) then if (present(iout)) then
iout_ = iout iout_ = iout
else else
iout_ = 6 iout_ = 6
end if end if
if (iout_ < 0) iout_ = 6
write(iout_,*) 'Preconditioner description'
if (allocated(p%baseprecv)) then if (allocated(p%baseprecv)) then
if (size(p%baseprecv)>=1) then ictxt = psb_cd_get_context(p%baseprecv(1)%desc_data)
write(iout_,*) 'Base preconditioner'
call psb_info(ictxt,me,np)
!
! The preconditioner description is printed by processor psb_root_.
! This agrees with the fact that all the parameters defining the
! preconditioner have the same values on all the procs (this is
! ensured by mld_precbld).
!
if (me==psb_root_) then
write(iout_,*) 'Preconditioner description'
nlev = size(p%baseprecv)
if (nlev >= 1) then
!
! Print description of base preconditioner
!
write(iout_,*) ' '
if (nlev > 1) then
write(iout_,*) ' Multilevel Schwarz'
write(iout_,*) ' Base preconditioner (smoother) details'
endif
ilev = 1 ilev = 1
select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_)) select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_))
case(mld_noprec_) case(mld_noprec_)
@ -987,24 +1208,26 @@ contains
case(mld_diag_) case(mld_diag_)
write(iout_,*) ' Diagonal scaling' write(iout_,*) ' Diagonal scaling'
case(mld_bjac_) case(mld_bjac_)
write(iout_,*) 'Block Jacobi with: ',& write(iout_,*) ' Block Jacobi with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
case(mld_as_) case(mld_as_)
write(iout_,*) 'Additive Schwarz with: ',& write(iout_,*) ' Additive Schwarz with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
@ -1017,81 +1240,172 @@ contains
write(iout_,*) ' Prolongation: ',& write(iout_,*) ' Prolongation: ',&
& prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_)) & prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_))
end select end select
end if end if
if (size(p%baseprecv)>=2) then
do ilev = 2, size(p%baseprecv) if (nlev > 1) then
!
! Print multilevel details
!
write(iout_,*) ' Multilevel details'
do ilev = 2, nlev
if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then
write(iout_,*) 'Inconsistent MLPREC part!' info = 3111
write(iout_,*) ' ',name,': error: inconsistent MLPREC part, should call MLD_PRECINIT'
return return
endif endif
end do
write(iout_,*) ' Number of levels: ',nlev
write(iout_,*) 'Multilevel: Level No', ilev !
! Currently, all the preconditioner parameters must have the same value at levels
! 2,...,nlev-1, hence only the values at level 2 are printed
!
ilev=2
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Multilevel type: ',& write(iout_,*) ' Multilevel type: ',&
& ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_)) & ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_))
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then write(iout_,*) ' Smoother position: ',&
write(iout_,*) 'Multilevel aggregation: ', & & smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
write(iout_,*) ' Aggregation: ', &
& aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_)) & aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_))
write(iout_,*) ' Aggregation smoothing: ', & write(iout_,*) ' Aggregation smoothing: ', &
& aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_)) & aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_))
write(iout_,*) ' Aggregation threshold: ', & write(iout_,*) ' Aggregation threshold: ', &
& p%baseprecv(ilev)%rprcparm(mld_aggr_thresh_) & p%baseprecv(ilev)%rprcparm(mld_aggr_thresh_)
if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then
write(iout_,*) 'Smoothing omega: ', & write(iout_,*) ' Damping omega: ', &
& p%baseprecv(ilev)%rprcparm(mld_aggr_damp_) & p%baseprecv(ilev)%rprcparm(mld_aggr_damp_)
write(iout_,*) 'Smoothing position: ',&
& smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
end if end if
write(iout_,*) 'Coarse matrix: ',& endif
!
! Coarse matrices are different at levels 2,...,nlev-1, hence related
! info is printed separately
!
do ilev = 2, nlev-1
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev
if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) ' Size of coarse matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', &
& p%baseprecv(ilev)%nlaggr(:)
end if
end if
end do
!
! Print coarsest level details
!
ilev = nlev
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev,' (coarsest)'
write(iout_,*) ' Coarsest matrix: ',&
& matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_)) & matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_))
if (allocated(p%baseprecv(ilev)%nlaggr)) then if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) 'Aggregation sizes: ', & write(iout_,*) ' Size of coarsest matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:)),' : ',p%baseprecv(ilev)%nlaggr(:) & sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', &
& p%baseprecv(ilev)%nlaggr(:)
end if end if
write(iout_,*) 'Factorization type: ',& if (p%baseprecv(ilev)%iprcparm(mld_coarse_mat_) == mld_distr_mat_ .and. &
& p%baseprecv(ilev)%iprcparm(mld_sub_solve_) /= mld_sludist_) then
write(iout_,*) ' Coarsest matrix solver: block Jacobi with ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
write(iout_,*) ' Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
else
write(iout_,*) ' Coarsest matrix solver: ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
end if
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
write(iout_,*) 'Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
end if end if
end do
end if end if
endif
else else
write(iout_,*) trim(name),': Error: No Base preconditioner available, something is wrong!'
write(iout_,*) trim(name),': Error: no base preconditioner available, something is wrong!'
info = -2
return return
endif endif
end subroutine mld_zfile_prec_descr end subroutine mld_zfile_prec_descr
subroutine mld_cfile_prec_descr(p,iout) subroutine mld_cfile_prec_descr(p,info,iout)
use psb_base_mod, only : psb_cd_get_context, psb_info
! Arguments ! Arguments
type(mld_cprec_type), intent(in) :: p type(mld_cprec_type), intent(in) :: p
integer, intent(out) :: info
integer, intent(in), optional :: iout integer, intent(in), optional :: iout
! Local variables ! Local variables
integer :: ilev integer :: ilev, nlev
integer :: ictxt, me, np
character(len=20), parameter :: name='mld_file_prec_descr' character(len=20), parameter :: name='mld_file_prec_descr'
integer :: iout_ integer :: iout_
info = 0
if (present(iout)) then if (present(iout)) then
iout_ = iout iout_ = iout
else else
iout_ = 6 iout_ = 6
end if end if
if (iout_ < 0) iout_ = 6
write(iout_,*) 'Preconditioner description'
if (allocated(p%baseprecv)) then if (allocated(p%baseprecv)) then
if (size(p%baseprecv)>=1) then ictxt = psb_cd_get_context(p%baseprecv(1)%desc_data)
write(iout_,*) 'Base preconditioner'
call psb_info(ictxt,me,np)
!
! The preconditioner description is printed by processor psb_root_.
! This agrees with the fact that all the parameters defining the
! preconditioner have the same values on all the procs (this is
! ensured by mld_precbld).
!
if (me==psb_root_) then
write(iout_,*) 'Preconditioner description'
nlev = size(p%baseprecv)
if (nlev >= 1) then
!
! Print description of base preconditioner
!
write(iout_,*) ' '
if (nlev > 1) then
write(iout_,*) ' Multilevel Schwarz'
write(iout_,*) ' Base preconditioner (smoother) details'
endif
ilev = 1 ilev = 1
select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_)) select case(p%baseprecv(ilev)%iprcparm(mld_smoother_type_))
case(mld_noprec_) case(mld_noprec_)
@ -1099,24 +1413,26 @@ contains
case(mld_diag_) case(mld_diag_)
write(iout_,*) ' Diagonal scaling' write(iout_,*) ' Diagonal scaling'
case(mld_bjac_) case(mld_bjac_)
write(iout_,*) 'Block Jacobi with: ',& write(iout_,*) ' Block Jacobi with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
case(mld_as_) case(mld_as_)
write(iout_,*) 'Additive Schwarz with: ',& write(iout_,*) ' Additive Schwarz with ',&
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
@ -1129,60 +1445,122 @@ contains
write(iout_,*) ' Prolongation: ',& write(iout_,*) ' Prolongation: ',&
& prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_)) & prolong_names(p%baseprecv(ilev)%iprcparm(mld_sub_prol_))
end select end select
end if end if
if (size(p%baseprecv)>=2) then
do ilev = 2, size(p%baseprecv) if (nlev > 1) then
!
! Print multilevel details
!
write(iout_,*) ' Multilevel details'
do ilev = 2, nlev
if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev)%iprcparm)) then
write(iout_,*) 'Inconsistent MLPREC part!' info = 3111
write(iout_,*) ' ',name,': error: inconsistent MLPREC part, should call MLD_PRECINIT'
return return
endif endif
end do
write(iout_,*) ' Number of levels: ',nlev
write(iout_,*) 'Multilevel: Level No', ilev !
! Currently, all the preconditioner parameters must have the same value at levels
! 2,...,nlev-1, hence only the values at level 2 are printed
!
ilev=2
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Multilevel type: ',& write(iout_,*) ' Multilevel type: ',&
& ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_)) & ml_names(p%baseprecv(ilev)%iprcparm(mld_ml_type_))
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then write(iout_,*) ' Smoother position: ',&
write(iout_,*) 'Multilevel aggregation: ', & & smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
write(iout_,*) ' Aggregation: ', &
& aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_)) & aggr_names(p%baseprecv(ilev)%iprcparm(mld_aggr_alg_))
write(iout_,*) ' Aggregation smoothing: ', & write(iout_,*) ' Aggregation smoothing: ', &
& aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_)) & aggr_kinds(p%baseprecv(ilev)%iprcparm(mld_aggr_kind_))
write(iout_,*) ' Aggregation threshold: ', & write(iout_,*) ' Aggregation threshold: ', &
& p%baseprecv(ilev)%rprcparm(mld_aggr_thresh_) & p%baseprecv(ilev)%rprcparm(mld_aggr_thresh_)
if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then if (p%baseprecv(ilev)%iprcparm(mld_aggr_kind_) /= mld_no_smooth_) then
write(iout_,*) 'Smoothing omega: ', & write(iout_,*) ' Damping omega: ', &
& p%baseprecv(ilev)%rprcparm(mld_aggr_damp_) & p%baseprecv(ilev)%rprcparm(mld_aggr_damp_)
write(iout_,*) 'Smoothing position: ',&
& smooth_names(p%baseprecv(ilev)%iprcparm(mld_smoother_pos_))
end if end if
write(iout_,*) 'Coarse matrix: ',& endif
!
! Coarse matrices are different at levels 2,...,nlev-1, hence related
! info is printed separately
!
do ilev = 2, nlev-1
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev
if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) ' Size of coarse matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', &
& p%baseprecv(ilev)%nlaggr(:)
end if
end if
end do
!
! Print coarsest level details
!
ilev = nlev
if (p%baseprecv(ilev)%iprcparm(mld_ml_type_)>mld_no_ml_) then
write(iout_,*) ' Level ',ilev,' (coarsest)'
write(iout_,*) ' Coarsest matrix: ',&
& matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_)) & matrix_names(p%baseprecv(ilev)%iprcparm(mld_coarse_mat_))
if (allocated(p%baseprecv(ilev)%nlaggr)) then if (allocated(p%baseprecv(ilev)%nlaggr)) then
write(iout_,*) 'Aggregation sizes: ', & write(iout_,*) ' Size of coarsest matrix: ', &
& sum( p%baseprecv(ilev)%nlaggr(:)),' : ',p%baseprecv(ilev)%nlaggr(:) & sum( p%baseprecv(ilev)%nlaggr(:))
write(iout_,*) ' Sizes of aggregates: ', &
& p%baseprecv(ilev)%nlaggr(:)
end if end if
write(iout_,*) 'Factorization type: ',& if (p%baseprecv(ilev)%iprcparm(mld_coarse_mat_) == mld_distr_mat_ .and. &
& p%baseprecv(ilev)%iprcparm(mld_sub_solve_) /= mld_sludist_) then
write(iout_,*) ' Coarsest matrix solver: block Jacobi with ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) & fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
write(iout_,*) ' Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
else
write(iout_,*) ' Coarsest matrix solver: ', &
& fact_names(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
end if
select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_)) select case(p%baseprecv(ilev)%iprcparm(mld_sub_solve_))
case(mld_ilu_n_,mld_milu_n_) case(mld_ilu_n_,mld_milu_n_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_) write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
case(mld_ilu_t_) case(mld_ilu_t_)
write(iout_,*) ' Fill level:',p%baseprecv(ilev)%iprcparm(mld_sub_fillin_)
write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_) write(iout_,*) ' Fill threshold :',p%baseprecv(ilev)%rprcparm(mld_fact_thrs_)
case(mld_slu_,mld_umf_,mld_sludist_) case(mld_slu_,mld_umf_,mld_sludist_)
case default case default
write(iout_,*) ' Should never get here!' write(iout_,*) ' Should never get here!'
end select end select
write(iout_,*) 'Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(mld_smoother_sweeps_))
end if end if
end do
end if end if
endif
else else
write(iout_,*) trim(name),': Error: No Base preconditioner available, something is wrong!'
write(iout_,*) trim(name),': Error: no base preconditioner available, something is wrong!'
info = -2
return return
endif endif
end subroutine mld_cfile_prec_descr end subroutine mld_cfile_prec_descr
function mld_zprec_short_descr(p) function mld_zprec_short_descr(p)
type(mld_zprec_type), intent(in) :: p type(mld_zprec_type), intent(in) :: p
character(len=20) :: mld_zprec_short_descr character(len=20) :: mld_zprec_short_descr

@ -47,8 +47,11 @@
! build the coarse-level matrix. ! build the coarse-level matrix.
! !
! The aggregation algorithm is a parallel version of that described in ! The aggregation algorithm is a parallel version of that described in
! M. Brezina and P. Vanek, A black-box iterative solver based on a ! * M. Brezina and P. Vanek, A black-box iterative solver based on a
! two-level Schwarz method, Computing, 63 (1999), 233-263. ! two-level Schwarz method, Computing, 63 (1999), 233-263.
! * P. Vanek, J. Mandel and M. Brezina, Algebraic Multigrid by Smoothed
! Aggregation for Second and Fourth Order Elliptic Problems, Computing, 56
! (1996), 179-196.
! For more details see ! For more details see
! P. D'Ambra, D. di Serafino and S. Filippone, On the development of ! P. D'Ambra, D. di Serafino and S. Filippone, On the development of
! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math. ! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math.

@ -91,7 +91,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
info = 3111 info = 3111
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
return return
endif endif
nlev_ = size(p%baseprecv) nlev_ = size(p%baseprecv)
@ -110,7 +110,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
info = 3111 info = 3111
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
return return
endif endif
@ -162,13 +162,16 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case default case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
end select end select
endif endif
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
@ -204,7 +207,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
do ilev_=1,max(1,nlev_-1) do ilev_=1,max(1,nlev_-1)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -215,7 +218,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
do ilev_=2,nlev_-1 do ilev_=2,nlev_-1
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -224,7 +227,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
case(mld_coarse_mat_) case(mld_coarse_mat_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
& ': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' & ': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -232,28 +235,29 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
case(mld_coarse_solve_) case(mld_coarse_solve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case(mld_bjac_) case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_ilu_n_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
case default & p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
end select end select
endif endif
case(mld_coarse_subsolve_) case(mld_coarse_subsolve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
end if end if
@ -262,7 +266,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -270,7 +274,7 @@ subroutine mld_sprecseti(p,what,val,info,ilev)
case(mld_coarse_fillin_) case(mld_coarse_fillin_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -355,7 +359,7 @@ subroutine mld_sprecsetc(p,what,string,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -426,7 +430,7 @@ subroutine mld_sprecsetr(p,what,val,info,ilev)
end if end if
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -438,7 +442,7 @@ subroutine mld_sprecsetr(p,what,val,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -479,16 +483,24 @@ subroutine mld_sprecsetr(p,what,val,info,ilev)
case(mld_fact_thrs_) case(mld_fact_thrs_)
do ilev_=1,nlev_ do ilev_=1,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
p%baseprecv(ilev_)%rprcparm(what) = val p%baseprecv(ilev_)%rprcparm(what) = val
end do end do
case(mld_coarse_fthrs_)
ilev_=nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1
return
endif
p%baseprecv(ilev_)%rprcparm(mld_fact_thrs_) = val
case(mld_aggr_damp_) case(mld_aggr_damp_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -497,7 +509,7 @@ subroutine mld_sprecsetr(p,what,val,info,ilev)
case(mld_aggr_thresh_) case(mld_aggr_thresh_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif

@ -47,8 +47,11 @@
! build the coarse-level matrix. ! build the coarse-level matrix.
! !
! The aggregation algorithm is a parallel version of that described in ! The aggregation algorithm is a parallel version of that described in
! M. Brezina and P. Vanek, A black-box iterative solver based on a ! * M. Brezina and P. Vanek, A black-box iterative solver based on a
! two-level Schwarz method, Computing, 63 (1999), 233-263. ! two-level Schwarz method, Computing, 63 (1999), 233-263.
! * P. Vanek, J. Mandel and M. Brezina, Algebraic Multigrid by Smoothed
! Aggregation for Second and Fourth Order Elliptic Problems, Computing, 56
! (1996), 179-196.
! For more details see ! For more details see
! P. D'Ambra, D. di Serafino and S. Filippone, On the development of ! P. D'Ambra, D. di Serafino and S. Filippone, On the development of
! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math. ! PSBLAS-based parallel two-level Schwarz preconditioners, Appl. Num. Math.

@ -91,7 +91,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
info = 3111 info = 3111
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
return return
endif endif
nlev_ = size(p%baseprecv) nlev_ = size(p%baseprecv)
@ -110,7 +110,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
info = 3111 info = 3111
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
return return
endif endif
@ -162,13 +162,16 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case default case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
end select end select
endif endif
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
@ -204,7 +207,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
do ilev_=1,max(1,nlev_-1) do ilev_=1,max(1,nlev_-1)
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -215,7 +218,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
do ilev_=2,nlev_-1 do ilev_=2,nlev_-1
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -224,7 +227,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
case(mld_coarse_mat_) case(mld_coarse_mat_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
& ': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' & ': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -232,28 +235,29 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
case(mld_coarse_solve_) case(mld_coarse_solve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
if (nlev_ > 1) then if (nlev_ > 1) then
p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val p%baseprecv(nlev_)%iprcparm(mld_coarse_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == 0) &
& p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = val
p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_ p%baseprecv(nlev_)%iprcparm(mld_smoother_type_) = mld_bjac_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
select case (val) select case (val)
case(mld_umf_, mld_slu_) case(mld_umf_, mld_slu_)
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_ p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_repl_mat_
case(mld_bjac_) case(mld_bjac_)
p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_ilu_n_ if (p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) == mld_bjac_) &
case default & p%baseprecv(nlev_)%iprcparm(mld_sub_solve_) = mld_umf_
p%baseprecv(nlev_)%iprcparm(mld_coarse_mat_) = mld_distr_mat_
end select end select
endif endif
case(mld_coarse_subsolve_) case(mld_coarse_subsolve_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
end if end if
@ -262,7 +266,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
case(mld_coarse_sweeps_) case(mld_coarse_sweeps_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -270,7 +274,7 @@ subroutine mld_zprecseti(p,what,val,info,ilev)
case(mld_coarse_fillin_) case(mld_coarse_fillin_)
if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then if (.not.allocated(p%baseprecv(nlev_)%iprcparm)) then
write(0,*) name,& write(0,*) name,&
&': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' &': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -355,7 +359,7 @@ subroutine mld_zprecsetc(p,what,string,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%iprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -427,7 +431,7 @@ subroutine mld_zprecsetr(p,what,val,info,ilev)
end if end if
if (.not.allocated(p%baseprecv)) then if (.not.allocated(p%baseprecv)) then
write(0,*) name,': Error: Uninitialized preconditioner, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -439,7 +443,7 @@ subroutine mld_zprecsetr(p,what,val,info,ilev)
return return
endif endif
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = 3111 info = 3111
return return
endif endif
@ -480,16 +484,24 @@ subroutine mld_zprecsetr(p,what,val,info,ilev)
case(mld_fact_thrs_) case(mld_fact_thrs_)
do ilev_=1,nlev_ do ilev_=1,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
p%baseprecv(ilev_)%rprcparm(what) = val p%baseprecv(ilev_)%rprcparm(what) = val
end do end do
case(mld_coarse_fthrs_)
ilev_=nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1
return
endif
p%baseprecv(ilev_)%rprcparm(mld_fact_thrs_) = val
case(mld_aggr_damp_) case(mld_aggr_damp_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif
@ -498,7 +510,7 @@ subroutine mld_zprecsetr(p,what,val,info,ilev)
case(mld_aggr_thresh_) case(mld_aggr_thresh_)
do ilev_=2,nlev_ do ilev_=2,nlev_
if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then if (.not.allocated(p%baseprecv(ilev_)%rprcparm)) then
write(0,*) name,': Error: Uninitialized preconditioner component, should call MLD_PRECINIT' write(0,*) name,': Error: uninitialized preconditioner component, should call MLD_PRECINIT'
info = -1 info = -1
return return
endif endif

@ -289,7 +289,7 @@ program cf_sample
call psb_sum(ictxt,descsize) call psb_sum(ictxt,descsize)
call psb_sum(ictxt,precsize) call psb_sum(ictxt,precsize)
if (iam==psb_root_) then if (iam==psb_root_) then
call mld_precdescr(prec) call mld_precdescr(prec,info)
write(*,'("Matrix: ",a)')mtrx_file write(*,'("Matrix: ",a)')mtrx_file
write(*,'("Computed solution on ",i8," processors")')np write(*,'("Computed solution on ",i8," processors")')np
write(*,'("Iterations to convergence : ",i6)')iter write(*,'("Iterations to convergence : ",i6)')iter

@ -289,7 +289,7 @@ program df_sample
call psb_sum(ictxt,descsize) call psb_sum(ictxt,descsize)
call psb_sum(ictxt,precsize) call psb_sum(ictxt,precsize)
if (iam==psb_root_) then if (iam==psb_root_) then
call mld_precdescr(prec) call mld_precdescr(prec,info)
write(*,'("Matrix: ",a)')mtrx_file write(*,'("Matrix: ",a)')mtrx_file
write(*,'("Computed solution on ",i8," processors")')np write(*,'("Computed solution on ",i8," processors")')np
write(*,'("Iterations to convergence : ",i6)')iter write(*,'("Iterations to convergence : ",i6)')iter

@ -289,7 +289,7 @@ program sf_sample
call psb_sum(ictxt,descsize) call psb_sum(ictxt,descsize)
call psb_sum(ictxt,precsize) call psb_sum(ictxt,precsize)
if (iam==psb_root_) then if (iam==psb_root_) then
call mld_precdescr(prec) call mld_precdescr(prec,info)
write(*,'("Matrix: ",a)')mtrx_file write(*,'("Matrix: ",a)')mtrx_file
write(*,'("Computed solution on ",i8," processors")')np write(*,'("Computed solution on ",i8," processors")')np
write(*,'("Iterations to convergence : ",i6)')iter write(*,'("Iterations to convergence : ",i6)')iter

@ -289,7 +289,7 @@ program zf_sample
call psb_sum(ictxt,descsize) call psb_sum(ictxt,descsize)
call psb_sum(ictxt,precsize) call psb_sum(ictxt,precsize)
if (iam==psb_root_) then if (iam==psb_root_) then
call mld_precdescr(prec) call mld_precdescr(prec,info)
write(*,'("Matrix: ",a)')mtrx_file write(*,'("Matrix: ",a)')mtrx_file
write(*,'("Computed solution on ",i8," processors")')np write(*,'("Computed solution on ",i8," processors")')np
write(*,'("Iterations to convergence : ",i6)')iter write(*,'("Iterations to convergence : ",i6)')iter

@ -9,6 +9,7 @@ FINCLUDES=$(FMFLAG). $(FMFLAG)$(MLDLIBDIR) $(FMFLAG)$(PSBDIR) $(FIFLAG).
EXEDIR=./runs EXEDIR=./runs
all: ppde spde
ppde: ppde.o data_input.o ppde: ppde.o data_input.o
$(F90LINK) ppde.o data_input.o -o ppde $(MLD_LIB) $(PSBLAS_LIB) $(LDLIBS) $(F90LINK) ppde.o data_input.o -o ppde $(MLD_LIB) $(PSBLAS_LIB) $(LDLIBS)

@ -222,7 +222,7 @@ program ppde
call psb_amx(ictxt,tprec) call psb_amx(ictxt,tprec)
if (iam == psb_root_) write(*,'("Preconditioner time : ",es10.4)')tprec if (iam == psb_root_) write(*,'("Preconditioner time : ",es10.4)')tprec
if (iam == psb_root_) call mld_precdescr(prec) if (iam == psb_root_) call mld_precdescr(prec,info)
if (iam == psb_root_) write(*,'(" ")') if (iam == psb_root_) write(*,'(" ")')
! !

@ -222,7 +222,7 @@ program spde
call psb_amx(ictxt,tprec) call psb_amx(ictxt,tprec)
if (iam == psb_root_) write(*,'("Preconditioner time : ",es10.4)')tprec if (iam == psb_root_) write(*,'("Preconditioner time : ",es10.4)')tprec
if (iam == psb_root_) call mld_precdescr(prec) if (iam == psb_root_) call mld_precdescr(prec,info)
if (iam == psb_root_) write(*,'(" ")') if (iam == psb_root_) write(*,'(" ")')
! !

Loading…
Cancel
Save