42 #ifndef THYRA_AZTECOO_LINEAR_OP_WITH_SOLVE_FACTORY_HPP 43 #define THYRA_AZTECOO_LINEAR_OP_WITH_SOLVE_FACTORY_HPP 45 #include "Thyra_LinearOpWithSolveFactoryBase.hpp" 46 #include "Thyra_EpetraOperatorViewExtractorBase.hpp" 47 #include "Teuchos_StandardMemberCompositionMacros.hpp" 48 #include "Teuchos_StandardCompositionMacros.hpp" 51 namespace Teuchos {
class ParameterList; }
87 Teuchos::RCP<Teuchos::ParameterList>
const& paramList = Teuchos::null
98 STANDARD_COMPOSITION_MEMBERS( EpetraOperatorViewExtractorBase, epetraFwdOpViewExtractor );
105 bool acceptsPreconditionerFactory()
const;
107 void setPreconditionerFactory(
108 const Teuchos::RCP<PreconditionerFactoryBase<double> > &precFactory,
109 const std::string &precFactoryName
112 Teuchos::RCP<PreconditionerFactoryBase<double> > getPreconditionerFactory()
const;
114 void unsetPreconditionerFactory(
115 Teuchos::RCP<PreconditionerFactoryBase<double> > *precFactory,
116 std::string *precFactoryName
119 bool isCompatible(
const LinearOpSourceBase<double> &fwdOpSrc )
const;
121 Teuchos::RCP<LinearOpWithSolveBase<double> > createOp()
const;
124 const Teuchos::RCP<
const LinearOpSourceBase<double> > &fwdOpSrc,
125 LinearOpWithSolveBase<double> *Op,
126 const ESupportSolveUse supportSolveUse
129 void initializeAndReuseOp(
130 const Teuchos::RCP<
const LinearOpSourceBase<double> > &fwdOpSrc,
131 LinearOpWithSolveBase<double> *Op
135 LinearOpWithSolveBase<double> *Op,
136 Teuchos::RCP<
const LinearOpSourceBase<double> > *fwdOpSrc,
137 Teuchos::RCP<
const PreconditionerBase<double> > *prec,
138 Teuchos::RCP<
const LinearOpSourceBase<double> > *approxFwdOpSrc,
139 ESupportSolveUse *supportSolveUse
142 bool supportsPreconditionerInputType(
const EPreconditionerInputType precOpType)
const;
144 void initializePreconditionedOp(
145 const Teuchos::RCP<
const LinearOpSourceBase<double> > &fwdOpSrc,
146 const Teuchos::RCP<
const PreconditionerBase<double> > &prec,
147 LinearOpWithSolveBase<double> *Op,
148 const ESupportSolveUse supportSolveUse
151 void initializeApproxPreconditionedOp(
152 const Teuchos::RCP<
const LinearOpSourceBase<double> > &fwdOpSrc,
153 const Teuchos::RCP<
const LinearOpSourceBase<double> > &approxFwdOpSrc,
154 LinearOpWithSolveBase<double> *Op,
155 const ESupportSolveUse supportSolveUse
163 void setParameterList(Teuchos::RCP<Teuchos::ParameterList>
const& paramList);
165 Teuchos::RCP<Teuchos::ParameterList> getNonconstParameterList();
167 Teuchos::RCP<Teuchos::ParameterList> unsetParameterList();
169 Teuchos::RCP<const Teuchos::ParameterList> getParameterList()
const;
171 Teuchos::RCP<const Teuchos::ParameterList> getValidParameters()
const;
179 std::string description()
const;
188 Teuchos::RCP<PreconditionerFactoryBase<double> > precFactory_;
189 std::string precFactoryName_;
190 Teuchos::RCP<Teuchos::ParameterList> thisValidParamList_;
191 Teuchos::RCP<Teuchos::ParameterList> paramList_;
193 int defaultFwdMaxIterations_;
194 double defaultFwdTolerance_;
195 int defaultAdjMaxIterations_;
196 double defaultAdjTolerance_;
197 bool outputEveryRhs_;
204 static Teuchos::RCP<const Teuchos::ParameterList> generateAndGetValidParameters();
205 void updateThisValidParamList();
207 void initializeOp_impl(
208 const Teuchos::RCP<
const LinearOpSourceBase<double> > &fwdOpSrc,
209 const Teuchos::RCP<
const PreconditionerBase<double> > &prec,
210 const Teuchos::RCP<
const LinearOpSourceBase<double> > &approxFwdOpSrc,
211 const bool reusePrec,
212 LinearOpWithSolveBase<double> *Op
221 #endif // THYRA_AZTECOO_LINEAR_OP_WITH_SOLVE_FACTORY_HPP LinearOpWithSolveFactoryBase subclass implemented in terms of AztecOO.