Tempus  Version of the Day
Time Integration
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Tempus_IntegratorAdjointSensitivity_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_IntegratorAdjointSensitivity_decl_hpp
10 #define Tempus_IntegratorAdjointSensitivity_decl_hpp
11 
12 // Tempus
13 #include "Tempus_config.hpp"
14 #include "Tempus_IntegratorBasic.hpp"
15 #include "Tempus_AdjointAuxSensitivityModelEvaluator.hpp"
16 
17 #include "Tempus_StepperStaggeredForwardSensitivity.hpp" // For SensitivityStepMode
18 
19 namespace Tempus {
20 
50 template <class Scalar>
51 class IntegratorAdjointSensitivity : virtual public Tempus::Integrator<Scalar> {
52  public:
114  const Teuchos::RCP<IntegratorBasic<Scalar>> &state_integrator,
115  const Teuchos::RCP<Thyra::ModelEvaluator<Scalar>> &adjoint_model,
117  &adjoint_aux_model,
118  const Teuchos::RCP<IntegratorBasic<Scalar>> &adjoint_integrator,
119  const Teuchos::RCP<SolutionHistory<Scalar>> &solution_history,
120  const int p_index, const int g_index, const bool g_depends_on_p,
121  const bool f_depends_on_p, const bool ic_depends_on_p,
122  const bool mass_matrix_is_identity);
123 
127 
130 
132 
133 
135  virtual bool advanceTime();
137  virtual bool advanceTime(const Scalar timeFinal) override;
139  virtual Scalar getTime() const override;
141  virtual int getIndex() const override;
143  virtual Status getStatus() const override;
145  virtual void setStatus(const Status st) override;
147  virtual Teuchos::RCP<Stepper<Scalar>> getStepper() const override;
150  const override;
155  override;
158  const override;
160  override;
165  {
166  return state_integrator_->getIntegratorTimer();
167  }
169  {
170  return state_integrator_->getStepperTimer();
171  }
172 
174 
176  virtual void initializeSolutionHistory(
177  Scalar t0, Teuchos::RCP<const Thyra::VectorBase<Scalar>> x0,
178  Teuchos::RCP<const Thyra::VectorBase<Scalar>> xdot0 = Teuchos::null,
179  Teuchos::RCP<const Thyra::VectorBase<Scalar>> xdotdot0 = Teuchos::null,
180  Teuchos::RCP<const Thyra::MultiVectorBase<Scalar>> DxDp0 = Teuchos::null,
182  Teuchos::null,
183  Teuchos::RCP<const Thyra::MultiVectorBase<Scalar>> DxdotdotDp0 =
184  Teuchos::null);
185 
189  virtual void setObserver(
190  Teuchos::RCP<IntegratorObserver<Scalar>> obs = Teuchos::null);
192  virtual void initialize();
193 
200 
207 
210 
212  {
213  return adjoint_model_;
214  };
215 
217 
218  std::string description() const override;
220  const Teuchos::EVerbosityLevel verbLevel) const override;
222 
225 
226  protected:
227  // Create sensitivity model evaluator from application model
230  const Teuchos::RCP<Thyra::ModelEvaluator<Scalar>> &adjoint_model,
231  const Teuchos::RCP<Teuchos::ParameterList> &inputPL);
232 
234  const Teuchos::RCP<const SolutionHistory<Scalar>> &state_solution_history,
236  &adjoint_solution_history);
237 
244  int p_index_;
245  int g_index_;
253 };
254 
256 
272 template <class Scalar>
277  const Teuchos::RCP<Thyra::ModelEvaluator<Scalar>> &adjoint_model =
278  Teuchos::null);
279 
281 template <class Scalar>
284 
285 } // namespace Tempus
286 
287 #endif // Tempus_IntegratorAdjointSensitivity_decl_hpp
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const override
virtual Teuchos::RCP< const Thyra::MultiVectorBase< Scalar > > getYDot() const
Get the current time derivative of the adjoint solution, ydot.
SensitivityStepMode getStepMode() const
What mode the current time integration step is in.
Teuchos::RCP< Thyra::MultiVectorBase< Scalar > > dgdp_
virtual Teuchos::RCP< TimeStepControl< Scalar > > getNonConstTimeStepControl() override
virtual void setObserver(Teuchos::RCP< IntegratorObserver< Scalar >> obs=Teuchos::null)
Set the Observer.
virtual Teuchos::RCP< const Thyra::VectorBase< Scalar > > getXDotDot() const
Get the current second time derivative of the solution, xdotdot.
virtual void setStatus(const Status st) override
Set Status.
void buildSolutionHistory(const Teuchos::RCP< const SolutionHistory< Scalar >> &state_solution_history, const Teuchos::RCP< const SolutionHistory< Scalar >> &adjoint_solution_history)
Teuchos::RCP< AdjointAuxSensitivityModelEvaluator< Scalar > > adjoint_aux_model_
virtual Teuchos::RCP< SolutionHistory< Scalar > > getNonConstSolutionHistory() override
Get the SolutionHistory.
ModelEvaluator for forming adjoint sensitivity equations.
virtual Teuchos::RCP< Teuchos::Time > getStepperTimer() const override
virtual Teuchos::RCP< const Thyra::VectorBase< Scalar > > getXDot() const
Get the current time derivative of the solution, xdot.
Teuchos::RCP< SolutionHistory< Scalar > > solutionHistory_
virtual Teuchos::RCP< IntegratorObserver< Scalar > > getObserver()
Get the Observer.
Teuchos::RCP< IntegratorBasic< Scalar > > adjoint_integrator_
virtual Teuchos::RCP< const Thyra::VectorBase< Scalar > > getX() const
Get the current solution, x.
virtual Teuchos::RCP< Teuchos::Time > getIntegratorTimer() const override
Returns the IntegratorTimer_ for this Integrator.
Teuchos::RCP< IntegratorAdjointSensitivity< Scalar > > createIntegratorAdjointSensitivity(Teuchos::RCP< Teuchos::ParameterList > pList, const Teuchos::RCP< Thyra::ModelEvaluator< Scalar >> &model, const Teuchos::RCP< Thyra::ModelEvaluator< Scalar >> &adjoint_model=Teuchos::null)
Nonmember constructor.
virtual Teuchos::RCP< const SolutionHistory< Scalar > > getSolutionHistory() const override
Get the SolutionHistory.
Status
Status for the Integrator, the Stepper and the SolutionState.
Teuchos::RCP< const Thyra::MultiVectorBase< Scalar > > dxdp_init_
IntegratorObserver class for time integrators.
virtual Teuchos::RCP< const Thyra::MultiVectorBase< Scalar > > getYDotDot() const
Get the current second time derivative of the adjoint solution, ydotdot.
Teuchos::RCP< AdjointAuxSensitivityModelEvaluator< Scalar > > createAdjointModel(const Teuchos::RCP< Thyra::ModelEvaluator< Scalar >> &model, const Teuchos::RCP< Thyra::ModelEvaluator< Scalar >> &adjoint_model, const Teuchos::RCP< Teuchos::ParameterList > &inputPL)
virtual Teuchos::RCP< const TimeStepControl< Scalar > > getTimeStepControl() const override
Get the TimeStepControl.
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
virtual bool advanceTime()
Advance the solution to timeMax, and return true if successful.
Teuchos::RCP< TimeStepControl< Scalar > > getSensNonConstTimeStepControl()
Teuchos::RCP< const SolutionHistory< Scalar > > getSensSolutionHistory() const
Teuchos::RCP< Thyra::ModelEvaluator< Scalar > > getAdjointModel() const
Teuchos::RCP< IntegratorBasic< Scalar > > state_integrator_
virtual Teuchos::RCP< const Thyra::MultiVectorBase< Scalar > > getY() const
Get the current adjoint solution, y.
virtual void initializeSolutionHistory(Scalar t0, Teuchos::RCP< const Thyra::VectorBase< Scalar >> x0, Teuchos::RCP< const Thyra::VectorBase< Scalar >> xdot0=Teuchos::null, Teuchos::RCP< const Thyra::VectorBase< Scalar >> xdotdot0=Teuchos::null, Teuchos::RCP< const Thyra::MultiVectorBase< Scalar >> DxDp0=Teuchos::null, Teuchos::RCP< const Thyra::MultiVectorBase< Scalar >> DxdotDp0=Teuchos::null, Teuchos::RCP< const Thyra::MultiVectorBase< Scalar >> DxdotdotDp0=Teuchos::null)
Set the initial state from Thyra::VectorBase(s)
Teuchos::RCP< const SolutionHistory< Scalar > > getStateSolutionHistory() const
Teuchos::RCP< Thyra::ModelEvaluator< Scalar > > model_
Teuchos::RCP< Thyra::ModelEvaluator< Scalar > > adjoint_model_
Thyra Base interface for time integrators. Time integrators are designed to advance the solution from...
Time integrator suitable for adjoint sensitivity analysis.
virtual int getIndex() const override
Get current index.
Teuchos::RCP< TimeStepControl< Scalar > > getStateNonConstTimeStepControl()
virtual Scalar getTime() const override
Get current time.
virtual Status getStatus() const override
Get Status.
virtual void initialize()
Initializes the Integrator after set* function calls.
virtual Teuchos::RCP< Stepper< Scalar > > getStepper() const override
Get the Stepper.
virtual Teuchos::RCP< const Thyra::MultiVectorBase< Scalar > > getDgDp() const
Return adjoint sensitivity stored in gradient format.
IntegratorAdjointSensitivity()
Constructor that requires a subsequent setParameterList, setStepper, and initialize calls...