Tempus  Version of the Day
Time Integration
Tempus_WrapperModelEvaluatorPairPartIMEX_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_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
10 #define Tempus_ModelEvaluatorPairPartIMEX_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  * All functions called on WrapperModelEvaluatorPairPartIMEX_Basic will call
21  * the same function on the implicit Model Evaluator. This was selected
22  * because the WrapperModelEvaluatorPairPartIMEX_Basic will be passed to the
23  * solvers which in turn make calls to solve the implicit ODE.
24  *
25  * If the explicit version of the Model Evaluator functions are needed,
26  * one should directly call it through the explicit Model Evaluator, e.g.,
27  * getExplicitModel()->get_x_space().
28  *
29  * The one exception to this rule is for getNominalValues(), which is
30  * controlled by implicitNominalValues. During the Integrator initialization
31  * this->getNominalValues needs to return
32  * explicitModel_->getNominalValues() [implicitNominalValues=false is the
33  * default], but during the nonlinear solves this->getNominalValues needs
34  * to return implicitModel_->getNominalValues() [implicitNominalValues=true].
35  */
36 template <typename Scalar>
39 {
40 public:
41 
42  /// Default constructor -- Still requires setting the models and running initialize.
44 
45  /// Constructor
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);
50 
51  /// Destructor
53 
54  /// Initialize after setting member data.
55  virtual void initialize();
56 
57  /// \name Overridden from Tempus::WrapperModelEvaluatorPairIMEX
58  //@{
59  virtual void setAppModel(
60  const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > & me);
61  virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
62  getAppModel() const;
63 
64  /// Set InArgs the wrapper ModelEvalutor.
65  virtual void setInArgs(Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs)
66  { wrapperImplicitInArgs_.setArgs(inArgs); }
67 
68  /// Get InArgs the wrapper ModelEvalutor.
69  virtual Thyra::ModelEvaluatorBase::InArgs<Scalar> getInArgs()
70  { return wrapperImplicitInArgs_; }
71 
72  /// Set OutArgs the wrapper ModelEvalutor.
73  virtual void setOutArgs(Thyra::ModelEvaluatorBase::OutArgs<Scalar> outArgs)
74  { wrapperImplicitOutArgs_.setArgs(outArgs); }
75 
76  /// Get OutArgs the wrapper ModelEvalutor.
77  virtual Thyra::ModelEvaluatorBase::OutArgs<Scalar> getOutArgs()
78  { return wrapperImplicitOutArgs_; }
79 
80  /// Set parameters for application implicit ModelEvaluator solve.
81  virtual void setForSolve(Teuchos::RCP<TimeDerivative<Scalar> > timeDer,
82  Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs,
83  Thyra::ModelEvaluatorBase::OutArgs<Scalar> outArgs)
84  {
85  timeDer_ = timeDer;
86  wrapperImplicitInArgs_.setArgs(inArgs);
87  wrapperImplicitOutArgs_.setArgs(outArgs);
88  useImplicitModel_ = true;
89  }
90 
91  //@}
92 
93  /// \name Methods that apply to both explicit and implicit terms.
94  //@{
95  /// Get the x-solution space
96  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
97  get_x_space() const;
98 
99  /// Get the g space
100  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
101  get_g_space(int i) const;
102 
103  /// Get the p space
104  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
105  get_p_space(int i) const;
106  //@}
107 
108  //@{ \name Accessors
109  virtual void setNumExplicitOnlyBlocks(int numExp)
110  {numExplicitOnlyBlocks_ = numExp; }
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  virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
117  getExplicitModel() const { return explicitModel_; }
118  virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> >
119  getImplicitModel() const { return implicitModel_; }
120  virtual int getNumExplicitOnlyBlocks() const
121  { return numExplicitOnlyBlocks_; }
122 
123  /// Extract IMEX vector from a full solution vector
124  virtual Teuchos::RCP<Thyra::VectorBase<Scalar> > getIMEXVector(
125  const Teuchos::RCP<Thyra::VectorBase<Scalar> > & full) const;
126 
127  /// Extract IMEX vector for reading
128  virtual Teuchos::RCP<const Thyra::VectorBase<Scalar> > getIMEXVector(
129  const Teuchos::RCP<const Thyra::VectorBase<Scalar> > & full) const;
130 
131  /// Extract explicit-only vector from a full solution vector
132  virtual Teuchos::RCP<Thyra::VectorBase<Scalar> > getExplicitOnlyVector(
133  const Teuchos::RCP<Thyra::VectorBase<Scalar> > & full) const;
134 
135  /// Extract explicit-only vector for reading
136  virtual Teuchos::RCP<const Thyra::VectorBase<Scalar> >getExplicitOnlyVector(
137  const Teuchos::RCP<const Thyra::VectorBase<Scalar> > & full) const;
138 
139  /// Set the parameter index for explicit-only vector
140  virtual void setParameterIndex(int parameterIndex = -1);
141  /// Get the parameter index for explicit-only vector
142  virtual int getParameterIndex() const { return parameterIndex_; }
143 
144  /// Set parameter to switch wrapperME base functions between explicit and implicit functions.
145  virtual void setUseImplicitModel(bool tf) { useImplicitModel_ = tf; }
146  /// Get parameter to switch wrapperME base functions between explicit and implicit functions.
147  virtual bool getUseImplicitModel() const { return useImplicitModel_; }
148  //@}
149 
150  /// \name Overridden from Thyra::StateFuncModelEvaluatorBase
151  //@{
152  virtual Teuchos::RCP<Thyra::LinearOpBase<Scalar> > create_W_op() const
153  { return implicitModel_->create_W_op(); }
154 
155  Teuchos::RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar> >
156  get_W_factory() const { return implicitModel_->get_W_factory(); }
157 
158  virtual Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar> >
159  get_f_space() const;
160 
161  virtual Thyra::ModelEvaluatorBase::InArgs<Scalar> getNominalValues() const;
162  virtual Thyra::ModelEvaluatorBase::InArgs<Scalar> createInArgs() const;
163  virtual Thyra::ModelEvaluatorBase::OutArgs<Scalar>createOutArgsImpl() const;
164 
165  virtual void evalModelImpl(
166  const Thyra::ModelEvaluatorBase::InArgs<Scalar> & in,
167  const Thyra::ModelEvaluatorBase::OutArgs<Scalar> & out) const;
168  //@}
169 
170 protected:
171 
172  /// Setup ME when using default constructor -- for derived classes
173  void setup(
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);
177 
178  Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > explicitModel_;
179  Teuchos::RCP<const Thyra::ModelEvaluator<Scalar> > implicitModel_;
180 
181  Teuchos::RCP<TimeDerivative<Scalar> > timeDer_;
182  Thyra::ModelEvaluatorBase::InArgs<Scalar> wrapperImplicitInArgs_;
183  Thyra::ModelEvaluatorBase::OutArgs<Scalar> wrapperImplicitOutArgs_;
184 
186  int parameterIndex_; //< implicit parameter index for explicit-only vector
187  bool useImplicitModel_; //< if true, use implicitModel_ else explicitModel_
188 };
189 
190 } // namespace Tempus
191 
192 #endif // Tempus_ModelEvaluatorPairPartIMEX_Basic_decl_hpp
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::WrapperModelEvaluatorPairPartIMEX_Basic
WrapperModelEvaluatorPairPartIMEX_Basic()
Default constructor – Still requires setting the models and running initialize.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:20
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setup
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.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:43
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::parameterIndex_
int parameterIndex_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:186
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic
ModelEvaluator pair for implicit and explicit (IMEX) evaulations.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:37
Tempus_WrapperModelEvaluatorPairIMEX.hpp
Tempus::WrapperModelEvaluatorPairIMEX
ModelEvaluator pair for implicit and explicit (IMEX) evaluations.
Definition: Tempus_WrapperModelEvaluatorPairIMEX.hpp:25
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::createOutArgsImpl
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:368
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::implicitModel_
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > implicitModel_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:179
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setNumExplicitOnlyBlocks
virtual void setNumExplicitOnlyBlocks(int numExp)
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:109
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::get_p_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_p_space(int i) const
Get the p space.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:147
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getExplicitOnlyVector
virtual Teuchos::RCP< Thyra::VectorBase< Scalar > > getExplicitOnlyVector(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &full) const
Extract explicit-only vector from a full solution vector.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:226
Tempus
Definition: Tempus_AdjointAuxSensitivityModelEvaluator_decl.hpp:20
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::get_g_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_g_space(int i) const
Get the g space.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:137
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::initialize
virtual void initialize()
Initialize after setting member data.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:61
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::useImplicitModel_
bool useImplicitModel_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:187
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getUseImplicitModel
virtual bool getUseImplicitModel() const
Get parameter to switch wrapperME base functions between explicit and implicit functions.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:147
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::get_f_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_f_space() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:324
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::wrapperImplicitInArgs_
Thyra::ModelEvaluatorBase::InArgs< Scalar > wrapperImplicitInArgs_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:182
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setExplicitModel
virtual void setExplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:111
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::timeDer_
Teuchos::RCP< TimeDerivative< Scalar > > timeDer_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:181
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::~WrapperModelEvaluatorPairPartIMEX_Basic
virtual ~WrapperModelEvaluatorPairPartIMEX_Basic()
Destructor.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:52
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getAppModel
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getAppModel() const
Get the underlying application ModelEvaluator.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:115
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::numExplicitOnlyBlocks_
int numExplicitOnlyBlocks_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:185
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setAppModel
virtual void setAppModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &me)
Set the underlying application ModelEvaluator.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:103
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setOutArgs
virtual void setOutArgs(Thyra::ModelEvaluatorBase::OutArgs< Scalar > outArgs)
Set OutArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:73
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setParameterIndex
virtual void setParameterIndex(int parameterIndex=-1)
Set the parameter index for explicit-only vector.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:282
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getOutArgs
virtual Thyra::ModelEvaluatorBase::OutArgs< Scalar > getOutArgs()
Get OutArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:77
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getNominalValues
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:335
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setInArgs
virtual void setInArgs(Thyra::ModelEvaluatorBase::InArgs< Scalar > inArgs)
Set InArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:65
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getInArgs
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > getInArgs()
Get InArgs the wrapper ModelEvalutor.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:69
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setUseImplicitModel
virtual void setUseImplicitModel(bool tf)
Set parameter to switch wrapperME base functions between explicit and implicit functions.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:145
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::create_W_op
virtual Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_W_op() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:152
Tempus::TimeDerivative
This interface defines the time derivative connection between an implicit Stepper and WrapperModelEva...
Definition: Tempus_TimeDerivative.hpp:32
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getImplicitModel
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getImplicitModel() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:119
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::createInArgs
virtual Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:346
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getNumExplicitOnlyBlocks
virtual int getNumExplicitOnlyBlocks() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:120
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getIMEXVector
virtual Teuchos::RCP< Thyra::VectorBase< Scalar > > getIMEXVector(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &full) const
Extract IMEX vector from a full solution vector.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:166
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::get_x_space
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Get the x-solution space.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:127
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::wrapperImplicitOutArgs_
Thyra::ModelEvaluatorBase::OutArgs< Scalar > wrapperImplicitOutArgs_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:183
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::setImplicitModel
virtual void setImplicitModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model)
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:157
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getParameterIndex
virtual int getParameterIndex() const
Get the parameter index for explicit-only vector.
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:142
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::getExplicitModel
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getExplicitModel() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:117
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::get_W_factory
Teuchos::RCP< const Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:156
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::evalModelImpl
virtual void evalModelImpl(const Thyra::ModelEvaluatorBase::InArgs< Scalar > &in, const Thyra::ModelEvaluatorBase::OutArgs< Scalar > &out) const
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_impl.hpp:389
Tempus::WrapperModelEvaluatorPairPartIMEX_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_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:81
Tempus::WrapperModelEvaluatorPairPartIMEX_Basic::explicitModel_
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > explicitModel_
Definition: Tempus_WrapperModelEvaluatorPairPartIMEX_Basic_decl.hpp:178