SpECTRE  v2024.12.16
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Modules Pages
TimeSteppers::Rk3Kennedy Class Reference

A third-order Runge-Kutta method with IMEX support. More...

#include <Rk3Kennedy.hpp>

Public Types

using options = implementation defined
 
- Public Types inherited from TimeStepper
using provided_time_stepper_interfaces = implementation defined
 
- Public Types inherited from ImexTimeStepper
using provided_time_stepper_interfaces = implementation defined
 

Public Member Functions

 Rk3Kennedy (const Rk3Kennedy &)=default
 
Rk3Kennedyoperator= (const Rk3Kennedy &)=default
 
 Rk3Kennedy (Rk3Kennedy &&)=default
 
Rk3Kennedyoperator= (Rk3Kennedy &&)=default
 
size_t order () const override
 The convergence order of the stepper. More...
 
double stable_step () const override
 Rough estimate of the maximum step size this method can take stably as a multiple of the step for Euler's method. More...
 
size_t imex_order () const override
 Convergence order of the integrator when used in IMEX mode. More...
 
size_t implicit_stage_order () const override
 
 WRAPPED_PUPable_decl_template (Rk3Kennedy)
 
 Rk3Kennedy (CkMigrateMessage *)
 
const ButcherTableaubutcher_tableau () const override
 
const ImplicitButcherTableauimplicit_butcher_tableau () const override
 
virtual size_t implicit_stage_order () const =0
 
virtual const ImplicitButcherTableauimplicit_butcher_tableau () const =0
 
- Public Member Functions inherited from TimeSteppers::RungeKutta
uint64_t number_of_substeps () const override
 Number of substeps in this TimeStepper. More...
 
uint64_t number_of_substeps_for_error () const override
 Number of substeps in this TimeStepper when providing an error measure for adaptive time-stepping. More...
 
size_t number_of_past_steps () const override
 Number of past time steps needed for multi-step method. More...
 
bool monotonic () const override
 Whether computational and temporal orderings of operations match. More...
 
TimeStepId next_time_id (const TimeStepId &current_id, const TimeDelta &time_step) const override
 The TimeStepId after the current substep. More...
 
TimeStepId next_time_id_for_error (const TimeStepId &current_id, const TimeDelta &time_step) const override
 The TimeStepId after the current substep when providing an error measure for adaptive time-stepping. More...
 
virtual const ButcherTableaubutcher_tableau () const =0
 
- Public Member Functions inherited from TimeStepper
 WRAPPED_PUPable_abstract (TimeStepper)
 
template<typename Vars >
void update_u (const gsl::not_null< Vars * > u, const TimeSteppers::History< Vars > &history, const TimeDelta &time_step) const
 Set u to the value at the end of the current substep. More...
 
template<typename Vars >
std::optional< StepperErrorEstimateupdate_u (const gsl::not_null< Vars * > u, const TimeSteppers::History< Vars > &history, const TimeDelta &time_step, const std::optional< StepperErrorTolerances > &tolerances) const
 Set u to the value at the end of the current substep; report the error measure when available. More...
 
template<typename Vars >
void clean_history (const gsl::not_null< TimeSteppers::History< Vars > * > history) const
 Remove old entries from the history. More...
 
template<typename Vars >
bool dense_update_u (const gsl::not_null< Vars * > u, const TimeSteppers::History< Vars > &history, const double time) const
 Compute the solution value at a time between steps. To evaluate at a time within a given step, call this method at the start of the step containing the time. The function returns true on success, otherwise the call should be retried after the next substep. More...
 
virtual size_t order () const =0
 The convergence order of the stepper. More...
 
virtual uint64_t number_of_substeps () const =0
 Number of substeps in this TimeStepper. More...
 
virtual uint64_t number_of_substeps_for_error () const =0
 Number of substeps in this TimeStepper when providing an error measure for adaptive time-stepping. More...
 
virtual size_t number_of_past_steps () const =0
 Number of past time steps needed for multi-step method. More...
 
virtual double stable_step () const =0
 Rough estimate of the maximum step size this method can take stably as a multiple of the step for Euler's method. More...
 
virtual bool monotonic () const =0
 Whether computational and temporal orderings of operations match. More...
 
virtual TimeStepId next_time_id (const TimeStepId &current_id, const TimeDelta &time_step) const =0
 The TimeStepId after the current substep. More...
 
virtual TimeStepId next_time_id_for_error (const TimeStepId &current_id, const TimeDelta &time_step) const =0
 The TimeStepId after the current substep when providing an error measure for adaptive time-stepping. More...
 
template<typename Vars >
bool can_change_step_size (const TimeStepId &time_id, const TimeSteppers::History< Vars > &history) const
 Whether a change in the step size is allowed before taking a step. Step sizes can never be changed on a substep. More...
 
- Public Member Functions inherited from ImexTimeStepper
 WRAPPED_PUPable_abstract (ImexTimeStepper)
 
virtual size_t imex_order () const =0
 Convergence order of the integrator when used in IMEX mode. More...
 
template<typename Vars >
void add_inhomogeneous_implicit_terms (const gsl::not_null< Vars * > u, const TimeSteppers::History< Vars > &implicit_history, const TimeDelta &time_step) const
 Add the change for the current implicit substep, Yn,inhomogeneous, to u, given a past history of the implicit derivatives. More...
 
template<typename Vars >
double implicit_weight (const TimeSteppers::History< Vars > &implicit_history, const TimeDelta &time_step) const
 The coefficient wn of the implicit derivative for the current substep. For a Runge-Kutta method, this is the coefficient on the diagonal of the Butcher tableau. More...
 

Static Public Attributes

static constexpr Options::String help
 
- Static Public Attributes inherited from TimeStepper
static constexpr bool local_time_stepping = false
 
static constexpr bool imex = false
 
- Static Public Attributes inherited from ImexTimeStepper
static constexpr bool imex = true
 

Detailed Description

A third-order Runge-Kutta method with IMEX support.

The coefficients are given as ARK3(2)4L[2]SA in .

The implicit part is stiffly accurate and L-stable.

The CFL factor/stable step size is 1.832102281377816.

Member Function Documentation

◆ butcher_tableau()

const ButcherTableau & TimeSteppers::Rk3Kennedy::butcher_tableau ( ) const
overridevirtual

◆ imex_order()

size_t TimeSteppers::Rk3Kennedy::imex_order ( ) const
overridevirtual

Convergence order of the integrator when used in IMEX mode.

Implements ImexTimeStepper.

◆ implicit_butcher_tableau()

const ImplicitButcherTableau & TimeSteppers::Rk3Kennedy::implicit_butcher_tableau ( ) const
overridevirtual

◆ implicit_stage_order()

size_t TimeSteppers::Rk3Kennedy::implicit_stage_order ( ) const
overridevirtual

Smallest order of the intermediate result at any substep. For the methods supported by this class, this cannot exceed 2.

Implements TimeSteppers::ImexRungeKutta.

◆ order()

size_t TimeSteppers::Rk3Kennedy::order ( ) const
overridevirtual

The convergence order of the stepper.

Implements TimeStepper.

◆ stable_step()

double TimeSteppers::Rk3Kennedy::stable_step ( ) const
overridevirtual

Rough estimate of the maximum step size this method can take stably as a multiple of the step for Euler's method.

Implements TimeStepper.

Member Data Documentation

◆ help

constexpr Options::String TimeSteppers::Rk3Kennedy::help
staticconstexpr
Initial value:
= {
"A 3rd-order Runge-Kutta scheme devised by Kennedy and Carpenter."}

The documentation for this class was generated from the following file: