"DoubleStep" Method for NDSolve


The method "DoubleStep" performs a single application of Richardson's extrapolation for any one-step integration method.

Although it is not always optimal, it is a general scheme for equipping a method with an error estimate (hence adaptivity in the step size) and extrapolating to increase the order of local accuracy.

"DoubleStep" is a special case of extrapolation but has been implemented as a separate method for efficiency.

Given a method of order :


Load some package with example problems and utility functions:
Click for copyable input
Select a nonstiff problem from the package:
Click for copyable input
Select a stiff problem from the package:
Click for copyable input

Extending Built-in Methods

The method "ExplicitEuler" carries out one integration step using Euler's method. It has no local error control and hence uses fixed step sizes.

This integrates a differential system using one application of Richardson's extrapolation (see (1)) with the base method "ExplicitEuler".
The local error estimate (2) is used to dynamically adjust the step size throughout the integration:
Click for copyable input
This illustrates how the step size varies during the numerical integration:
Click for copyable input
The stiffness detection device (described within "StiffnessTest Method Option for NDSolve") ascertains that the "ExplicitEuler" method is restricted by stability rather than local accuracy:
Click for copyable input
An alternative base method is more appropriate for this problem:
Click for copyable input

User-Defined Methods and Method Properties

Integration methods can be added to the NDSolve framework.

In order for these to work like built-in methods it can be necessary to specify various method properties. These properties can then be used by other methods to build up compound integrators.

Here is how to define a top-level plug-in for the classical RungeKutta method (see "NDSolve Method Plug-in Framework: Classical RungeKutta" and "ExplicitRungeKutta Method for NDSolve" for more details):
Click for copyable input

Method properties used by "DoubleStep" are now described.

Order and Symmetry

This attempts to integrate a system using one application of Richardson's extrapolation based on the classical RungeKutta method:
Click for copyable input

Without knowing the order of the base method, "DoubleStep" is unable to carry out Richardson's extrapolation.

This defines a method property to communicate to the framework that the classical RungeKutta method has order four:
Click for copyable input
The method "DoubleStep" is now able to ascertain that ClassicalRungeKutta is of order four and can use this information when refining the solution and estimating the local error:
Click for copyable input

The order of the result of Richardson's extrapolation depends on whether the extrapolated method has a local error expansion in powers of or (the latter occurs if the base method is symmetric).

If no method property for symmetry is defined, the "DoubleStep" method assumes by default that the base integrator is not symmetric.

This explicitly specifies that the classical RungeKutta method is not symmetric using the "SymmetricMethodQ" property:
Click for copyable input

Stiffness Detection

Details of the scheme used for stiffness detection can be found within "StiffnessTest Method Option for NDSolve".

Stiffness detection relies on knowledge of the linear stability boundary of the method, which has not been defined.

Computing the exact linear stability boundary of a method under extrapolation can be quite complicated. Therefore a default value is selected which works for all methods. This corresponds to considering the p order power series approximation to the exponential at 0 and ignoring higher order terms.

Higher Order

The following example extrapolates the classical RungeKutta method of order four using two applications of (3).

The inner specification of "DoubleStep" constructs a method of order five.

A second application of "DoubleStep" is used to obtain a method of order six, which uses adaptive step sizes.

Nested applications of "DoubleStep" are used to raise the order and provide an adaptive step-size estimate:
Click for copyable input

In general the method "Extrapolation" is more appropriate for constructing high-order integration schemes from low-order methods.

Option Summary

option name
default value
"LocalExtrapolation"Truespecify whether to advance the solution using local extrapolation according to (4)
MethodNonespecify the method to use as the base integration scheme
"StepSizeRatioBounds"{,4}specify the bounds on a relative change in the new step size hn+1 from the current step size hn as low hn+1/hn high
"StepSizeSafetyFactors"Automaticspecify the safety factors to incorporate into the error estimate (5) used for adaptive step sizes
"StiffnessTest"Automaticspecify whether to use the stiffness detection capability

Options of the method "DoubleStep".

The default setting of Automatic for the option "StiffnessTest" indicates that the stiffness test is activated if a nonstiff base method is used.

The default setting of Automatic for the option "StepSizeSafetyFactors" uses the values {9/10,4/5} for a stiff base method and {9/10,13/20} for a nonstiff base method.