12#ifndef DUMUX_TIMESTEPPING_MULTISTAGE_TIMESTEPPER_HH
13#define DUMUX_TIMESTEPPING_MULTISTAGE_TIMESTEPPER_HH
39 params_.resize(size_);
40 for (std::size_t k = 0; k < size_; ++k)
49 p.skipTemporal = (abs(p.alpha) < 1e-6);
50 p.skipSpatial = (abs(p.betaDt) < 1e-6);
59 {
return params_[k].alpha; }
63 {
return params_[k].betaDt; }
67 {
return params_[k].timeAtStage; }
71 {
return params_[k].dtFraction; }
75 {
return params_[k].skipTemporal; }
79 {
return params_[k].skipSpatial; }
83 std::vector<Params> params_;
92template<
class PDESolver,
class Scalar =
double>
108 : pdeSolver_(pdeSolver)
109 , msMethod_(msMethod)
111 std::cout <<
"Initialize time stepper with method " << msMethod_->name()
112 << Fmt::format(
" ({} stage{})", msMethod_->numStages(), (msMethod_->numStages() > 1 ?
"s" :
""))
124 void step(Variables& vars,
const Scalar t,
const Scalar dt)
127 pdeSolver_->assembler().clearStages();
129 for (
auto stageIdx = 1UL; stageIdx <= msMethod_->numStages(); ++stageIdx)
132 pdeSolver_->assembler().prepareStage(
134 std::make_shared<StageParams>(*msMethod_, stageIdx, t, dt)
138 pdeSolver_->solve(vars);
142 pdeSolver_->assembler().clearStages();
146 std::shared_ptr<PDESolver> pdeSolver_;
147 std::shared_ptr<const MultiStageMethod<Scalar>> msMethod_;
Abstract interface for one-step multi-stage method parameters in Shu/Osher form.
Definition: multistagemethods.hh:75
virtual Scalar timeStepWeight(std::size_t k) const =0
time step weights for each stage ( )
virtual Scalar temporalWeight(std::size_t i, std::size_t k) const =0
weights of the temporal operator residual ( )
virtual Scalar spatialWeight(std::size_t i, std::size_t k) const =0
weights of the spatial operator residual ( )
Data object for the parameters of a given stage.
Definition: multistagetimestepper.hh:29
Scalar timeAtStage(std::size_t k) const
the time at which we have to evaluate the operators
Definition: multistagetimestepper.hh:66
Scalar spatialWeight(std::size_t k) const
weights of the spatial operator residual ( )
Definition: multistagetimestepper.hh:62
Scalar timeStepFraction(std::size_t k) const
the fraction of a time step corresponding to the k-th stage
Definition: multistagetimestepper.hh:70
Scalar skipTemporal(std::size_t k) const
If .
Definition: multistagetimestepper.hh:74
std::size_t size() const
Definition: multistagetimestepper.hh:54
Scalar skipSpatial(std::size_t k) const
If .
Definition: multistagetimestepper.hh:78
Scalar temporalWeight(std::size_t k) const
weights of the temporal operator residual ( )
Definition: multistagetimestepper.hh:58
MultiStageParams(const MultiStageMethod< Scalar > &m, std::size_t i, const Scalar t, const Scalar dt)
Extract params for stage i from method m.
Definition: multistagetimestepper.hh:36
Time stepping with a multi-stage method.
Definition: multistagetimestepper.hh:94
MultiStageTimeStepper(std::shared_ptr< PDESolver > pdeSolver, std::shared_ptr< const MultiStageMethod< Scalar > > msMethod)
The constructor.
Definition: multistagetimestepper.hh:106
void step(Variables &vars, const Scalar t, const Scalar dt)
Advance one time step of the given time loop.
Definition: multistagetimestepper.hh:124
Detail::PDESolver::AssemblerVariables< Assembler > Variables
export the type of variables that represent a numerical solution
Definition: common/pdesolver.hh:71
Parameters for different multistage time stepping methods.
Definition: experimental/assembly/cclocalassembler.hh:36