Tempus
Version of the Day
Time Integration
Main Page
Related Pages
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
src
Tempus_StepperRKAppActionComposite.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_StepperRKAppActionComposite_hpp
10
#define Tempus_StepperRKAppActionComposite_hpp
11
12
#include "Tempus_config.hpp"
13
#include "
Tempus_StepperRKAppAction.hpp
"
14
#include <vector>
15
16
namespace
Tempus {
17
23
template
<
class
Scalar>
24
class
StepperRKAppActionComposite
25
:
virtual
public
Tempus::StepperRKAppAction
<Scalar>
26
{
27
public
:
28
30
StepperRKAppActionComposite
() {}
31
33
virtual
~StepperRKAppActionComposite
() {}
34
36
virtual
void
execute
(
37
Teuchos::RCP
<
SolutionHistory<Scalar>
> sh,
38
Teuchos::RCP
<
StepperRKBase<Scalar>
> stepper,
39
const
typename
StepperRKAppAction<Scalar>::ACTION_LOCATION
actLoc)
40
{
41
for
(
auto
& a :
appActions_
)
42
a->execute(sh, stepper, actLoc);
43
}
44
45
// Add AppAction to the AppAction vector.
46
void
addRKAppAction
(
Teuchos::RCP
<
StepperRKAppAction<Scalar>
> appAction)
47
{
48
appActions_
.push_back(appAction);
49
}
50
51
// Clear the AppAction vector.
52
void
clearRKAppActions
()
53
{
appActions_
.clear(); }
54
55
// Return the size of the AppAction vector.
56
std::size_t
getSize
()
const
{
return
appActions_
.size(); }
57
58
private
:
59
60
std::vector<Teuchos::RCP<StepperRKAppAction<Scalar > > >
appActions_
;
61
62
};
63
64
}
// namespace Tempus
65
#endif // Tempus_StepperRKAppActionComposite_hpp
Tempus::StepperRKAppActionComposite::StepperRKAppActionComposite
StepperRKAppActionComposite()
Default constructor.
Definition:
Tempus_StepperRKAppActionComposite.hpp:30
Tempus_StepperRKAppAction.hpp
Tempus::StepperRKAppActionComposite::getSize
std::size_t getSize() const
Definition:
Tempus_StepperRKAppActionComposite.hpp:56
Tempus::StepperRKAppActionComposite
This composite AppAction loops over added AppActions.
Definition:
Tempus_StepperRKAppActionComposite.hpp:24
Tempus::StepperRKBase
Base class for Runge-Kutta methods, ExplicitRK, DIRK and IMEX.
Definition:
Tempus_StepperRKAppAction.hpp:19
Tempus::StepperRKAppAction
Application Action for StepperRKBase.
Definition:
Tempus_StepperRKAppAction.hpp:34
Tempus::StepperRKAppActionComposite::execute
virtual 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.
Definition:
Tempus_StepperRKAppActionComposite.hpp:36
Tempus::StepperRKAppActionComposite::appActions_
std::vector< Teuchos::RCP< StepperRKAppAction< Scalar > > > appActions_
Definition:
Tempus_StepperRKAppActionComposite.hpp:60
Tempus::SolutionHistory
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
Definition:
Tempus_Integrator.hpp:25
Tempus::StepperRKAppActionComposite::~StepperRKAppActionComposite
virtual ~StepperRKAppActionComposite()
Destructor.
Definition:
Tempus_StepperRKAppActionComposite.hpp:33
Tempus::StepperRKAppAction::ACTION_LOCATION
ACTION_LOCATION
Indicates the location of application action (see algorithm).
Definition:
Tempus_StepperRKAppAction.hpp:39
Tempus::StepperRKAppActionComposite::clearRKAppActions
void clearRKAppActions()
Definition:
Tempus_StepperRKAppActionComposite.hpp:52
Teuchos::RCP
Tempus::StepperRKAppActionComposite::addRKAppAction
void addRKAppAction(Teuchos::RCP< StepperRKAppAction< Scalar > > appAction)
Definition:
Tempus_StepperRKAppActionComposite.hpp:46
Generated by
1.8.5