Tempus  Version of the Day
Time Integration
Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp
Go to the documentation of this file.
1 // @HEADER
2 // ****************************************************************************
3 // Tempus: Copyright (2017) Sandia Corporation
4 //
5 // Distributed under BSD 3-clause license (See accompanying file Copyright.txt)
6 // ****************************************************************************
7 // @HEADER
8 
9 #ifndef Tempus_ModelEvaluatorPairIMEX_Basic_decl_hpp
10 #define Tempus_ModelEvaluatorPairIMEX_Basic_decl_hpp
11 
13 #include "Thyra_StateFuncModelEvaluatorBase.hpp"
14 
15 
16 namespace Tempus {
17 
18 /** \brief ModelEvaluator pair for implicit and explicit (IMEX) evaulations.
19  *
20  * This ModelEvaluator takes a state, x, and determines the explicit and
21  * implicit residuals. Additionally, it coordinates the explicit and
22  * implicit physics to ensure they are compatible, e.g.,
23  * how to translate between implicit and explicit model in and out
24  * arguments, if needed.
25  *
26  * All functions called on WrapperModelEvaluatorPairIMEX_Basic will call
27  * the same function on the implicit Model Evaluator. This was selected
28  * because the WrapperModelEvaluatorPairIMEX_Basic will be passed to the
29  * solvers which in turn make calls to solve the implicit ODE.
30  *
31  * If the explicit version of the Model Evaluator functions are needed,
32  * one should directly call it through the explicit Model Evaluator, e.g.,
33  * getExplicitModel()->get_x_space().
34  *
35  * This was taken and modified from Drekar's IMEXModelPair class.
36  */
37 template <typename Scalar>
40 {
41 public:
42 
43  /// Constructor
45  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >& explicitModel,
46  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >& implicitModel)
47  : timeDer_(Teuchos::null)
48  {
49  setExplicitModel(explicitModel);
50  setImplicitModel(implicitModel);
51  initialize();
52  }
53 
54  /// Destructor
56 
57  /// Initialize after setting member data.
58  virtual void initialize();
59 
60  /// \name Overridden from Tempus::WrapperModelEvaluatorPairIMEX
61  //@{
62  virtual void setAppModel(
63  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > & me);
64  virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
65  getAppModel() const;
66 
67  /// Set InArgs the wrapper ModelEvalutor.
68  virtual void setInArgs(Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs)
69  { wrapperImplicitInArgs_.setArgs(inArgs); }
70 
71  /// Get InArgs the wrapper ModelEvalutor.
72  virtual Thyra::ModelEvaluatorBase::InArgs<Scalar> getInArgs()
73  { return wrapperImplicitInArgs_; }
74 
75  /// Set OutArgs the wrapper ModelEvalutor.
76  virtual void setOutArgs(Thyra::ModelEvaluatorBase::OutArgs<Scalar> outArgs)
77  { wrapperImplicitOutArgs_.setArgs(outArgs); }
78 
79  /// Get OutArgs the wrapper ModelEvalutor.
80  virtual Thyra::ModelEvaluatorBase::OutArgs<Scalar> getOutArgs()
81  { return wrapperImplicitOutArgs_; }
82 
83  /// Set parameters for application implicit ModelEvaluator solve.
84  virtual void setForSolve(Teuchos::RCP<TimeDerivative<Scalar> > timeDer,
85  Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs,
86  Thyra::ModelEvaluatorBase::OutArgs<Scalar> outArgs)
87  {
88  timeDer_ = timeDer;
89  wrapperImplicitInArgs_.setArgs(inArgs);
90  wrapperImplicitOutArgs_.setArgs(outArgs);
91  }
92 
93  //@}
94 
95  /// \name Methods that apply to both explicit and implicit terms.
96  //@{
97  /// Get the x-solution space
98  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
99  get_x_space() const;
100 
101  /// Get the g space
102  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
103  get_g_space(int i) const;
104 
105  /// Get the p space
106  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
107  get_p_space(int i) const;
108  //@}
109 
110  //@{ \name Accessors
111  virtual void setExplicitModel(
112  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > & model )
113  { explicitModel_ = model; }
114  virtual void setImplicitModel(
115  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > & model )
116  { implicitModel_ = model; }
117  virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
118  getExplicitModel() const { return explicitModel_; }
119  virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
120  getImplicitModel() const { return implicitModel_; }
121  //@}
122 
123  /// \name Overridden from Thyra::StateFuncModelEvaluatorBase
124  //@{
125  virtual Teuchos::RCP<Thyra::LinearOpBase<Scalar> > create_W_op() const
126  { return implicitModel_->create_W_op(); }
127 
128  Teuchos::RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar> >
129  get_W_factory() const { return implicitModel_->get_W_factory(); }
130 
131  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
132  get_f_space() const { return explicitModel_->get_f_space(); }
133 
134  virtual Thyra::ModelEvaluatorBase::InArgs<Scalar> getNominalValues() const;
135  virtual Thyra::ModelEvaluatorBase::InArgs<Scalar> createInArgs() const;
136  virtual Thyra::ModelEvaluatorBase::OutArgs<Scalar>createOutArgsImpl() const;
137 
138  virtual void evalModelImpl(
139  const Thyra::ModelEvaluatorBase::InArgs<Scalar> & in,
140  const Thyra::ModelEvaluatorBase::OutArgs<Scalar> & out) const;
141  //@}
142 
143 protected:
144 
145  /// Default constructor -- only allowed for derived classes
147 
148  /// Setup ME when using default constructor -- for derived classes
149  void setup(
150  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >& explicitModel,
151  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >& implicitModel)
152  {
153  setExplicitModel(explicitModel);
154  setImplicitModel(implicitModel);
155  initialize();
156  }
157 
158 protected:
159 
160  Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > explicitModel_;
161  Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > implicitModel_;
162 
163  Teuchos::RCP<TimeDerivative<Scalar> > timeDer_;
164  Thyra::ModelEvaluatorBase::InArgs<Scalar> wrapperImplicitInArgs_;
165  Thyra::ModelEvaluatorBase::OutArgs<Scalar> wrapperImplicitOutArgs_;
166 };
167 
168 } // namespace Tempus
169 
170 #endif // Tempus_ModelEvaluatorPairIMEX_Basic_decl_hpp
Tempus::WrapperModelEvaluatorPairIMEX_Basic::get_f_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_f_space() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:132
Tempus::WrapperModelEvaluatorPairIMEX_Basic::wrapperImplicitOutArgs_
Thyra::ModelEvaluatorBase::OutArgs< Scalar > wrapperImplicitOutArgs_
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:165
Tempus::WrapperModelEvaluatorPairIMEX_Basic::wrapperImplicitInArgs_
Thyra::ModelEvaluatorBase::InArgs< Scalar > wrapperImplicitInArgs_
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:164
Tempus::WrapperModelEvaluatorPairIMEX_Basic
ModelEvaluator pair for implicit and explicit (IMEX) evaulations.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:38
Tempus::WrapperModelEvaluatorPairIMEX_Basic::WrapperModelEvaluatorPairIMEX_Basic
WrapperModelEvaluatorPairIMEX_Basic()
Default constructor – only allowed for derived classes.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:146
Tempus::WrapperModelEvaluatorPairIMEX_Basic::getOutArgs
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > getOutArgs()
Get OutArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:80
Tempus::WrapperModelEvaluatorPairIMEX_Basic::evalModelImpl
virtual void evalModelImpl(const Thyra::ModelEvaluatorBase::InArgs< Scalar > &in, const Thyra::ModelEvaluatorBase::OutArgs< Scalar > &out) const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:130
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setExplicitModel
virtual void setExplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:111
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setAppModel
virtual void setAppModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &me)
Set the underlying application ModelEvaluator.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:50
Tempus_WrapperModelEvaluatorPairIMEX.hpp
Tempus::WrapperModelEvaluatorPairIMEX
ModelEvaluator pair for implicit and explicit (IMEX) evaluations.
Definition: Tempus_WrapperModelEvaluatorPairIMEX.hpp:25
Tempus::WrapperModelEvaluatorPairIMEX_Basic::~WrapperModelEvaluatorPairIMEX_Basic
virtual ~WrapperModelEvaluatorPairIMEX_Basic()
Destructor.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:55
Tempus::WrapperModelEvaluatorPairIMEX_Basic::explicitModel_
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > explicitModel_
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:160
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setOutArgs
virtual void setOutArgs(Thyra::ModelEvaluatorBase::OutArgs< Scalar > outArgs)
Set OutArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:76
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setForSolve
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.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:84
Tempus
Definition: Tempus_AdjointAuxSensitivityModelEvaluator_decl.hpp:20
Tempus::WrapperModelEvaluatorPairIMEX_Basic::get_x_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Get the x-solution space.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:74
Tempus::WrapperModelEvaluatorPairIMEX_Basic::getAppModel
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getAppModel() const
Get the underlying application ModelEvaluator.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:62
Tempus::WrapperModelEvaluatorPairIMEX_Basic::getNominalValues
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:98
Tempus::WrapperModelEvaluatorPairIMEX_Basic::get_W_factory
Teuchos::RCP< const Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:129
Tempus::WrapperModelEvaluatorPairIMEX_Basic::create_W_op
virtual Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_W_op() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:125
Tempus::WrapperModelEvaluatorPairIMEX_Basic::WrapperModelEvaluatorPairIMEX_Basic
WrapperModelEvaluatorPairIMEX_Basic(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &explicitModel, const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &implicitModel)
Constructor.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:44
Tempus::WrapperModelEvaluatorPairIMEX_Basic::getInArgs
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getInArgs()
Get InArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:72
Tempus::WrapperModelEvaluatorPairIMEX_Basic::implicitModel_
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > implicitModel_
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:161
Tempus::WrapperModelEvaluatorPairIMEX_Basic::get_p_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_p_space(int i) const
Get the p space.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:90
Tempus::WrapperModelEvaluatorPairIMEX_Basic::get_g_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_g_space(int i) const
Get the g space.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:82
Tempus::WrapperModelEvaluatorPairIMEX_Basic::createInArgs
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:108
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setInArgs
virtual void setInArgs(Thyra::ModelEvaluatorBase::InArgs< Scalar > inArgs)
Set InArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:68
Tempus::WrapperModelEvaluatorPairIMEX_Basic::getImplicitModel
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getImplicitModel() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:120
Tempus::WrapperModelEvaluatorPairIMEX_Basic::getExplicitModel
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getExplicitModel() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:118
Tempus::TimeDerivative
This interface defines the time derivative connection between an implicit Stepper and WrapperModelEva...
Definition: Tempus_TimeDerivative.hpp:32
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setImplicitModel
virtual void setImplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:114
Tempus::WrapperModelEvaluatorPairIMEX_Basic::setup
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.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:149
Teuchos
Definition: Tempus_Integrator.hpp:19
Tempus::WrapperModelEvaluatorPairIMEX_Basic::initialize
virtual void initialize()
Initialize after setting member data.
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:21
Tempus::WrapperModelEvaluatorPairIMEX_Basic::createOutArgsImpl
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_impl.hpp:120
Tempus::WrapperModelEvaluatorPairIMEX_Basic::timeDer_
Teuchos::RCP< TimeDerivative< Scalar > > timeDer_
Definition: Tempus_WrapperModelEvaluatorPairIMEX_Basic_decl.hpp:163