foodie_integrator_multistage_object Module

module~~foodie_integrator_multistage_object~~UsesGraph module~foodie_integrator_multistage_object foodie_integrator_multistage_object module~foodie_integrator_object foodie_integrator_object module~foodie_integrator_object->module~foodie_integrator_multistage_object penf penf penf->module~foodie_integrator_multistage_object penf->module~foodie_integrator_object module~foodie_integrand_object foodie_integrand_object penf->module~foodie_integrand_object iso_fortran_env iso_fortran_env iso_fortran_env->module~foodie_integrator_multistage_object iso_fortran_env->module~foodie_integrator_object module~foodie_integrand_object->module~foodie_integrator_multistage_object
Help

Define the abstract type integrator_multistage_object of FOODIE ODE integrators.

Used By

module~~foodie_integrator_multistage_object~~UsedByGraph module~foodie_integrator_multistage_object foodie_integrator_multistage_object module~foodie_integrator_runge_kutta_ssp foodie_integrator_runge_kutta_ssp module~foodie_integrator_multistage_object->module~foodie_integrator_runge_kutta_ssp module~foodie_integrator_euler_explicit foodie_integrator_euler_explicit module~foodie_integrator_multistage_object->module~foodie_integrator_euler_explicit module~foodie_integrator_runge_kutta_emd foodie_integrator_runge_kutta_emd module~foodie_integrator_multistage_object->module~foodie_integrator_runge_kutta_emd module~foodie foodie module~foodie_integrator_multistage_object->module~foodie module~foodie_integrator_runge_kutta_low_storage foodie_integrator_runge_kutta_low_storage module~foodie_integrator_multistage_object->module~foodie_integrator_runge_kutta_low_storage module~foodie_integrator_runge_kutta_lssp foodie_integrator_runge_kutta_lssp module~foodie_integrator_multistage_object->module~foodie_integrator_runge_kutta_lssp module~foodie_integrator_runge_kutta_ssp->module~foodie module~foodie_integrator_euler_explicit->module~foodie module~foodie_integrator_runge_kutta_emd->module~foodie program~integrate_burgers integrate_burgers module~foodie->program~integrate_burgers program~integrate_lorenz integrate_lorenz module~foodie->program~integrate_lorenz module~type_euler_1d type_euler_1D module~foodie->module~type_euler_1d module~foodie_test_integrand_tester_object foodie_test_integrand_tester_object module~foodie->module~foodie_test_integrand_tester_object module~foodie_test_lcce_test foodie_test_lcce_test module~foodie->module~foodie_test_lcce_test module~type_euler_1d_openmp type_euler_1D_openmp module~foodie->module~type_euler_1d_openmp program~integrate_euler_1d_caf~2 integrate_euler_1D_caf module~foodie->program~integrate_euler_1d_caf~2 module~foodie_test_oscillation_test foodie_test_oscillation_test module~foodie->module~foodie_test_oscillation_test program~integrate_euler_1d integrate_euler_1D module~foodie->program~integrate_euler_1d module~foodie_test_object foodie_test_object module~foodie->module~foodie_test_object module~foodie_test_integrand_oscillation foodie_test_integrand_oscillation module~foodie->module~foodie_test_integrand_oscillation module~foodie_test_integrand_lcce foodie_test_integrand_lcce module~foodie->module~foodie_test_integrand_lcce module~type_euler_1d_caf type_euler_1D_caf module~foodie->module~type_euler_1d_caf module~type_burgers type_burgers module~foodie->module~type_burgers module~foodie_test_integrand_ladvection foodie_test_integrand_ladvection module~foodie->module~foodie_test_integrand_ladvection program~integrate_euler_1d_openmp integrate_euler_1D_openmp module~foodie->program~integrate_euler_1d_openmp module~type_lorenz type_lorenz module~foodie->module~type_lorenz module~foodie_integrator_runge_kutta_low_storage->module~foodie module~foodie_integrator_runge_kutta_lssp->module~foodie module~type_euler_1d->program~integrate_euler_1d module~foodie_test_integrand_tester_object->module~foodie_test_object module~foodie_test_integrand_tester_object->module~foodie_test_integrand_oscillation module~foodie_test_integrand_tester_object->module~foodie_test_integrand_lcce module~foodie_test_integrand_tester_object->module~foodie_test_integrand_ladvection program~foodie_test_lcce foodie_test_lcce module~foodie_test_lcce_test->program~foodie_test_lcce module~type_euler_1d_openmp->program~integrate_euler_1d_openmp program~foodie_test_oscillation foodie_test_oscillation module~foodie_test_oscillation_test->program~foodie_test_oscillation program~foodie_tester foodie_tester module~foodie_test_object->program~foodie_tester module~foodie_test_integrand_oscillation->module~foodie_test_oscillation_test module~foodie_test_integrand_oscillation->module~foodie_test_object module~foodie_test_integrand_lcce->module~foodie_test_lcce_test module~foodie_test_integrand_lcce->module~foodie_test_object module~type_euler_1d_caf->program~integrate_euler_1d_caf~2 module~type_burgers->program~integrate_burgers module~foodie_test_integrand_ladvection->module~foodie_test_object module~type_lorenz->program~integrate_lorenz
Help


Abstract Interfaces

abstract interface

Abstract interfaces of deferred methods of integrator_multistage_object.

  • private subroutine integrate_fast_interface(self, U, Dt, t, new_Dt)

    Integrate integrand field, fast mode.

    Arguments

    Type IntentOptional AttributesName
    class(integrator_multistage_object), intent(inout) :: self

    Integrator.

    class(integrand_object), intent(inout) :: U

    Field to be integrated.

    real(kind=R_P), intent(in) :: Dt

    Time step.

    real(kind=R_P), intent(in) :: t

    Time.

    real(kind=R_P), intent(out), optional :: new_Dt

    New adapted time step.

abstract interface

Abstract interfaces of deferred methods of integrator_multistage_object.

  • private subroutine integrate_interface(self, U, Dt, t, new_Dt)

    Integrate integrand field.

    Arguments

    Type IntentOptional AttributesName
    class(integrator_multistage_object), intent(inout) :: self

    Integrator.

    class(integrand_object), intent(inout) :: U

    Integrand.

    real(kind=R_P), intent(in) :: Dt

    Time step.

    real(kind=R_P), intent(in) :: t

    Time.

    real(kind=R_P), intent(out), optional :: new_Dt

    New adapted time step.


Derived Types

type, public, abstract, extends(integrator_object) :: integrator_multistage_object

Abstract type of FOODIE ODE integrators of the multistage family.

Components

TypeVisibility AttributesNameInitial
class(integrand_object), public, allocatable:: buffer

Buffer used for fast integration.

character(len=:), public, allocatable:: description_

Informative description of the integrator.

integer(kind=I_P), public :: error =0

Error status code.

character(len=:), public, allocatable:: error_message

Error message, hopefully meaningful.

integer(kind=I_P), public :: registers

Number of registers used for stages.

class(integrand_object), public, allocatable:: stage(:)

Stages.

integer(kind=I_P), public :: stages

Number of stages.

Type-Bound Procedures

procedure, public, pass(self) :: allocate_integrand_members

Allocate integrand members.

procedure, public, pass(lhs) :: assign_abstract

Assign ony members of abstract integrator_object type.

procedure, public, pass(lhs) :: assign_multistage

Assign members of integrator_multistage_object and parents.

generic, public :: assignment(=) => integr_assign_integr

Overload =.

procedure, public, pass(self) :: check_error

Check for error occurrencies.

procedure(class_name_interface), public, pass(self) :: class_name

Return the class name of schemes.

procedure, public, pass(self) :: description

Return informative integrator description.

procedure, public, pass(self) :: destroy_abstract

Destroy only members of abstract integrator_object type.

procedure, public, pass(self) :: destroy_multistage

Destroy the integrator.

procedure(has_fast_mode_interface), public, pass(self) :: has_fast_mode

Return .true. if the integrator class has fast mode integrate.

procedure(assignment_interface), public, pass(lhs) :: integr_assign_integr

Operator =.

procedure(integrate_interface), public, pass(self) :: integrate

Integrate integrand field.

procedure(integrate_fast_interface), public, pass(self) :: integrate_fast

Integrate integrand field, fast mode.

procedure, public, pass(self) :: is_multistage

Return .true. for multistage integrator.

procedure, public, pass(self) :: is_multistep

Return .true. for multistep integrator.

procedure(is_supported_interface), public, pass(self) :: is_supported

Return .true. if the integrator class support the given scheme.

procedure, public, pass(self) :: stages_number

Return number of stages used.

procedure, public, pass(self) :: steps_number

Return number of steps used.

procedure(supported_schemes_interface), public, pass(self) :: supported_schemes

Return the list of supported schemes.

procedure, public, pass(self) :: trigger_error

Trigger an error.


Functions

private elemental function is_multistage(self)

Return .true. for multistage integrator.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(in) :: self

Integrator.

Return Value logical

Inquire result.

private elemental function is_multistep(self)

Return .true. for multistage integrator.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(in) :: self

Integrator.

Return Value logical

Inquire result.

private elemental function stages_number(self)

Return number of stages used.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(in) :: self

Integrator.

Return Value integer(kind=I_P)

Number of stages used.

private elemental function steps_number(self)

Return number of steps used.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(in) :: self

Integrator.

Return Value integer(kind=I_P)

Number of steps used.


Subroutines

private subroutine allocate_integrand_members(self, U)

Allocate members of interpolator being of integrand_object class.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(inout) :: self

Integrator.

class(integrand_object), intent(in) :: U

Integrand.

private subroutine assign_multistage(lhs, rhs)

Assign members of integrator_multistage_object and parents.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(inout) :: lhs

Left hand side.

class(integrator_object), intent(in) :: rhs

Right hand side.

private elemental subroutine destroy_multistage(self)

Destroy the integrator.

Arguments

Type IntentOptional AttributesName
class(integrator_multistage_object), intent(inout) :: self

Integrator.