10 #include "Teko_Config.h"
11 #include "Teko_PreconditionerFactory.hpp"
13 #include "Teko_InverseLibrary.hpp"
14 #include "Teko_Preconditioner.hpp"
17 #include "Teko_JacobiPreconditionerFactory.hpp"
18 #include "Teko_GaussSeidelPreconditionerFactory.hpp"
19 #include "Teko_HierarchicalGaussSeidelPreconditionerFactory.hpp"
20 #include "Teko_AddPreconditionerFactory.hpp"
21 #include "Teko_MultPreconditionerFactory.hpp"
22 #include "Teko_LU2x2PreconditionerFactory.hpp"
23 #include "Teko_IterativePreconditionerFactory.hpp"
24 #include "Teko_DiagnosticPreconditionerFactory.hpp"
25 #include "Teko_DiagonallyScaledPreconditionerFactory.hpp"
26 #include "Teko_DiagonalPreconditionerFactory.hpp"
27 #include "Teko_AdaptivePreconditionerFactory.hpp"
28 #ifdef TEKO_HAVE_EPETRA
29 #include "Teko_ProbingPreconditionerFactory.hpp"
31 #include "Teko_IdentityPreconditionerFactory.hpp"
32 #include "NS/Teko_LSCPreconditionerFactory.hpp"
33 #include "NS/Teko_SIMPLEPreconditionerFactory.hpp"
34 #include "NS/Teko_TimingsSIMPLEPreconditionerFactory.hpp"
36 #ifdef Teko_ENABLE_ML_SMOOTHERS
37 #include "Teko_SmootherPreconditionerFactory.hpp"
38 #include "Teko_MLPreconditionerFactory.hpp"
41 #include "Thyra_DefaultPreconditioner.hpp"
43 using namespace Thyra;
50 bool PreconditionerFactory::isCompatible(
const Thyra::LinearOpSourceBase<double> &fwdOpSrc)
const {
51 RCP<const Thyra::LinearOpBase<double> > A = fwdOpSrc.getOp();
52 return A != Teuchos::null;
56 RCP<Thyra::PreconditionerBase<double> > PreconditionerFactory::createPrec()
const {
59 bp->setStateObject(buildPreconditionerState());
60 bp->getStateObject()->setInitialized(
false);
66 void PreconditionerFactory::initializePrec(
const RCP<
const LinearOpSourceBase<double> > &ASrc,
67 PreconditionerBase<double> *prec,
68 const ESupportSolveUse )
const {
70 LinearOp A = Teuchos::rcp_const_cast<Thyra::LinearOpBase<double> >(ASrc->getOp());
73 TEUCHOS_ASSERT(blkPrec != 0);
76 RCP<PreconditionerState> state = blkPrec->getStateObject();
77 state->setInitialized(
false);
80 const RCP<const LinearOpBase<double> > M = buildPreconditionerOperator(A, *state);
83 setOpRequestHandler(*
this, M);
86 DefaultPreconditioner<double> &dPrec = Teuchos::dyn_cast<DefaultPreconditioner<double> >(*prec);
87 dPrec.initializeUnspecified(Teuchos::rcp_const_cast<LinearOpBase<double> >(M));
91 void PreconditionerFactory::initializePrec(
92 const RCP<
const LinearOpSourceBase<double> > &ASrc,
93 const RCP<
const Thyra::MultiVectorBase<double> > &solnVec, PreconditionerBase<double> *prec,
94 const ESupportSolveUse supportSolveUse)
const {
95 Preconditioner *blkPrec =
dynamic_cast<Preconditioner *
>(prec);
96 blkPrec->setSourceVector(Teuchos::rcp_const_cast<Thyra::MultiVectorBase<double> >(solnVec));
98 initializePrec(ASrc, prec, supportSolveUse);
102 void PreconditionerFactory::uninitializePrec(
103 PreconditionerBase<double> * ,
104 RCP<
const LinearOpSourceBase<double> > * ,
105 ESupportSolveUse * )
const {
109 TEUCHOS_TEST_FOR_EXCEPT_MSG(
true,
"\"PreconditionerFactory::uninitializePrec not implemented\"");
116 void PreconditionerFactory::setParameterList(
const RCP<Teuchos::ParameterList> ¶mList) {
117 paramList_ = paramList;
121 RCP<Teuchos::ParameterList> PreconditionerFactory::getNonconstParameterList() {
return paramList_; }
124 RCP<Teuchos::ParameterList> PreconditionerFactory::unsetParameterList() {
125 RCP<Teuchos::ParameterList> _paramList = paramList_;
126 paramList_ = Teuchos::null;
131 void PreconditionerFactory::setInverseLibrary(
const RCP<const InverseLibrary> &il) {
132 inverseLibrary_ = il;
136 RCP<const InverseLibrary> PreconditionerFactory::getInverseLibrary()
const {
138 if (inverseLibrary_ == Teuchos::null)
return InverseLibrary::buildFromStratimikos();
140 return inverseLibrary_;
149 const LinearOp &op) {
150 ModifiableLinearOp mlo = Teuchos::rcp_const_cast<Thyra::LinearOpBase<double> >(op);
153 RCP<RequestHandlerContainer> reqHandCont =
155 if (reqHandCont != Teuchos::null) {
163 CloneFactory<PreconditionerFactory> PreconditionerFactory::precFactoryBuilder_;
179 RCP<PreconditionerFactory> PreconditionerFactory::buildPreconditionerFactory(
180 const std::string &name,
const Teuchos::ParameterList &settings,
181 const RCP<const InverseLibrary> &invLib) {
182 Teko_DEBUG_SCOPE(
"PreconditionerFactory::buildPreconditionerFactory", 10);
185 if (precFactoryBuilder_.cloneCount() == 0) initializePrecFactoryBuilder();
188 RCP<PreconditionerFactory> precFact = precFactoryBuilder_.build(name);
190 Teko_DEBUG_MSG_BEGIN(5);
191 DEBUG_STREAM <<
"Looked up \"" << name <<
"\"" << std::endl;
192 DEBUG_STREAM <<
"Built " << precFact << std::endl;
193 Teko_DEBUG_MSG_END();
195 if (precFact == Teuchos::null)
return Teuchos::null;
198 if (invLib != Teuchos::null) {
199 precFact->setInverseLibrary(invLib);
200 precFact->setRequestHandler(invLib->getRequestHandler());
205 precFact->initializeFromParameterList(settings);
223 void PreconditionerFactory::addPreconditionerFactory(
const std::string &name,
224 const RCP<Cloneable> &clone) {
226 if (precFactoryBuilder_.cloneCount() == 0) initializePrecFactoryBuilder();
229 precFactoryBuilder_.addClone(name, clone);
233 void PreconditionerFactory::initializePrecFactoryBuilder() {
234 RCP<Cloneable> clone;
238 precFactoryBuilder_.addClone(
"Block LU2x2", clone);
241 precFactoryBuilder_.addClone(
"Block Jacobi", clone);
244 precFactoryBuilder_.addClone(
"Block Gauss-Seidel", clone);
247 precFactoryBuilder_.addClone(
"Hierarchical Block Gauss-Seidel", clone);
250 precFactoryBuilder_.addClone(
"Block Add", clone);
253 precFactoryBuilder_.addClone(
"Block Multiply", clone);
256 precFactoryBuilder_.addClone(
"NS LSC", clone);
259 precFactoryBuilder_.addClone(
"NS SIMPLE", clone);
262 precFactoryBuilder_.addClone(
"NS SIMPLE-Timed", clone);
265 precFactoryBuilder_.addClone(
"Iterative Preconditioner", clone);
268 precFactoryBuilder_.addClone(
"Explicit Diagonal Preconditioner", clone);
271 precFactoryBuilder_.addClone(
"Diagnostic Inverse", clone);
274 precFactoryBuilder_.addClone(
"Diagonal Scaling", clone);
277 precFactoryBuilder_.addClone(
"Identity", clone);
280 precFactoryBuilder_.addClone(
"Adaptive", clone);
282 #if defined(Teko_ENABLE_Isorropia) && defined(TEKO_HAVE_EPETRA)
284 precFactoryBuilder_.addClone(
"Probing Preconditioner", clone);
287 #ifdef Teko_ENABLE_ML_SMOOTHERS
289 precFactoryBuilder_.addClone(
"Blocked ML Preconditioner", clone);
293 void PreconditionerFactory::getPreconditionerFactoryNames(std::vector<std::string> &names) {
295 if (precFactoryBuilder_.cloneCount() == 0) initializePrecFactoryBuilder();
296 precFactoryBuilder_.getCloneNames(names);
virtual void setRequestHandler(const Teuchos::RCP< RequestHandler > &rh)=0
Set the request handler with pointers to the appropriate callbacks.
An extension of the Thyra::DefaultPreconditioner class with some specializations useful for use withi...
virtual Teuchos::RCP< RequestHandler > getRequestHandler() const =0
Get the request handler with pointers to the appropriate callbacks.