version 3.8
multistagetimestepper.hh
Go to the documentation of this file.
1// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2// vi: set et ts=4 sw=4 sts=4:
3//
4// SPDX-FileCopyrightInfo: Copyright © DuMux Project contributors, see AUTHORS.md in root folder
5// SPDX-License-Identifier: GPL-3.0-or-later
6//
12#ifndef DUMUX_TIMESTEPPING_MULTISTAGE_TIMESTEPPER_HH
13#define DUMUX_TIMESTEPPING_MULTISTAGE_TIMESTEPPER_HH
14
15#include <memory>
16#include <vector>
17#include <cmath>
18#include <iostream>
19
20#include <dumux/io/format.hh>
21
23
24namespace Dumux::Experimental {
25
27template<class Scalar>
29{
30 struct Params {
31 Scalar alpha, betaDt, timeAtStage, dtFraction;
33 };
34public:
36 MultiStageParams(const MultiStageMethod<Scalar>& m, std::size_t i, const Scalar t, const Scalar dt)
37 : size_(i+1)
38 {
39 params_.resize(size_);
40 for (std::size_t k = 0; k < size_; ++k)
41 {
42 auto& p = params_[k];
43 p.alpha = m.temporalWeight(i, k);
44 p.betaDt = m.spatialWeight(i, k)*dt;
45 p.timeAtStage = t + m.timeStepWeight(k)*dt;
46 p.dtFraction = m.timeStepWeight(k);
47
48 using std::abs;
49 p.skipTemporal = (abs(p.alpha) < 1e-6);
50 p.skipSpatial = (abs(p.betaDt) < 1e-6);
51 }
52 }
53
54 std::size_t size () const
55 { return size_; }
56
58 Scalar temporalWeight (std::size_t k) const
59 { return params_[k].alpha; }
60
62 Scalar spatialWeight (std::size_t k) const
63 { return params_[k].betaDt; }
64
66 Scalar timeAtStage (std::size_t k) const
67 { return params_[k].timeAtStage; }
68
70 Scalar timeStepFraction (std::size_t k) const
71 { return params_[k].dtFraction; }
72
74 Scalar skipTemporal (std::size_t k) const
75 { return params_[k].skipTemporal; }
76
78 Scalar skipSpatial (std::size_t k) const
79 { return params_[k].skipSpatial; }
80
81private:
82 std::size_t size_;
83 std::vector<Params> params_;
84};
85
92template<class PDESolver, class Scalar = double>
94{
95 using Variables = typename PDESolver::Variables;
97
98public:
99
106 MultiStageTimeStepper(std::shared_ptr<PDESolver> pdeSolver,
107 std::shared_ptr<const MultiStageMethod<Scalar>> msMethod)
108 : pdeSolver_(pdeSolver)
109 , msMethod_(msMethod)
110 {
111 std::cout << "Initialize time stepper with method " << msMethod_->name()
112 << Fmt::format(" ({} stage{})", msMethod_->numStages(), (msMethod_->numStages() > 1 ? "s" : ""))
113 << std::endl;
114 }
115
124 void step(Variables& vars, const Scalar t, const Scalar dt)
125 {
126 // make sure there are no traces of previous stages
127 pdeSolver_->assembler().clearStages();
128
129 for (auto stageIdx = 1UL; stageIdx <= msMethod_->numStages(); ++stageIdx)
130 {
131 // prepare the assembler for this stage
132 pdeSolver_->assembler().prepareStage(
133 vars,
134 std::make_shared<StageParams>(*msMethod_, stageIdx, t, dt)
135 );
136
137 // assemble & solve
138 pdeSolver_->solve(vars);
139 }
140
141 // clear traces of previously registered stages
142 pdeSolver_->assembler().clearStages();
143 }
144
145private:
146 std::shared_ptr<PDESolver> pdeSolver_;
147 std::shared_ptr<const MultiStageMethod<Scalar>> msMethod_;
148};
149
150} // end namespace Dumux::Experimental
151
152#endif
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
Formatting based on the fmt-library which implements std::format of C++20.
Parameters for different multistage time stepping methods.
Definition: experimental/assembly/cclocalassembler.hh:36