|
Tempus
Version of the Day
Time Integration
|
Go to the documentation of this file.
9 #ifndef Tempus_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
10 #define Tempus_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
13 #include "Thyra_StateFuncModelEvaluatorBase.hpp"
36 template <
typename Scalar>
47 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> >& explicitModel,
48 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> >& implicitModel,
49 int numExplicitOnlyBlocks = 0,
int parameterIndex = -1);
60 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> > & me);
61 virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
65 virtual void setInArgs(Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs)
69 virtual Thyra::ModelEvaluatorBase::InArgs<Scalar>
getInArgs()
73 virtual void setOutArgs(Thyra::ModelEvaluatorBase::OutArgs<Scalar> outArgs)
77 virtual Thyra::ModelEvaluatorBase::OutArgs<Scalar>
getOutArgs()
82 Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs,
83 Thyra::ModelEvaluatorBase::OutArgs<Scalar> outArgs)
96 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
100 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
104 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
112 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> > & model )
115 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> > & model );
116 virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
118 virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
124 virtual Teuchos::RCP<Thyra::VectorBase<Scalar> >
getIMEXVector(
125 const Teuchos::RCP<Thyra::VectorBase<Scalar> > & full)
const;
128 virtual Teuchos::RCP<const Thyra::VectorBase<Scalar> >
getIMEXVector(
129 const Teuchos::RCP<
const Thyra::VectorBase<Scalar> > & full)
const;
133 const Teuchos::RCP<Thyra::VectorBase<Scalar> > & full)
const;
137 const Teuchos::RCP<
const Thyra::VectorBase<Scalar> > & full)
const;
152 virtual Teuchos::RCP<Thyra::LinearOpBase<Scalar> >
create_W_op()
const
155 Teuchos::RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar> >
158 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
162 virtual Thyra::ModelEvaluatorBase::InArgs<Scalar>
createInArgs()
const;
166 const Thyra::ModelEvaluatorBase::InArgs<Scalar> & in,
167 const Thyra::ModelEvaluatorBase::OutArgs<Scalar> & out)
const;
174 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> >& explicitModel,
175 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> >& implicitModel,
176 int numExplicitOnlyBlocks = 0,
int parameterIndex = -1);
192 #endif // Tempus_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
WrapperModelEvaluatorPairPartIMEX_Basic()
Default constructor – Still requires setting the models and running initialize.
void setup(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &explicitModel, const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &implicitModel, int numExplicitOnlyBlocks=0, int parameterIndex=-1)
Setup ME when using default constructor – for derived classes.
ModelEvaluator pair for implicit and explicit (IMEX) evaulations.
ModelEvaluator pair for implicit and explicit (IMEX) evaluations.
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > implicitModel_
virtual void setNumExplicitOnlyBlocks(int numExp)
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_p_space(int i) const
Get the p space.
virtual Teuchos::RCP< Thyra::VectorBase< Scalar > > getExplicitOnlyVector(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &full) const
Extract explicit-only vector from a full solution vector.
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_g_space(int i) const
Get the g space.
virtual void initialize()
Initialize after setting member data.
virtual bool getUseImplicitModel() const
Get parameter to switch wrapperME base functions between explicit and implicit functions.
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_f_space() const
Thyra::ModelEvaluatorBase::InArgs< Scalar > wrapperImplicitInArgs_
virtual void setExplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
Teuchos::RCP< TimeDerivative< Scalar > > timeDer_
virtual ~WrapperModelEvaluatorPairPartIMEX_Basic()
Destructor.
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getAppModel() const
Get the underlying application ModelEvaluator.
int numExplicitOnlyBlocks_
virtual void setAppModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &me)
Set the underlying application ModelEvaluator.
virtual void setOutArgs(Thyra::ModelEvaluatorBase::OutArgs< Scalar > outArgs)
Set OutArgs the wrapper ModelEvalutor.
virtual void setParameterIndex(int parameterIndex=-1)
Set the parameter index for explicit-only vector.
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > getOutArgs()
Get OutArgs the wrapper ModelEvalutor.
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
virtual void setInArgs(Thyra::ModelEvaluatorBase::InArgs< Scalar > inArgs)
Set InArgs the wrapper ModelEvalutor.
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getInArgs()
Get InArgs the wrapper ModelEvalutor.
virtual void setUseImplicitModel(bool tf)
Set parameter to switch wrapperME base functions between explicit and implicit functions.
virtual Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_W_op() const
This interface defines the time derivative connection between an implicit Stepper and WrapperModelEva...
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getImplicitModel() const
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
virtual int getNumExplicitOnlyBlocks() const
virtual Teuchos::RCP< Thyra::VectorBase< Scalar > > getIMEXVector(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &full) const
Extract IMEX vector from a full solution vector.
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Get the x-solution space.
Thyra::ModelEvaluatorBase::OutArgs< Scalar > wrapperImplicitOutArgs_
virtual void setImplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
virtual int getParameterIndex() const
Get the parameter index for explicit-only vector.
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getExplicitModel() const
Teuchos::RCP< const Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const
virtual void evalModelImpl(const Thyra::ModelEvaluatorBase::InArgs< Scalar > &in, const Thyra::ModelEvaluatorBase::OutArgs< Scalar > &out) const
virtual void setForSolve(Teuchos::RCP< TimeDerivative< Scalar > > timeDer, Thyra::ModelEvaluatorBase::InArgs< Scalar > inArgs, Thyra::ModelEvaluatorBase::OutArgs< Scalar > outArgs)
Set parameters for application implicit ModelEvaluator solve.
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > explicitModel_