10#ifndef Tempus_ModelEvaluatorPairIMEX_Basic_decl_hpp
11#define Tempus_ModelEvaluatorPairIMEX_Basic_decl_hpp
13#include "Tempus_config.hpp"
15#include "Thyra_StateFuncModelEvaluatorBase.hpp"
38template <
typename Scalar>
63 virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
getAppModel()
72 const int index = -1 )
88 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_x_space()
92 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_g_space(
96 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_p_space(
125 virtual Teuchos::RCP<Thyra::LinearOpBase<Scalar> >
create_W_op()
const
130 Teuchos::RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar> >
136 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_f_space()
143 virtual Thyra::ModelEvaluatorBase::InArgs<Scalar>
createInArgs()
const;
147 const Thyra::ModelEvaluatorBase::InArgs<Scalar>& in,
148 const Thyra::ModelEvaluatorBase::OutArgs<Scalar>& out)
const;
169 Teuchos::RCP<Thyra::VectorBase<Scalar> >
x_;
170 Teuchos::RCP<Thyra::VectorBase<Scalar> >
xDot_;
172 Teuchos::RCP<ImplicitODEParameters<Scalar> >
p_;
173 Teuchos::RCP<Thyra::VectorBase<Scalar> >
y_;
ModelEvaluator pair for implicit and explicit (IMEX) evaulations.
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
virtual void setImplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
WrapperModelEvaluatorPairIMEX_Basic()
Default constructor – only allowed for derived classes.
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getExplicitModel() const
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_f_space() const
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > implicitModel_
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_g_space(int i) const
Get the g space.
Teuchos::RCP< Thyra::VectorBase< Scalar > > y_
virtual Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_W_op() const
virtual void setAppModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &me)
Set the underlying application ModelEvaluator.
virtual void initialize()
Initialize after setting member data.
virtual void evalModelImpl(const Thyra::ModelEvaluatorBase::InArgs< Scalar > &in, const Thyra::ModelEvaluatorBase::OutArgs< Scalar > &out) const
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getAppModel() const
Get the underlying application ModelEvaluator.
void setForSolve(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &x, const Teuchos::RCP< Thyra::VectorBase< Scalar > > &xDot, const Scalar time, const Teuchos::RCP< ImplicitODEParameters< Scalar > > &p, const Teuchos::RCP< Thyra::VectorBase< Scalar > > &y=Teuchos::null, const int index=-1)
Set parameters for application implicit ModelEvaluator solve.
Teuchos::RCP< Thyra::VectorBase< Scalar > > x_
Teuchos::RCP< TimeDerivative< Scalar > > timeDer_
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Get the x-solution space.
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > explicitModel_
virtual ~WrapperModelEvaluatorPairIMEX_Basic()
Destructor.
Teuchos::RCP< const Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getImplicitModel() const
Teuchos::RCP< ImplicitODEParameters< Scalar > > p_
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_p_space(int i) const
Get the p space.
Teuchos::RCP< Thyra::VectorBase< Scalar > > xDot_
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
virtual void setExplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
WrapperModelEvaluatorPairIMEX_Basic(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &explicitModel, const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &implicitModel)
Constructor.
void setup(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &explicitModel, const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &implicitModel)
Setup ME when using default constructor – for derived classes.
ModelEvaluator pair for implicit and explicit (IMEX) evaluations.