Ifpack2 Templated Preconditioning Package Version 1.0
Loading...
Searching...
No Matches
Ifpack2_Details_OneLevelFactory_def.hpp
1// @HEADER
2// *****************************************************************************
3// Ifpack2: Templated Object-Oriented Algebraic Preconditioner Package
4//
5// Copyright 2009 NTESS and the Ifpack2 contributors.
6// SPDX-License-Identifier: BSD-3-Clause
7// *****************************************************************************
8// @HEADER
9
10#ifndef IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
11#define IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
12
13#include "Ifpack2_Factory.hpp"
14#include "Ifpack2_Utilities.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"
32
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
38
39#ifdef HAVE_IFPACK2_AMESOS2
40# include "Ifpack2_Details_Amesos2Wrapper.hpp"
41#endif // HAVE_IFPACK2_AMESOS2
42
43#ifdef HAVE_IFPACK2_HYPRE
44# include "Ifpack2_Hypre.hpp"
45#endif // HAVE_IFPACK2_HYPRE
46
47
48namespace Ifpack2 {
49namespace Details {
50
51template<class MatrixType>
52Teuchos::RCP<typename OneLevelFactory<MatrixType>::prec_type>
53OneLevelFactory<MatrixType>::create (const std::string& precType,
54 const Teuchos::RCP<const row_matrix_type>& matrix) const
55{
56 using Teuchos::RCP;
57 using Teuchos::rcp;
58
59 RCP<prec_type> prec;
60
61 // precTypeUpper is the upper-case version of precType.
62 std::string precTypeUpper = canonicalize(precType);
63
64 if (precTypeUpper == "CHEBYSHEV") {
65 // We have to distinguish Ifpack2::Chebyshev from its
66 // implementation class Ifpack2::Details::Chebyshev.
67 prec = rcp (new ::Ifpack2::Chebyshev<row_matrix_type> (matrix));
68 }
69 else if (precTypeUpper == "DENSE" || precTypeUpper == "LAPACK") {
70 prec = rcp (new Details::DenseSolver<row_matrix_type> (matrix));
71 }
72 else if (precTypeUpper == "AMESOS2") {
73#ifdef HAVE_IFPACK2_AMESOS2
74 prec = rcp (new Details::Amesos2Wrapper<row_matrix_type> (matrix));
75#else
76 TEUCHOS_TEST_FOR_EXCEPTION(
77 true, std::invalid_argument, "Ifpack2::Details::OneLevelFactory: "
78 "You may not ask for the preconditioner \"AMESOS2\" unless "
79 "you have built Trilinos with the Amesos2 package enabled.");
80#endif // HAVE_IFPACK2_AMESOS2
81 }
82 else if (precTypeUpper == "DIAGONAL") {
83 prec = rcp (new Diagonal<row_matrix_type> (matrix));
84 }
85 else if (precTypeUpper == "ILUT") {
86 prec = rcp (new ILUT<row_matrix_type> (matrix));
87 }
88 else if (precTypeUpper == "RELAXATION") {
89 prec = rcp (new Relaxation<row_matrix_type> (matrix));
90 }
91 else if (precTypeUpper == "RILUK") {
92 prec = rcp (new RILUK<row_matrix_type> (matrix));
93 }
94 else if (precTypeUpper == "MDF") {
95 prec = rcp (new MDF<row_matrix_type> (matrix));
96 }
97 else if (precTypeUpper == "RBILUK") {
98 prec = rcp (new Experimental::RBILUK<row_matrix_type>(matrix));
99 }
100 else if (precTypeUpper == "FAST_IC" || precTypeUpper == "FAST_ILU" || precTypeUpper == "FAST_ILU_B" || precTypeUpper == "FAST_ILDL") {
101 #ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
102 {
103 if(precTypeUpper == "FAST_IC")
105 else if(precTypeUpper == "FAST_ILU")
107 else if(precTypeUpper == "FAST_ILU_B")
109 else if(precTypeUpper == "FAST_ILDL")
111 }
112 #else
113 {
114 throw std::invalid_argument("The Ifpack2 FastIC, FastILU and FastILDL preconditioners require the FastILU subpackage of ShyLU to be enabled\n"
115 "To enable FastILU, set the CMake option Trilinos_ENABLE_ShyLU_NodeFastILU=ON");
116 }
117 #endif
118 }
119 else if (precTypeUpper == "KRYLOV") {
120 TEUCHOS_TEST_FOR_EXCEPTION
121 (true, std::invalid_argument, "The \"KRYLOV\" preconditioner option has "
122 "been deprecated and removed. If you want a Krylov solver, use the "
123 "Belos package.");
124 }
125 else if (precTypeUpper == "BLOCK_RELAXATION" ||
126 precTypeUpper == "BLOCK RELAXATION" ||
127 precTypeUpper == "BLOCKRELAXATION" ||
128 precTypeUpper == "DENSE_BLOCK_RELAXATION" ||
129 precTypeUpper == "DENSE BLOCK RELAXATION" ||
130 precTypeUpper == "DENSEBLOCKRELAXATION" ) {
131 // NOTE (mfh 12 Aug 2016) Choice of "container type" is now a
132 // run-time parameter. The "ContainerType" template parameter is
133 // now always Container<row_matrix_type>.
134 prec = rcp (new BlockRelaxation<row_matrix_type> (matrix));
135 Teuchos::ParameterList params;
136 params.set ("relaxation: container", "Dense");
137 prec->setParameters (params);
138 }
139 else if (precTypeUpper == "DATABASE SCHWARZ") {
140 prec = rcp (new DatabaseSchwarz<row_matrix_type> (matrix));
141 }
142 else if (precTypeUpper == "SPARSE_BLOCK_RELAXATION" ||
143 precTypeUpper == "SPARSE BLOCK RELAXATION" ||
144 precTypeUpper == "SPARSEBLOCKRELAXATION" ) {
145 // FIXME (mfh 22 May 2014) We would prefer to have the choice of
146 // dense or sparse blocks (the "container type") be a run-time
147 // decision. This will require refactoring BlockRelaxation so
148 // that the "container type" is not a template parameter. For
149 // now, we default to use dense blocks.
150 //typedef SparseContainer<row_matrix_type, ILUT<row_matrix_type>> container_type;
151#ifdef HAVE_IFPACK2_AMESOS2
152 prec = rcp (new BlockRelaxation<row_matrix_type> (matrix));
153 Teuchos::ParameterList params;
154 params.set ("relaxation: container", "SparseAmesos2");
155 prec->setParameters (params);
156#else
157 TEUCHOS_TEST_FOR_EXCEPTION
158 (true, std::invalid_argument, "Ifpack2::Details::OneLevelFactory: "
159 "\"SPARSE BLOCK RELAXATION\" requires building Trilinos with Amesos2 enabled.");
160#endif
161 }
162 else if (precTypeUpper == "TRIDI_RELAXATION" ||
163 precTypeUpper == "TRIDI RELAXATION" ||
164 precTypeUpper == "TRIDIRELAXATION" ||
165 precTypeUpper == "TRIDIAGONAL_RELAXATION" ||
166 precTypeUpper == "TRIDIAGONAL RELAXATION" ||
167 precTypeUpper == "TRIDIAGONALRELAXATION") {
168 prec = rcp (new BlockRelaxation<row_matrix_type> (matrix));
169 Teuchos::ParameterList params;
170 params.set ("relaxation: container", "TriDi");
171 prec->setParameters (params);
172 }
173 else if (precTypeUpper == "BANDED_RELAXATION" ||
174 precTypeUpper == "BANDED RELAXATION" ||
175 precTypeUpper == "BANDEDRELAXATION") {
176 prec = rcp (new BlockRelaxation<row_matrix_type> (matrix));
177 Teuchos::ParameterList params;
178 params.set ("relaxation: container", "Banded");
179 prec->setParameters (params);
180 }
181 else if (precTypeUpper == "IDENTITY" || precTypeUpper == "IDENTITY_SOLVER") {
182 prec = rcp (new IdentitySolver<row_matrix_type> (matrix));
183 }
184
185 else if (precTypeUpper == "LOCAL SPARSE TRIANGULAR SOLVER" ||
186 precTypeUpper == "LOCAL_SPARSE_TRIANGULAR_SOLVER" ||
187 precTypeUpper == "LOCALSPARSETRIANGULARSOLVER" ||
188 precTypeUpper == "SPARSE TRIANGULAR SOLVER" ||
189 precTypeUpper == "SPARSE_TRIANGULAR_SOLVER" ||
190 precTypeUpper == "SPARSETRIANGULARSOLVER") {
191 prec = rcp (new LocalSparseTriangularSolver<row_matrix_type> (matrix));
192 }
193 else if(precTypeUpper == "HIPTMAIR") {
194 prec = rcp (new Hiptmair<row_matrix_type> (matrix));
195 }
196#ifdef HAVE_IFPACK2_HYPRE
197 else if (precTypeUpper == "HYPRE") {
198 prec = rcp (new Hypre<row_matrix_type> (matrix));
199 }
200#endif
201 else {
202 TEUCHOS_TEST_FOR_EXCEPTION(
203 true, std::invalid_argument, "Ifpack2::Details::OneLevelFactory::create: "
204 "Invalid preconditioner type \"" << precType << "\".");
205 }
206
207 TEUCHOS_TEST_FOR_EXCEPTION(
208 prec.is_null (), std::logic_error, "Ifpack2::Details::OneLevelFactory::"
209 "create: Return value is null right before return. This should never "
210 "happen. Please report this bug to the Ifpack2 developers.");
211 return prec;
212}
213
214template<class MatrixType>
215bool
216OneLevelFactory<MatrixType>::isSupported (const std::string& precType) const
217{
218 // precTypeUpper is the upper-case version of precType.
219 std::string precTypeUpper = canonicalize(precType);
220 std::vector<std::string> supportedNames = {
221 "CHEBYSHEV", "DENSE", "LAPACK",
222#ifdef HAVE_IFPACK2_AMESOS2
223 "AMESOS2",
224#endif
225 "DIAGONAL", "ILUT", "RELAXATION", "RILUK", "RBILUK", "MDF",
226#ifdef HAVE_IFPACK2_SHYLU_NODEFASTILU
227 "FAST_IC", "FAST_ILU", "FAST_ILU_B", "FAST_ILDL",
228#endif
229 "BLOCK_RELAXATION", "BLOCK RELAXATION", "BLOCKRELAXATION", "DENSE_BLOCK_RELAXATION", "DENSE BLOCK RELAXATION", "DENSEBLOCKRELAXATION",
230 "DATABASE SCHWARZ",
231#ifdef HAVE_IFPACK2_AMESOS2
232 "SPARSE_BLOCK_RELAXATION", "SPARSE BLOCK RELAXATION", "SPARSEBLOCKRELAXATION",
233#endif
234 #ifdef HAVE_IFPACK2_HYPRE
235 "HYPRE",
236#endif
237 "TRIDI_RELAXATION", "TRIDI RELAXATION", "TRIDIRELAXATION", "TRIDIAGONAL_RELAXATION", "TRIDIAGONAL RELAXATION", "TRIDIAGONALRELAXATION",
238 "BANDED_RELAXATION", "BANDED RELAXATION", "BANDEDRELAXATION",
239 "IDENTITY", "IDENTITY_SOLVER",
240 "LOCAL SPARSE TRIANGULAR SOLVER", "LOCAL_SPARSE_TRIANGULAR_SOLVER", "LOCALSPARSETRIANGULARSOLVER", "SPARSE TRIANGULAR SOLVER", "SPARSE_TRIANGULAR_SOLVER", "SPARSETRIANGULARSOLVER",
241 "HIPTMAIR"
242 };
243 // const size_t numSupportedNames = supportedNames.size();
244 // const auto end = supportedNames + numSupportedNames;
245 auto it = std::find(std::begin(supportedNames), std::end(supportedNames), precTypeUpper);
246 return it != std::end(supportedNames);
247}
248
249} // namespace Details
250} // namespace Ifpack2
251
252#define IFPACK2_DETAILS_ONELEVELFACTORY_INSTANT(S,LO,GO,N) \
253 template class Ifpack2::Details::OneLevelFactory< Tpetra::RowMatrix<S, LO, GO, N> >;
254
255#endif // IFPACK2_DETAILS_ONELEVELFACTORY_DEF_HPP
File for utility functions.
Block relaxation preconditioners (or smoothers) for Tpetra::RowMatrix and Tpetra::CrsMatrix sparse ma...
Definition Ifpack2_BlockRelaxation_decl.hpp:58
Overlapping Schwarz where redundant patches are not stored explicitly.
Definition Ifpack2_DatabaseSchwarz_decl.hpp:72
Wrapper class for direct solvers in Amesos2.
Definition Ifpack2_Details_Amesos2Wrapper_decl.hpp:78
"Preconditioner" that uses LAPACK's dense LU.
Definition Ifpack2_Details_DenseSolver_decl.hpp:51
The Ifpack2 wrapper to the incomplete Chebyshev preconditioner of ShyLU FastILU.
Definition Ifpack2_Details_Fic_decl.hpp:30
The Ifpack2 wrapper to the ILDL preconditioner of ShyLU FastILU.
Definition Ifpack2_Details_Fildl_decl.hpp:30
The Ifpack2 wrapper to the ILU preconditioner of ShyLU FastILU.
Definition Ifpack2_Details_Filu_decl.hpp:30
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:53
Diagonal preconditioner.
Definition Ifpack2_Diagonal_decl.hpp:47
ILU(k) factorization of a given Tpetra::BlockCrsMatrix.
Definition Ifpack2_Experimental_RBILUK_decl.hpp:97
Wrapper for Hiptmair smoothers.
Definition Ifpack2_Hiptmair_decl.hpp:43
ILUT (incomplete LU factorization with threshold) of a Tpetra sparse matrix.
Definition Ifpack2_ILUT_decl.hpp:69
"Identity" preconditioner.
Definition Ifpack2_IdentitySolver_decl.hpp:36
"Preconditioner" that solves local sparse triangular systems.
Definition Ifpack2_LocalSparseTriangularSolver_decl.hpp:55
MDF (incomplete LU factorization with minimum discarded fill reordering) of a Tpetra sparse matrix.
Definition Ifpack2_MDF_decl.hpp:59
ILU(k) factorization of a given Tpetra::RowMatrix.
Definition Ifpack2_RILUK_decl.hpp:222
Relaxation preconditioners for Tpetra::RowMatrix and Tpetra::CrsMatrix sparse matrices.
Definition Ifpack2_Relaxation_decl.hpp:217
Preconditioners and smoothers for Tpetra sparse matrices.
Definition Ifpack2_AdditiveSchwarz_decl.hpp:41