43 #ifndef IFPACK2_DETAILS_ONELEVELFACTORY_DECL_HPP 44 #define IFPACK2_DETAILS_ONELEVELFACTORY_DECL_HPP 46 #include "Ifpack2_ConfigDefs.hpp" 48 #include "Tpetra_RowMatrix.hpp" 49 #include <type_traits> 109 template<
class MatrixType>
112 typedef typename MatrixType::scalar_type scalar_type;
113 typedef typename MatrixType::local_ordinal_type local_ordinal_type;
114 typedef typename MatrixType::global_ordinal_type global_ordinal_type;
115 typedef typename MatrixType::node_type node_type;
116 typedef ::Ifpack2::Preconditioner<scalar_type,
120 typedef ::Tpetra::RowMatrix<scalar_type,
123 node_type> row_matrix_type;
125 static_assert (std::is_same<MatrixType, row_matrix_type>::value,
126 "Ifpack2::Details::OneLevelFactory: MatrixType must be a " 127 "Tpetra::RowMatrix specialization.");
139 Teuchos::RCP<prec_type>
140 create (
const std::string& precType,
141 const Teuchos::RCP<const row_matrix_type>& matrix)
const;
147 #endif // IFPACK2_DETAILS_ONELEVELFACTORY_DECL_HPP 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:68
Ifpack2 implementation details.
Interface for all Ifpack2 preconditioners.
Definition: Ifpack2_Preconditioner.hpp:107
"Factory" for creating single-level preconditioners.
Definition: Ifpack2_Details_OneLevelFactory_decl.hpp:110
Preconditioners and smoothers for Tpetra sparse matrices.
Definition: Ifpack2_AdditiveSchwarz_decl.hpp:72