rkf108_class Derived Type

type, public, extends(rk_variable_step_class) :: rkf108_class

Runga-Kutta Feagin 8(10) method.


Inherits

type~~rkf108_class~~InheritsGraph type~rkf108_class rkf108_class type~rk_variable_step_class rk_variable_step_class type~rkf108_class->type~rk_variable_step_class type~stepsize_class stepsize_class type~rk_variable_step_class->type~stepsize_class stepsize_method

Type-Bound Procedures

procedure, public :: initialize

initialize the class (set n,f, and report)

  • private subroutine initialize(me, n, f, rtol, atol, stepsize_method, hinit_method, report, g)

    Initialize the rk_variable_step_class.

    Arguments

    Type IntentOptional Attributes Name
    class(rk_variable_step_class), intent(inout) :: me
    integer, intent(in) :: n

    number of equations

    procedure(deriv_func) :: f

    derivative function

    real(kind=wp), intent(in), dimension(:) :: rtol

    relative tolerance (if size=1, then same tol used for all equations)

    real(kind=wp), intent(in), dimension(:) :: atol

    absolute tolerance (if size=1, then same tol used for all equations)

    class(stepsize_class), intent(in) :: stepsize_method

    method for varying the step size

    integer, intent(in), optional :: hinit_method

    which method to use for automatic initial step size computation. 1 = use hstart, 2 = use hinit.

    procedure(report_func), optional :: report

    for reporting the steps

    procedure(event_func), optional :: g

    for stopping at an event

procedure, public :: destroy

destructor

procedure, public, non_overridable :: integrate

main integration routine

  • private subroutine integrate(me, t0, x0, h, tf, xf, ierr)

    Main integration routine for the rk_variable_step_class.

    Arguments

    Type IntentOptional Attributes Name
    class(rk_variable_step_class), intent(inout) :: me
    real(kind=wp), intent(in) :: t0

    initial time

    real(kind=wp), intent(in), dimension(:) :: x0

    initial state

    real(kind=wp), intent(in) :: h

    initial abs(time step)

    real(kind=wp), intent(in) :: tf

    final time

    real(kind=wp), intent(out), dimension(:) :: xf

    final state

    integer, intent(out), optional :: ierr

    0 = no errors, <0 = error. if not present, an error will stop program.

procedure, public, non_overridable :: integrate_to_event

integration with event finding

  • private subroutine integrate_to_event(me, t0, x0, h, tmax, tol, tf, xf, gf, ierr)

    Event-finding integration routine for the rk_variable_step_class. Integrates until g(t,x)=0, or until t=tf (whichever happens first).

    Read more…

    Arguments

    Type IntentOptional Attributes Name
    class(rk_variable_step_class), intent(inout) :: me
    real(kind=wp), intent(in) :: t0

    initial time

    real(kind=wp), intent(in), dimension(me%n) :: x0

    initial state

    real(kind=wp), intent(in) :: h

    abs(time step)

    real(kind=wp), intent(in) :: tmax

    max final time if event not located

    real(kind=wp), intent(in) :: tol

    function tolerance for root finding

    real(kind=wp), intent(out) :: tf

    actual final time reached

    real(kind=wp), intent(out), dimension(me%n) :: xf

    final state (at tf)

    real(kind=wp), intent(out) :: gf

    g value at tf

    integer, intent(out), optional :: ierr

    0 = no errors, <0 = error. if not present, an error will stop program.

procedure, public :: step => rkf108

  • private subroutine rkf108(me, t, x, h, xf, terr)

    Feagin's RK8(10) method -- a 10th-order method with an embedded 8th-order method.

    Read more…

    Arguments

    Type IntentOptional Attributes Name
    class(rkf108_class), intent(inout) :: me
    real(kind=wp), intent(in) :: t

    initial time

    real(kind=wp), intent(in), dimension(me%n) :: x

    initial state

    real(kind=wp), intent(in) :: h

    time step

    real(kind=wp), intent(out), dimension(me%n) :: xf

    state at time t+h

    real(kind=wp), intent(out), dimension(me%n) :: terr

    truncation error estimate

procedure, public :: order => rkf108_order

  • private pure function rkf108_order(me) result(p)

    Returns the order of the rkf108 method.

    Arguments

    Type IntentOptional Attributes Name
    class(rkf108_class), intent(in) :: me

    Return Value integer

    order of the method

Source Code

    type,extends(rk_variable_step_class),public :: rkf108_class
        !! Runga-Kutta Feagin 8(10) method.
        contains
        procedure :: step  => rkf108
        procedure :: order => rkf108_order
    end type rkf108_class