Numerical Methods
In this chapter, I will cover different methods to integrate differential equations (ODE) numerically. Since the integrand is evaluated numerically, I will replace every \(=\) to be \(\approx\) to make it clear it's just an estimation only.
// TODO: investigate what is consistency and order in numerical methods
Euler Method
This is a first-order numerical method to solve ordinary differential equations (ODEs) with a given initial value. It allows us to approximate a nearby point on the curve by moving a short distance \(\Delta t\) along a line tangent, that is the first-order derivative \(f'(t)\), to the curve \(f(t)\). To write that down:
Rewriting it in an iterative way, we can find the next position a particle \(\mathbf{x}_{n+1}\) with its current position \(\mathbf{x}_n\):
Implicit Euler Method
The implicit here means instead of computing directly the approximation \(\mathbf{x}_{n+1}\) from \(\mathbf{x}_n\), we need to solve an implicit equation:
Also known as backward Euler method, because it uses right-hand quadrature method instead of the left-hand rectangle. Implicit method is difficult to evaluate, and usually required iterative methods to solve (e.g. fixed point iteration), but they have better numerical properties and thus more stable.
Symplectic Euler Method
This one has way too much names, it's also called semi-implicit Euler, semi-explicit Euler, Euler-Cromer, and Newton-Størmer-Verlet1.
Rewrite it in terms of motion:
Look familiar? This is usually seen in game physics to predict a moving body in the next time frame. It is a mix of explicit and implicit method to calculate the final body position. Velocity is integrated explicitly, and position is integrated implicitly by using the velocity from the next time frame.
Verlet Method2
This is a second-order numerical method to integrate Newton's equations of motion.
We begin by letting the second-derivative \(\ddot{\mathbf{x}}=f''(t)\) be the change of the finite difference of the backward-difference and forward-difference. In other words, using central difference approximation to find the second derivative. When \(\Delta t\rightarrow 0\), it will converge to the true second-derivative value. In numerical computations, it will always be an approximation as it's impossible to have an infinitely small step size.
It has an interesting property, we can see the approximated second-derivative is independent from its first-derivative. In simpler words, the next position vector \(\mathbf{x}_{n+1}\) can be obtained directly by the previous two \(\mathbf{x}_n\) and \(\mathbf{x}_{n-1}\), without the need of calculating velocity. Continue from \((1)\), we get:
Computing Velocity
Because velocities are not explicitly given by definition, it can only be estimated by the mean value theorem.
To erase the dependency or previous position, just shift the time frame by \(\Delta t\) at the cost of accuracy (forward-difference approximation). And you will soon notice it falls back to the form of Euler method.
-
F.Crivelli. The Störmer-Verlet method, 2008. https://www2.math.ethz.ch/education/bachelor/seminars/fs2008/nas/crivelli.pdf ↩
-
Gorilla Sun. Euler and Verlet Integration for Particle Physics. https://www.gorillasun.de/blog/euler-and-verlet-integration-for-particle-physics/ ↩