10 #ifndef IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
11 #define IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
13 #include "Ifpack2_Factory.hpp"
15 #include "Ifpack2_Chebyshev.hpp"
16 #include "Ifpack2_Details_DenseSolver.hpp"
17 #include "Ifpack2_Diagonal.hpp"
18 #include "Ifpack2_IdentitySolver.hpp"
19 #include "Ifpack2_ILUT.hpp"
20 #include "Ifpack2_MDF.hpp"
21 #include "Ifpack2_Relaxation.hpp"
22 #include "Ifpack2_RILUK.hpp"
23 #include "Ifpack2_Experimental_RBILUK.hpp"
24 #include "Ifpack2_BlockRelaxation.hpp"
25 #include "Ifpack2_BandedContainer.hpp"
26 #include "Ifpack2_DenseContainer.hpp"
27 #include "Ifpack2_DatabaseSchwarz.hpp"
28 #include "Ifpack2_SparseContainer.hpp"
29 #include "Ifpack2_TriDiContainer.hpp"
30 #include "Ifpack2_LocalSparseTriangularSolver.hpp"
31 #include "Ifpack2_Hiptmair.hpp"
33 #ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
34 #include "Ifpack2_Details_Fic.hpp"
35 #include "Ifpack2_Details_Fildl.hpp"
36 #include "Ifpack2_Details_Filu.hpp"
37 #endif // HAVE_IFPACK2_SHYLU_NODEFASTILU
39 #ifdef HAVE_IFPACK2_AMESOS2
40 #include "Ifpack2_Details_Amesos2Wrapper.hpp"
41 #endif // HAVE_IFPACK2_AMESOS2
43 #ifdef HAVE_IFPACK2_HYPRE
44 #include "Ifpack2_Hypre.hpp"
45 #endif // HAVE_IFPACK2_HYPRE
50 template <
class MatrixType>
60 std::string precTypeUpper = canonicalize(precType);
62 if (precTypeUpper ==
"CHEBYSHEV") {
65 prec =
rcp(new ::Ifpack2::Chebyshev<row_matrix_type>(matrix));
66 }
else if (precTypeUpper ==
"DENSE" || precTypeUpper ==
"LAPACK") {
68 }
else if (precTypeUpper ==
"AMESOS2") {
69 #ifdef HAVE_IFPACK2_AMESOS2
73 true, std::invalid_argument,
74 "Ifpack2::Details::OneLevelFactory: "
75 "You may not ask for the preconditioner \"AMESOS2\" unless "
76 "you have built Trilinos with the Amesos2 package enabled.");
77 #endif // HAVE_IFPACK2_AMESOS2
78 }
else if (precTypeUpper ==
"DIAGONAL") {
80 }
else if (precTypeUpper ==
"ILUT") {
82 }
else if (precTypeUpper ==
"RELAXATION") {
84 }
else if (precTypeUpper ==
"RILUK") {
86 }
else if (precTypeUpper ==
"MDF") {
88 }
else if (precTypeUpper ==
"RBILUK") {
90 }
else if (precTypeUpper ==
"FAST_IC" || precTypeUpper ==
"FAST_ILU" || precTypeUpper ==
"FAST_ILU_B" || precTypeUpper ==
"FAST_ILDL") {
91 #ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
93 if (precTypeUpper ==
"FAST_IC")
95 else if (precTypeUpper ==
"FAST_ILU")
97 else if (precTypeUpper ==
"FAST_ILU_B")
99 else if (precTypeUpper ==
"FAST_ILDL")
104 throw std::invalid_argument(
105 "The Ifpack2 FastIC, FastILU and FastILDL preconditioners require the FastILU subpackage of ShyLU to be enabled\n"
106 "To enable FastILU, set the CMake option Trilinos_ENABLE_ShyLU_NodeFastILU=ON");
109 }
else if (precTypeUpper ==
"KRYLOV") {
111 "The \"KRYLOV\" preconditioner option has "
112 "been deprecated and removed. If you want a Krylov solver, use the "
114 }
else if (precTypeUpper ==
"BLOCK_RELAXATION" ||
115 precTypeUpper ==
"BLOCK RELAXATION" ||
116 precTypeUpper ==
"BLOCKRELAXATION" ||
117 precTypeUpper ==
"DENSE_BLOCK_RELAXATION" ||
118 precTypeUpper ==
"DENSE BLOCK RELAXATION" ||
119 precTypeUpper ==
"DENSEBLOCKRELAXATION") {
125 params.
set(
"relaxation: container",
"Dense");
127 }
else if (precTypeUpper ==
"DATABASE SCHWARZ") {
129 }
else if (precTypeUpper ==
"SPARSE_BLOCK_RELAXATION" ||
130 precTypeUpper ==
"SPARSE BLOCK RELAXATION" ||
131 precTypeUpper ==
"SPARSEBLOCKRELAXATION") {
138 #ifdef HAVE_IFPACK2_AMESOS2
141 params.
set(
"relaxation: container",
"SparseAmesos2");
145 "Ifpack2::Details::OneLevelFactory: "
146 "\"SPARSE BLOCK RELAXATION\" requires building Trilinos with Amesos2 enabled.");
148 }
else if (precTypeUpper ==
"TRIDI_RELAXATION" ||
149 precTypeUpper ==
"TRIDI RELAXATION" ||
150 precTypeUpper ==
"TRIDIRELAXATION" ||
151 precTypeUpper ==
"TRIDIAGONAL_RELAXATION" ||
152 precTypeUpper ==
"TRIDIAGONAL RELAXATION" ||
153 precTypeUpper ==
"TRIDIAGONALRELAXATION") {
156 params.
set(
"relaxation: container",
"TriDi");
158 }
else if (precTypeUpper ==
"BANDED_RELAXATION" ||
159 precTypeUpper ==
"BANDED RELAXATION" ||
160 precTypeUpper ==
"BANDEDRELAXATION") {
163 params.
set(
"relaxation: container",
"Banded");
165 }
else if (precTypeUpper ==
"IDENTITY" || precTypeUpper ==
"IDENTITY_SOLVER") {
169 else if (precTypeUpper ==
"LOCAL SPARSE TRIANGULAR SOLVER" ||
170 precTypeUpper ==
"LOCAL_SPARSE_TRIANGULAR_SOLVER" ||
171 precTypeUpper ==
"LOCALSPARSETRIANGULARSOLVER" ||
172 precTypeUpper ==
"SPARSE TRIANGULAR SOLVER" ||
173 precTypeUpper ==
"SPARSE_TRIANGULAR_SOLVER" ||
174 precTypeUpper ==
"SPARSETRIANGULARSOLVER") {
176 }
else if (precTypeUpper ==
"HIPTMAIR") {
179 #ifdef HAVE_IFPACK2_HYPRE
180 else if (precTypeUpper ==
"HYPRE") {
181 prec =
rcp(
new Hypre<row_matrix_type>(matrix));
186 true, std::invalid_argument,
187 "Ifpack2::Details::OneLevelFactory::create: "
188 "Invalid preconditioner type \""
189 << precType <<
"\".");
193 prec.is_null(), std::logic_error,
194 "Ifpack2::Details::OneLevelFactory::"
195 "create: Return value is null right before return. This should never "
196 "happen. Please report this bug to the Ifpack2 developers.");
200 template <
class MatrixType>
201 std::vector<std::string>
203 std::vector<std::string> supportedNames = {
204 "CHEBYSHEV",
"DENSE",
"LAPACK",
205 #ifdef HAVE_IFPACK2_AMESOS2
208 "DIAGONAL",
"ILUT",
"RELAXATION",
"RILUK",
"RBILUK",
"MDF",
209 #ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
210 "FAST_IC",
"FAST_ILU",
"FAST_ILU_B",
"FAST_ILDL",
212 "BLOCK_RELAXATION",
"BLOCK RELAXATION",
"BLOCKRELAXATION",
"DENSE_BLOCK_RELAXATION",
"DENSE BLOCK RELAXATION",
"DENSEBLOCKRELAXATION",
214 #ifdef HAVE_IFPACK2_AMESOS2
215 "SPARSE_BLOCK_RELAXATION",
"SPARSE BLOCK RELAXATION",
"SPARSEBLOCKRELAXATION",
217 #ifdef HAVE_IFPACK2_HYPRE
220 "TRIDI_RELAXATION",
"TRIDI RELAXATION",
"TRIDIRELAXATION",
"TRIDIAGONAL_RELAXATION",
"TRIDIAGONAL RELAXATION",
"TRIDIAGONALRELAXATION",
221 "BANDED_RELAXATION",
"BANDED RELAXATION",
"BANDEDRELAXATION",
222 "IDENTITY",
"IDENTITY_SOLVER",
223 "LOCAL SPARSE TRIANGULAR SOLVER",
"LOCAL_SPARSE_TRIANGULAR_SOLVER",
"LOCALSPARSETRIANGULARSOLVER",
"SPARSE TRIANGULAR SOLVER",
"SPARSE_TRIANGULAR_SOLVER",
"SPARSETRIANGULARSOLVER",
225 return supportedNames;
228 template <
class MatrixType>
229 bool OneLevelFactory<MatrixType>::isSupported(
const std::string& precType)
const {
231 std::string precTypeUpper = canonicalize(precType);
232 std::vector<std::string> supportedNames = getSupportedNames();
235 auto it = std::find(std::begin(supportedNames), std::end(supportedNames), precTypeUpper);
236 return it != std::end(supportedNames);
242 #define IFPACK2_DETAILS_ONELEVELFACTORY_INSTANT(S, LO, GO, N) \
243 template class Ifpack2::Details::OneLevelFactory<Tpetra::RowMatrix<S, LO, GO, N> >;
245 #endif // IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
MDF (incomplete LU factorization with minimum discarded fill reordering) of a Tpetra sparse matrix...
Definition: Ifpack2_MDF_decl.hpp:50
Teuchos::RCP< prec_type > create(const std::string &precType, const Teuchos::RCP< const row_matrix_type > &matrix) const
Create an instance of Preconditioner given the string name of the preconditioner type.
Definition: Ifpack2_Details_OneLevelFactory_def.hpp:52
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Diagonal preconditioner.
Definition: Ifpack2_Diagonal_decl.hpp:38
ILU(k) factorization of a given Tpetra::RowMatrix.
Definition: Ifpack2_RILUK_decl.hpp:213
ParameterList & set(std::string const &name, T &&value, std::string const &docString="", RCP< const ParameterEntryValidator > const &validator=null)
"Preconditioner" that uses LAPACK's dense LU.
Definition: Ifpack2_Details_DenseSolver_decl.hpp:42
The Ifpack2 wrapper to the ILDL preconditioner of ShyLU FastILU.
Definition: Ifpack2_Details_Fildl_decl.hpp:27
The Ifpack2 wrapper to the ILU preconditioner of ShyLU FastILU.
Definition: Ifpack2_Details_Filu_decl.hpp:27
ILUT (incomplete LU factorization with threshold) of a Tpetra sparse matrix.
Definition: Ifpack2_ILUT_decl.hpp:60
Block relaxation preconditioners (or smoothers) for Tpetra::RowMatrix and Tpetra::CrsMatrix sparse ma...
Definition: Ifpack2_BlockRelaxation_decl.hpp:49
"Identity" preconditioner.
Definition: Ifpack2_IdentitySolver_decl.hpp:27
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
Wrapper for Hiptmair smoothers.
Definition: Ifpack2_Hiptmair_decl.hpp:38
Wrapper class for direct solvers in Amesos2.
Definition: Ifpack2_Details_Amesos2Wrapper_decl.hpp:68
"Preconditioner" that solves local sparse triangular systems.
Definition: Ifpack2_LocalSparseTriangularSolver_decl.hpp:46
File for utility functions.
ParameterList & setParameters(const ParameterList &source)
Overlapping Schwarz where redundant patches are not stored explicitly.
Definition: Ifpack2_DatabaseSchwarz_decl.hpp:63
The Ifpack2 wrapper to the incomplete Chebyshev preconditioner of ShyLU FastILU.
Definition: Ifpack2_Details_Fic_decl.hpp:27
"Factory" for creating single-level preconditioners.
Definition: Ifpack2_Details_OneLevelFactory_decl.hpp:92
Relaxation preconditioners for Tpetra::RowMatrix and Tpetra::CrsMatrix sparse matrices.
Definition: Ifpack2_Relaxation_decl.hpp:206
ILU(k) factorization of a given Tpetra::BlockCrsMatrix.
Definition: Ifpack2_Experimental_RBILUK_decl.hpp:95