10#ifndef Tempus_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
11#define Tempus_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
13#include "Tempus_config.hpp"
15#include "Thyra_StateFuncModelEvaluatorBase.hpp"
37template <
typename Scalar>
49 int numExplicitOnlyBlocks = 0,
int parameterIndex = -1);
61 virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
getAppModel()
65 virtual Thyra::ModelEvaluatorBase::InArgs<Scalar>
getInArgs()
71 virtual Thyra::ModelEvaluatorBase::OutArgs<Scalar>
getOutArgs()
82 const int index = -1 )
86 typedef Thyra::ModelEvaluatorBase MEB;
88 MEB::OutArgs<Scalar> outArgs = this->createOutArgs();
90 if (y != Teuchos::null) inArgs.set_p(index, y);
91 if (inArgs.supports(MEB::IN_ARG_x_dot)) inArgs.set_x_dot(xDot);
92 if (inArgs.supports(MEB::IN_ARG_t)) inArgs.set_t(time);
93 if (inArgs.supports(MEB::IN_ARG_step_size))
94 inArgs.set_step_size(p->timeStepSize_);
95 if (inArgs.supports(MEB::IN_ARG_alpha)) inArgs.set_alpha(p->alpha_);
96 if (inArgs.supports(MEB::IN_ARG_beta)) inArgs.set_beta(p->beta_);
97 if (inArgs.supports(MEB::IN_ARG_stage_number))
98 inArgs.set_stage_number(p->stageNumber_);
111 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_x_space()
115 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_g_space(
119 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_p_space(
151 virtual Teuchos::RCP<Thyra::VectorBase<Scalar> >
getIMEXVector(
155 virtual Teuchos::RCP<const Thyra::VectorBase<Scalar> >
getIMEXVector(
181 virtual Teuchos::RCP<Thyra::LinearOpBase<Scalar> >
create_W_op()
const
186 Teuchos::RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar> >
192 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
get_f_space()
196 virtual Thyra::ModelEvaluatorBase::InArgs<Scalar>
createInArgs()
const;
200 const Thyra::ModelEvaluatorBase::InArgs<Scalar>& in,
201 const Thyra::ModelEvaluatorBase::OutArgs<Scalar>& out)
const;
209 int numExplicitOnlyBlocks = 0,
int parameterIndex = -1);
ModelEvaluator pair for implicit and explicit (IMEX) evaluations.
ModelEvaluator pair for implicit and explicit (IMEX) evaulations.
Teuchos::RCP< TimeDerivative< Scalar > > timeDer_
virtual int getNumExplicitOnlyBlocks() const
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > getOutArgs()
Get OutArgs the wrapper ModelEvalutor.
virtual void setNumExplicitOnlyBlocks(int numExp)
int parameterIndex_
implicit parameter index for explicit-only vector
bool useImplicitModel_
if true, use implicitModel_ else explicitModel_
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.
virtual Teuchos::RCP< Thyra::VectorBase< Scalar > > getIMEXVector(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &full) const
Extract IMEX vector from a full solution vector.
virtual void setParameterIndex(int parameterIndex=-1)
Set the parameter index for explicit-only vector.
int numExplicitOnlyBlocks_
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 int getParameterIndex() const
Get the parameter index for explicit-only vector.
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.
Thyra::ModelEvaluatorBase::OutArgs< Scalar > wrapperImplicitOutArgs_
virtual void evalModelImpl(const Thyra::ModelEvaluatorBase::InArgs< Scalar > &in, const Thyra::ModelEvaluatorBase::OutArgs< Scalar > &out) const
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getInArgs()
Get InArgs the wrapper ModelEvalutor.
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_f_space() const
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_p_space(int i) const
Get the p space.
virtual void setUseImplicitModel(bool tf)
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_g_space(int i) const
Get the g space.
virtual Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_W_op() const
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getExplicitModel() const
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getAppModel() const
Get the underlying application ModelEvaluator.
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Get the x-solution space.
virtual bool getUseImplicitModel() const
virtual ~WrapperModelEvaluatorPairPartIMEX_Basic()
Destructor.
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > implicitModel_
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
virtual void setAppModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &me)
Set the underlying application ModelEvaluator.
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getImplicitModel() const
WrapperModelEvaluatorPairPartIMEX_Basic()
Thyra::ModelEvaluatorBase::InArgs< Scalar > wrapperImplicitInArgs_
virtual void setExplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
Teuchos::RCP< const Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const
virtual void setImplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > explicitModel_
virtual void initialize()
Initialize after setting member data.