43#ifndef IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
44#define IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
46#include "Ifpack2_Factory.hpp"
48#include "Ifpack2_Chebyshev.hpp"
49#include "Ifpack2_Details_DenseSolver.hpp"
50#include "Ifpack2_Diagonal.hpp"
51#include "Ifpack2_IdentitySolver.hpp"
52#include "Ifpack2_ILUT.hpp"
53#include "Ifpack2_MDF.hpp"
54#include "Ifpack2_Relaxation.hpp"
55#include "Ifpack2_RILUK.hpp"
56#include "Ifpack2_Experimental_RBILUK.hpp"
57#include "Ifpack2_BlockRelaxation.hpp"
58#include "Ifpack2_BandedContainer.hpp"
59#include "Ifpack2_DenseContainer.hpp"
60#include "Ifpack2_DatabaseSchwarz.hpp"
61#include "Ifpack2_SparseContainer.hpp"
62#include "Ifpack2_TriDiContainer.hpp"
63#include "Ifpack2_LocalSparseTriangularSolver.hpp"
64#include "Ifpack2_Hiptmair.hpp"
66#ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
67#include "Ifpack2_Details_Fic.hpp"
68#include "Ifpack2_Details_Fildl.hpp"
69#include "Ifpack2_Details_Filu.hpp"
72#ifdef HAVE_IFPACK2_AMESOS2
73# include "Ifpack2_Details_Amesos2Wrapper.hpp"
76#ifdef HAVE_IFPACK2_HYPRE
77# include "Ifpack2_Hypre.hpp"
84template<
class MatrixType>
85Teuchos::RCP<typename OneLevelFactory<MatrixType>::prec_type>
87 const Teuchos::RCP<const row_matrix_type>& matrix)
const
95 std::string precTypeUpper = canonicalize(precType);
97 if (precTypeUpper ==
"CHEBYSHEV") {
100 prec = rcp (new ::Ifpack2::Chebyshev<row_matrix_type> (matrix));
102 else if (precTypeUpper ==
"DENSE" || precTypeUpper ==
"LAPACK") {
105 else if (precTypeUpper ==
"AMESOS2") {
106#ifdef HAVE_IFPACK2_AMESOS2
109 TEUCHOS_TEST_FOR_EXCEPTION(
110 true, std::invalid_argument,
"Ifpack2::Details::OneLevelFactory: "
111 "You may not ask for the preconditioner \"AMESOS2\" unless "
112 "you have built Trilinos with the Amesos2 package enabled.");
115 else if (precTypeUpper ==
"DIAGONAL") {
118 else if (precTypeUpper ==
"ILUT") {
121 else if (precTypeUpper ==
"RELAXATION") {
124 else if (precTypeUpper ==
"RILUK") {
127 else if (precTypeUpper ==
"MDF") {
130 else if (precTypeUpper ==
"RBILUK") {
133 else if (precTypeUpper ==
"FAST_IC" || precTypeUpper ==
"FAST_ILU" || precTypeUpper ==
"FAST_ILDL") {
134 #ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
136 if(precTypeUpper ==
"FAST_IC")
138 else if(precTypeUpper ==
"FAST_ILU")
140 else if(precTypeUpper ==
"FAST_ILDL")
145 throw std::invalid_argument(
"The Ifpack2 FastIC, FastILU and FastILDL preconditioners require the FastILU subpackage of ShyLU to be enabled\n"
146 "To enable FastILU, set the CMake option Trilinos_ENABLE_ShyLU_NodeFastILU=ON");
150 else if (precTypeUpper ==
"KRYLOV") {
151 TEUCHOS_TEST_FOR_EXCEPTION
152 (
true, std::invalid_argument,
"The \"KRYLOV\" preconditioner option has "
153 "been deprecated and removed. If you want a Krylov solver, use the "
156 else if (precTypeUpper ==
"BLOCK_RELAXATION" ||
157 precTypeUpper ==
"BLOCK RELAXATION" ||
158 precTypeUpper ==
"BLOCKRELAXATION" ||
159 precTypeUpper ==
"DENSE_BLOCK_RELAXATION" ||
160 precTypeUpper ==
"DENSE BLOCK RELAXATION" ||
161 precTypeUpper ==
"DENSEBLOCKRELAXATION" ) {
166 Teuchos::ParameterList params;
167 params.set (
"relaxation: container",
"Dense");
168 prec->setParameters (params);
170 else if (precTypeUpper ==
"DATABASE SCHWARZ") {
173 else if (precTypeUpper ==
"SPARSE_BLOCK_RELAXATION" ||
174 precTypeUpper ==
"SPARSE BLOCK RELAXATION" ||
175 precTypeUpper ==
"SPARSEBLOCKRELAXATION" ) {
182#ifdef HAVE_IFPACK2_AMESOS2
184 Teuchos::ParameterList params;
185 params.set (
"relaxation: container",
"SparseAmesos2");
186 prec->setParameters (params);
188 TEUCHOS_TEST_FOR_EXCEPTION
189 (
true, std::invalid_argument,
"Ifpack2::Details::OneLevelFactory: "
190 "\"SPARSE BLOCK RELAXATION\" requires building Trilinos with Amesos2 enabled.");
193 else if (precTypeUpper ==
"TRIDI_RELAXATION" ||
194 precTypeUpper ==
"TRIDI RELAXATION" ||
195 precTypeUpper ==
"TRIDIRELAXATION" ||
196 precTypeUpper ==
"TRIDIAGONAL_RELAXATION" ||
197 precTypeUpper ==
"TRIDIAGONAL RELAXATION" ||
198 precTypeUpper ==
"TRIDIAGONALRELAXATION") {
200 Teuchos::ParameterList params;
201 params.set (
"relaxation: container",
"TriDi");
202 prec->setParameters (params);
204 else if (precTypeUpper ==
"BANDED_RELAXATION" ||
205 precTypeUpper ==
"BANDED RELAXATION" ||
206 precTypeUpper ==
"BANDEDRELAXATION") {
208 Teuchos::ParameterList params;
209 params.set (
"relaxation: container",
"Banded");
210 prec->setParameters (params);
212 else if (precTypeUpper ==
"IDENTITY" || precTypeUpper ==
"IDENTITY_SOLVER") {
216 else if (precTypeUpper ==
"LOCAL SPARSE TRIANGULAR SOLVER" ||
217 precTypeUpper ==
"LOCAL_SPARSE_TRIANGULAR_SOLVER" ||
218 precTypeUpper ==
"LOCALSPARSETRIANGULARSOLVER" ||
219 precTypeUpper ==
"SPARSE TRIANGULAR SOLVER" ||
220 precTypeUpper ==
"SPARSE_TRIANGULAR_SOLVER" ||
221 precTypeUpper ==
"SPARSETRIANGULARSOLVER") {
224 else if(precTypeUpper ==
"HIPTMAIR") {
227#ifdef HAVE_IFPACK2_HYPRE
228 else if (precTypeUpper ==
"HYPRE") {
229 prec = rcp (
new Hypre<row_matrix_type> (matrix));
233 TEUCHOS_TEST_FOR_EXCEPTION(
234 true, std::invalid_argument,
"Ifpack2::Details::OneLevelFactory::create: "
235 "Invalid preconditioner type \"" << precType <<
"\".");
238 TEUCHOS_TEST_FOR_EXCEPTION(
239 prec.is_null (), std::logic_error,
"Ifpack2::Details::OneLevelFactory::"
240 "create: Return value is null right before return. This should never "
241 "happen. Please report this bug to the Ifpack2 developers.");
245template<
class MatrixType>
247OneLevelFactory<MatrixType>::isSupported (
const std::string& precType)
const
250 std::string precTypeUpper = canonicalize(precType);
251 std::vector<std::string> supportedNames = {
252 "CHEBYSHEV",
"DENSE",
"LAPACK",
253#ifdef HAVE_IFPACK2_AMESOS2
256 "DIAGONAL",
"ILUT",
"RELAXATION",
"RILUK",
"RBILUK",
"MDF",
257#ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
258 "FAST_IC",
"FAST_ILU",
"FAST_ILDL",
260 "BLOCK_RELAXATION",
"BLOCK RELAXATION",
"BLOCKRELAXATION",
"DENSE_BLOCK_RELAXATION",
"DENSE BLOCK RELAXATION",
"DENSEBLOCKRELAXATION",
262#ifdef HAVE_IFPACK2_AMESOS2
263 "SPARSE_BLOCK_RELAXATION",
"SPARSE BLOCK RELAXATION",
"SPARSEBLOCKRELAXATION",
265 #ifdef HAVE_IFPACK2_HYPRE
268 "TRIDI_RELAXATION",
"TRIDI RELAXATION",
"TRIDIRELAXATION",
"TRIDIAGONAL_RELAXATION",
"TRIDIAGONAL RELAXATION",
"TRIDIAGONALRELAXATION",
269 "BANDED_RELAXATION",
"BANDED RELAXATION",
"BANDEDRELAXATION",
270 "IDENTITY",
"IDENTITY_SOLVER",
271 "LOCAL SPARSE TRIANGULAR SOLVER",
"LOCAL_SPARSE_TRIANGULAR_SOLVER",
"LOCALSPARSETRIANGULARSOLVER",
"SPARSE TRIANGULAR SOLVER",
"SPARSE_TRIANGULAR_SOLVER",
"SPARSETRIANGULARSOLVER",
276 auto it = std::find(std::begin(supportedNames), std::end(supportedNames), precTypeUpper);
277 return it != std::end(supportedNames);
283#define IFPACK2_DETAILS_ONELEVELFACTORY_INSTANT(S,LO,GO,N) \
284 template class Ifpack2::Details::OneLevelFactory< Tpetra::RowMatrix<S, LO, GO, N> >;
File for utility functions.
Block relaxation preconditioners (or smoothers) for Tpetra::RowMatrix and Tpetra::CrsMatrix sparse ma...
Definition Ifpack2_BlockRelaxation_decl.hpp:91
Overlapping Schwarz where redundant patches are not stored explicitly.
Definition Ifpack2_DatabaseSchwarz_decl.hpp:106
Wrapper class for direct solvers in Amesos2.
Definition Ifpack2_Details_Amesos2Wrapper_decl.hpp:111
"Preconditioner" that uses LAPACK's dense LU.
Definition Ifpack2_Details_DenseSolver_decl.hpp:84
The Ifpack2 wrapper to the incomplete Chebyshev preconditioner of ShyLU FastILU.
Definition Ifpack2_Details_Fic_decl.hpp:63
The Ifpack2 wrapper to the ILDL preconditioner of ShyLU FastILU.
Definition Ifpack2_Details_Fildl_decl.hpp:63
The Ifpack2 wrapper to the ILU preconditioner of ShyLU FastILU.
Definition Ifpack2_Details_Filu_decl.hpp:63
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:86
Diagonal preconditioner.
Definition Ifpack2_Diagonal_decl.hpp:80
ILU(k) factorization of a given Tpetra::BlockCrsMatrix.
Definition Ifpack2_Experimental_RBILUK_decl.hpp:130
Wrapper for Hiptmair smoothers.
Definition Ifpack2_Hiptmair_decl.hpp:76
ILUT (incomplete LU factorization with threshold) of a Tpetra sparse matrix.
Definition Ifpack2_ILUT_decl.hpp:102
"Identity" preconditioner.
Definition Ifpack2_IdentitySolver_decl.hpp:69
"Preconditioner" that solves local sparse triangular systems.
Definition Ifpack2_LocalSparseTriangularSolver_decl.hpp:88
MDF (incomplete LU factorization with minimum discarded fill reordering) of a Tpetra sparse matrix.
Definition Ifpack2_MDF_decl.hpp:92
ILU(k) factorization of a given Tpetra::RowMatrix.
Definition Ifpack2_RILUK_decl.hpp:254
Relaxation preconditioners for Tpetra::RowMatrix and Tpetra::CrsMatrix sparse matrices.
Definition Ifpack2_Relaxation_decl.hpp:248
Preconditioners and smoothers for Tpetra sparse matrices.
Definition Ifpack2_AdditiveSchwarz_decl.hpp:74