
In
numerical analysis
Numerical analysis is the study of algorithms that use numerical approximation (as opposed to symbolic manipulations) for the problems of mathematical analysis (as distinguished from discrete mathematics). It is the study of numerical methods th ...
, a branch of
applied mathematics
Applied mathematics is the application of mathematical methods by different fields such as physics, engineering, medicine, biology, finance, business, computer science, and industry. Thus, applied mathematics is a combination of mathemat ...
, the midpoint method is a one-step method for
numerically
Numerical analysis is the study of algorithms that use numerical approximation (as opposed to symbolic manipulations) for the problems of mathematical analysis (as distinguished from discrete mathematics). It is the study of numerical methods th ...
solving the
differential equation
In mathematics, a differential equation is an equation that relates one or more unknown functions and their derivatives. In applications, the functions generally represent physical quantities, the derivatives represent their rates of change, a ...
,
:
The explicit midpoint method is given by the formula
the implicit midpoint method by
for
Here,
is the ''step size'' — a small positive number,
and
is the computed approximate value of
The explicit midpoint method is sometimes also known as the modified Euler method, the implicit method is the most simple
collocation method In mathematics, a collocation method is a method for the numerical solution of ordinary differential equations, partial differential equations and integral equations. The idea is to choose a finite-dimensional space of candidate solutions (usually ...
, and, applied to Hamiltonian dynamics, a
symplectic integrator In mathematics, a symplectic integrator (SI) is a numerical integration scheme for Hamiltonian systems. Symplectic integrators form the subclass of geometric integrators which, by definition, are canonical transformations. They are widely used in ...
. Note that the modified Euler method can refer to
Heun's method,
for further clarity see
List of Runge–Kutta methods.
The name of the method comes from the fact that in the formula above, the function
giving the slope of the solution is evaluated at
the midpoint between
at which the value of
is known and
at which the value of
needs to be found.
A geometric interpretation may give a better intuitive understanding of the method (see figure at right). In the basic
Euler's method
In mathematics and computational science, the Euler method (also called forward Euler method) is a first-order numerical procedure for solving ordinary differential equations (ODEs) with a given initial value. It is the most basic explicit m ...
, the tangent of the curve at
is computed using
. The next value
is found where the tangent intersects the vertical line
. However, if the second derivative is only positive between
and
, or only negative (as in the diagram), the curve will increasingly veer away from the tangent, leading to larger errors as
increases. The diagram illustrates that the tangent at the midpoint (upper, green line segment) would most likely give a more accurate approximation of the curve in that interval. However, this midpoint tangent could not be accurately calculated because we do not know the curve (that is what is to be calculated). Instead, this tangent is estimated by using the original Euler's method to estimate the value of
at the midpoint, then computing the slope of the tangent with
. Finally, the improved tangent is used to calculate the value of
from
. This last step is represented by the red chord in the diagram. Note that the red chord is not exactly parallel to the green segment (the true tangent), due to the error in estimating the value of
at the midpoint.
The local error at each step of the midpoint method is of order
, giving a global error of order
. Thus, while more computationally intensive than Euler's method, the midpoint method's error generally decreases faster as
.
The methods are examples of a class of higher-order methods known as
Runge–Kutta methods
In numerical analysis, the Runge–Kutta methods ( ) are a family of implicit and explicit iterative methods, which include the Euler method, used in temporal discretization for the approximate solutions of simultaneous nonlinear equations. Th ...
.
Derivation of the midpoint method

The midpoint method is a refinement of the Euler's method
:
and is derived in a similar manner.
The key to deriving Euler's method is the approximate equality
which is obtained from the slope formula
and keeping in mind that
For the midpoint methods, one replaces (3) with the more accurate
:
when instead of (2) we find
One cannot use this equation to find
as one does not know
at
. The solution is then to use a
Taylor series
In mathematics, the Taylor series or Taylor expansion of a function is an infinite sum of terms that are expressed in terms of the function's derivatives at a single point. For most common functions, the function and the sum of its Taylor se ...
expansion exactly as if using the
Euler method to solve for
:
:
which, when plugged in (4), gives us
:
and the explicit midpoint method (1e).
The implicit method (1i) is obtained by approximating the value at the half step
by the midpoint of the line segment from
to
:
and thus
:
Inserting the approximation
for
results in the implicit Runge-Kutta method
:
which contains the implicit Euler method with step size
as its first part.
Because of the time symmetry of the implicit method, all
terms of even degree in
of the local error cancel, so that the local error is automatically of order
. Replacing the implicit with the explicit Euler method in the determination of
results again in the explicit midpoint method.
See also
*
Rectangle method
In mathematics, a Riemann sum is a certain kind of approximation of an integral by a finite sum. It is named after nineteenth century German mathematician Bernhard Riemann. One very common application is approximating the area of functions or l ...
*
Heun's method
*
Leapfrog integration and
Verlet integration
Verlet integration () is a numerical method used to integrate Newton's equations of motion. It is frequently used to calculate trajectories of particles in molecular dynamics simulations and computer graphics. The algorithm was first used in 1791 ...
Notes
References
*
* .
*
{{Numerical integrators
Numerical differential equations
Runge–Kutta methods