Tempus  Version of the Day
Time Integration
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Tempus_StepperRKModifierBase.hpp
Go to the documentation of this file.
1 //@HEADER
2 // *****************************************************************************
3 // Tempus: Time Integration and Sensitivity Analysis Package
4 //
5 // Copyright 2017 NTESS and the Tempus contributors.
6 // SPDX-License-Identifier: BSD-3-Clause
7 // *****************************************************************************
8 //@HEADER
9 
10 #ifndef Tempus_StepperRKModifierBase_hpp
11 #define Tempus_StepperRKModifierBase_hpp
12 
13 #include "Tempus_config.hpp"
14 #include "Tempus_SolutionHistory.hpp"
16 
17 namespace Tempus {
18 
19 // Forward Declaration
20 template <class Scalar>
21 class StepperRKBase;
22 
40 template <class Scalar>
42  : virtual public Tempus::StepperRKAppAction<Scalar> {
43  private:
44  /* \brief Adaptor execute function
45  *
46  * This is an adaptor function to bridge between the AppAction
47  * interface and the Modifier interface. It is meant to be private
48  * and non-virtual as deriving from this class should only need to
49  * implement the modify function.
50  *
51  * For the Modifier interface, this adaptor is a "simple pass through".
52  */
53  void execute(
56  const typename StepperRKAppAction<Scalar>::ACTION_LOCATION actLoc)
57  {
58  this->modify(sh, stepper, actLoc);
59  }
60 
61  public:
63  virtual void modify(
65  Teuchos::RCP<StepperRKBase<Scalar> > /* stepper */,
66  const typename StepperRKAppAction<Scalar>::ACTION_LOCATION actLoc) = 0;
67 };
68 
69 } // namespace Tempus
70 
71 #endif // Tempus_StepperRKModifierBase_hpp
Base class for Runge-Kutta methods, ExplicitRK, DIRK and IMEX.
Application Action for StepperRKBase.
virtual void modify(Teuchos::RCP< SolutionHistory< Scalar > >, Teuchos::RCP< StepperRKBase< Scalar > >, const typename StepperRKAppAction< Scalar >::ACTION_LOCATION actLoc)=0
Modify RK Stepper.
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
void execute(Teuchos::RCP< SolutionHistory< Scalar > > sh, Teuchos::RCP< StepperRKBase< Scalar > > stepper, const typename StepperRKAppAction< Scalar >::ACTION_LOCATION actLoc)
Execute application action for RK Stepper.
ACTION_LOCATION
Indicates the location of application action (see algorithm).