47 #ifndef STRATIMIKOS_MUELU_TPETRA_HELPERS_HPP
48 #define STRATIMIKOS_MUELU_TPETRA_HELPERS_HPP
51 #include "Stratimikos_LinearSolverBuilder.hpp"
57 #if defined(HAVE_MUELU_EXPERIMENTAL) && defined(HAVE_MUELU_TEKO)
64 #include "Teuchos_AbstractFactoryStd.hpp"
68 namespace Stratimikos {
70 template <
typename Scalar = MueLu::DefaultScalar,
typename LocalOrdinal = MueLu::DefaultLocalOrdinal,
typename GlobalOrdinal = MueLu::DefaultGlobalOrdinal,
typename Node = MueLu::DefaultNode>
71 void enableMueLu(LinearSolverBuilder<Scalar>& builder,
const std::string& stratName =
"MueLu") {
72 #if defined(HAVE_MUELU_STRATIMIKOS) && defined(HAVE_MUELU_THYRA)
76 "Stratimikos::enableMueLu cannot add \"" + stratName +
"\" because it is already included in builder!");
78 typedef Thyra::PreconditionerFactoryBase<Scalar> Base;
79 typedef Thyra::MueLuPreconditionerFactory<Scalar, LocalOrdinal, GlobalOrdinal, Node> Impl;
81 builder.setPreconditioningStrategyFactory(Teuchos::abstractFactoryStd<Base, Impl>(), stratName);
85 template <
typename LocalOrdinal,
typename GlobalOrdinal,
typename Node>
86 MUELU_DEPRECATED
void enableMueLu(LinearSolverBuilder<double>& builder,
const std::string& stratName =
"MueLu") {
87 enableMueLu<double, LocalOrdinal, GlobalOrdinal, Node>(builder, stratName);
90 template <
typename Scalar = MueLu::DefaultScalar,
typename LocalOrdinal = MueLu::DefaultLocalOrdinal,
typename GlobalOrdinal = MueLu::DefaultGlobalOrdinal,
typename Node = MueLu::DefaultNode>
91 void enableMueLuRefMaxwell(LinearSolverBuilder<Scalar>& builder,
const std::string& stratName =
"MueLuRefMaxwell") {
92 #if defined(HAVE_MUELU_STRATIMIKOS) && defined(HAVE_MUELU_THYRA)
96 "Stratimikos::enableMueLuRefMaxwell cannot add \"" + stratName +
"\" because it is already included in builder!");
98 typedef Thyra::PreconditionerFactoryBase<Scalar> Base;
99 typedef Thyra::MueLuRefMaxwellPreconditionerFactory<Scalar, LocalOrdinal, GlobalOrdinal, Node> Impl;
101 builder.setPreconditioningStrategyFactory(Teuchos::abstractFactoryStd<Base, Impl>(), stratName);
105 template <
typename LocalOrdinal,
typename GlobalOrdinal,
typename Node>
106 MUELU_DEPRECATED
void enableMueLuRefMaxwell(LinearSolverBuilder<double>& builder,
const std::string& stratName =
"MueLuRefMaxwell") {
107 enableMueLuRefMaxwell<double, LocalOrdinal, GlobalOrdinal, Node>(builder, stratName);
110 template <
typename Scalar = MueLu::DefaultScalar,
typename LocalOrdinal = MueLu::DefaultLocalOrdinal,
typename GlobalOrdinal = MueLu::DefaultGlobalOrdinal,
typename Node = MueLu::DefaultNode>
111 void enableMueLuMaxwell1(LinearSolverBuilder<Scalar>& builder,
const std::string& stratName =
"MueLuMaxwell1") {
112 #if defined(HAVE_MUELU_STRATIMIKOS) && defined(HAVE_MUELU_THYRA)
116 "Stratimikos::enableMueLuRefMaxwell cannot add \"" + stratName +
"\" because it is already included in builder!");
118 typedef Thyra::PreconditionerFactoryBase<Scalar> Base;
119 typedef Thyra::MueLuMaxwell1PreconditionerFactory<Scalar, LocalOrdinal, GlobalOrdinal, Node> Impl;
121 builder.setPreconditioningStrategyFactory(Teuchos::abstractFactoryStd<Base, Impl>(), stratName);
125 template <
typename LocalOrdinal,
typename GlobalOrdinal,
typename Node>
126 MUELU_DEPRECATED
void enableMueLuMaxwell1(LinearSolverBuilder<double>& builder,
const std::string& stratName =
"MueLuMaxwell1") {
127 enableMueLuMaxwell1<double, LocalOrdinal, GlobalOrdinal, Node>(builder, stratName);
130 #if defined(HAVE_MUELU_EXPERIMENTAL) && defined(HAVE_MUELU_TEKO)
133 void enableMueLuTpetraQ2Q1(DefaultLinearSolverBuilder &builder,
const std::string &stratName =
"MueLu");
136 template <
typename Scalar = MueLu::DefaultScalar,
typename LocalOrdinal = MueLu::DefaultLocalOrdinal,
typename GlobalOrdinal = MueLu::DefaultGlobalOrdinal,
typename Node = MueLu::DefaultNode>
141 "Stratimikos::enableMueLuTpetraQ2Q1 cannot add \"" + stratName +
"\" because it is already included in builder!");
143 typedef Thyra::PreconditionerFactoryBase<Scalar> Base;
146 builder.setPreconditioningStrategyFactory(Teuchos::abstractFactoryStd<Base, Impl>(), stratName);
149 template <
typename LocalOrdinal,
typename GlobalOrdinal,
typename Node>
150 MUELU_DEPRECATED
void enableMueLuTpetraQ2Q1(LinearSolverBuilder<double>& builder,
const std::string& stratName =
"MueLu") {
151 enableMueLuTpetraQ2Q1<double, LocalOrdinal, GlobalOrdinal, Node>(builder, stratName);
void enableMueLu(LinearSolverBuilder< Scalar > &builder, const std::string &stratName="MueLu")
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Concrete preconditioner factory subclass based on MueLu.
void enableMueLuTpetraQ2Q1(LinearSolverBuilder< Scalar > &builder, const std::string &stratName="MueLu")
bool isParameter(const std::string &name) const
void enableMueLuRefMaxwell(LinearSolverBuilder< Scalar > &builder, const std::string &stratName="MueLuRefMaxwell")
void enableMueLuMaxwell1(LinearSolverBuilder< Scalar > &builder, const std::string &stratName="MueLuMaxwell1")