Tempus Version of the Day
Time Integration
Loading...
Searching...
No Matches
Tempus_StepperTrapezoidalModifierBase.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_StepperTrapezoidalModifierBase_hpp
11#define Tempus_StepperTrapezoidalModifierBase_hpp
12
13#include "Tempus_config.hpp"
14#include "Tempus_SolutionHistory.hpp"
16
17namespace Tempus {
18
37template <class Scalar>
39 : virtual public Tempus::StepperTrapezoidalAppAction<Scalar> {
40 private:
41 /* \brief Adaptor execute function
42 *
43 * This is an adaptor function to bridge between the AppAction
44 * interface and the Modifier interface. It is meant to be private
45 * and non-virtual as deriving from this class should only need to
46 * implement the modify function.
47 *
48 * For the Modifier interface, this adaptor is a "simple pass through".
49 */
50 void execute(
51 Teuchos::RCP<SolutionHistory<Scalar> > sh,
52 Teuchos::RCP<StepperTrapezoidal<Scalar> > stepper,
54 actLoc)
55 {
56 this->modify(sh, stepper, actLoc);
57 }
58
59 public:
61 virtual void modify(
62 Teuchos::RCP<SolutionHistory<Scalar> > /* sh */,
63 Teuchos::RCP<StepperTrapezoidal<Scalar> > /* stepper */,
65 actLoc) = 0;
66};
67
68} // namespace Tempus
69
70#endif // Tempus_StepperTrapezoidalModifierBase_hpp
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
Application Action for StepperTrapezoidal.
ACTION_LOCATION
Indicates the location of application action (see algorithm).
virtual void modify(Teuchos::RCP< SolutionHistory< Scalar > >, Teuchos::RCP< StepperTrapezoidal< Scalar > >, const typename StepperTrapezoidalAppAction< Scalar >::ACTION_LOCATION actLoc)=0
Modify Trapezoidal Stepper.
void execute(Teuchos::RCP< SolutionHistory< Scalar > > sh, Teuchos::RCP< StepperTrapezoidal< Scalar > > stepper, const typename StepperTrapezoidalAppAction< Scalar >::ACTION_LOCATION actLoc)
Execute application action for Trapezoidal Stepper.
Trapezoidal method time stepper.