Solution Methods for IVPs: The Midpoint Method
The Midpoint Method
Similar to Heun’s method, the midpoint method provides a slight modification to both the implicit and explicit Euler methods. Consider the following IVP:
Assuming that the value of the dependent variable
data:image/s3,"s3://crabby-images/a5d6b/a5d6b20610ac0fbf0bd801dbec04e1fb2688f2f5" alt="Rendered by QuickLaTeX.com x"
data:image/s3,"s3://crabby-images/46eb9/46eb9e0c4fdfb0cf3b042063c6b8055d5cf04857" alt="Rendered by QuickLaTeX.com x_i"
data:image/s3,"s3://crabby-images/345b0/345b0317a6bdce971de1a8ee80420bde7827f8b1" alt="Rendered by QuickLaTeX.com t_i"
Therefore:
If the midpoint rule of the rectangle method of numerical integration is used for the right-hand side with one interval we obtain:
where the error term is inherited from the use of
data:image/s3,"s3://crabby-images/e2732/e27328e987c6e6b405c334e2e96cb1c26f65a35d" alt="Rendered by QuickLaTeX.com I_2"
data:image/s3,"s3://crabby-images/0d1ca/0d1caa11432e70be8ef3e1845926b26b0a4429d5" alt="Rendered by QuickLaTeX.com x_{i+1}"
Using this estimate, the local truncation error is thus proportional to the cube of the step size. If the errors from each interval are added together, with
data:image/s3,"s3://crabby-images/55062/55062856cb21095690fb855cff035b1eae0a0c82" alt="Rendered by QuickLaTeX.com n=\frac{L}{h}"
data:image/s3,"s3://crabby-images/7936f/7936f367abdde19bbbab4ec216e2c52daab735d3" alt="Rendered by QuickLaTeX.com L"
data:image/s3,"s3://crabby-images/f7d4d/f7d4d89994d18f545ab02b0414b2191e27a60e96" alt="Rendered by QuickLaTeX.com t_n-t_0"
which is similar to Heun’s method but better than both the implicit and explicit Euler methods. Note that the midpoint method is essentially a slight modification to the Euler’s method in which the slope used to calculate the value of
data:image/s3,"s3://crabby-images/0d1ca/0d1caa11432e70be8ef3e1845926b26b0a4429d5" alt="Rendered by QuickLaTeX.com x_{i+1}"
data:image/s3,"s3://crabby-images/9badf/9badfa02dc129de9e630c4c8f6f52c11a41f0b23" alt="Rendered by QuickLaTeX.com x_{i+1/2}=\frac{x_{i+1}+x_i}{2}"
data:image/s3,"s3://crabby-images/46eb9/46eb9e0c4fdfb0cf3b042063c6b8055d5cf04857" alt="Rendered by QuickLaTeX.com x_i"
data:image/s3,"s3://crabby-images/0d3c7/0d3c7d51f0ab32cd428178d54378a14f9d54aa4e" alt="Rendered by QuickLaTeX.com x_{i+1/2}^{(0)}"
data:image/s3,"s3://crabby-images/0d1ca/0d1caa11432e70be8ef3e1845926b26b0a4429d5" alt="Rendered by QuickLaTeX.com x_{i+1}"
data:image/s3,"s3://crabby-images/0d3c7/0d3c7d51f0ab32cd428178d54378a14f9d54aa4e" alt="Rendered by QuickLaTeX.com x_{i+1/2}^{(0)}"
data:image/s3,"s3://crabby-images/0d1ca/0d1caa11432e70be8ef3e1845926b26b0a4429d5" alt="Rendered by QuickLaTeX.com x_{i+1}"
data:image/s3,"s3://crabby-images/0d1ca/0d1caa11432e70be8ef3e1845926b26b0a4429d5" alt="Rendered by QuickLaTeX.com x_{i+1}"
MidPointMethod[fp_, x0_, h_, t0_, tmax_] := (n = (tmax - t0)/h + 1; xtable = Table[0, {i, 1, n}]; xtable[[1]] = x0; Do[xi120 = xtable[[i - 1]] + h/2*fp[xtable[[i - 1]], t0 + (i - 2) h]; xtable[[i]] = xtable[[i - 1]] + h (fp[xi120, t0 + (i - 1-1/2) h]), {i, 2, n}]; Data = Table[{t0 + (i - 1)*h, xtable[[i]]}, {i, 1, n}]; Data)
View Python Code
def MidPointMethod(fp, x0, h, t0, tmax): n = int((tmax - t0)/h + 1) xtable = [0 for i in range(n)] xtable[0] = x0 for i in range(1,n): xi120 = xtable[i - 1] + h/2*fp(xtable[i - 1], t0 + (i - 1)*h) xtable[i] = xtable[i - 1] + h*(fp(xi120, t0 + (i - 1/2)*h)) Data = [[t0 + i*h, xtable[i]] for i in range(n)] return Data
Example
Solve Example 4 above using the midpoint method.
Solution
The midpoint method is implemented by first assuming an estimate for based on the explicit Euler method:
Then, the estimate for
data:image/s3,"s3://crabby-images/0d1ca/0d1caa11432e70be8ef3e1845926b26b0a4429d5" alt="Rendered by QuickLaTeX.com x_{i+1}"
Setting
data:image/s3,"s3://crabby-images/fab65/fab6508eb5e68d705104468607bb4a8c6dd1ab7d" alt="Rendered by QuickLaTeX.com x_0=-5"
data:image/s3,"s3://crabby-images/f72b5/f72b50f928640f10cc0614265ddfd410bc79e7fd" alt="Rendered by QuickLaTeX.com t_0=0"
data:image/s3,"s3://crabby-images/a20de/a20de59aa0de515bf22c2df90cd287b0843214ea" alt="Rendered by QuickLaTeX.com t_1=0.1"
data:image/s3,"s3://crabby-images/8fedc/8fedc553a6a842eba23d27c38b9daed64ed2ab2c" alt="Rendered by QuickLaTeX.com h=0.1"
data:image/s3,"s3://crabby-images/4f34f/4f34f46c2a83f652a7fb8360880bdea97dae2846" alt="Rendered by QuickLaTeX.com x_{0.5}^{(0)}"
Using this information, the slope at
data:image/s3,"s3://crabby-images/4f34f/4f34f46c2a83f652a7fb8360880bdea97dae2846" alt="Rendered by QuickLaTeX.com x_{0.5}^{(0)}"
data:image/s3,"s3://crabby-images/703f7/703f7d472038b44e04ed6f63a6274bba92dea6b3" alt="Rendered by QuickLaTeX.com x_1"
Similarly, an initial estimate for
data:image/s3,"s3://crabby-images/3ab4d/3ab4d96ce76f059cff726f3f93ccd1e501dd8c4a" alt="Rendered by QuickLaTeX.com x_{1.5}^{(0)}"
Using this information, the slope at
data:image/s3,"s3://crabby-images/3ab4d/3ab4d96ce76f059cff726f3f93ccd1e501dd8c4a" alt="Rendered by QuickLaTeX.com x_{1.5}^{(0)}"
data:image/s3,"s3://crabby-images/21e1d/21e1d07385ca9b0271a9af98153f4ebb91952bfb" alt="Rendered by QuickLaTeX.com x_2"
Proceeding iteratively gives the values of up to
. The Microsoft Excel file MidPoint.xlsx provides the required calculations.
The following graph shows the produced numerical data (black dots) overlapping the exact solution (blue line). The Mathematica code is given below.
MidPointMethod[fp_, x0_, h_, t0_, tmax_] := (n = (tmax - t0)/h + 1; xtable = Table[0, {i, 1, n}]; xtable[[1]] = x0; Do[xi120 = xtable[[i - 1]] + h/2*fp[xtable[[i - 1]], t0 + (i - 2) h]; xtable[[i]] = xtable[[i - 1]] + h (fp[xi120, t0 + (i - 1 - 1/2) h]), {i, 2, n}]; Data2 = Table[{t0 + (i - 1)*h, xtable[[i]]}, {i, 1, n}]; Data2) Clear[x, xtable] a = DSolve[{x'[t] == t*x[t]^2 + 2*x[t], x[0] == -5}, x, t]; x = x[t] /. a[[1]] fp[x_, t_] := t*x^2 + 2*x; Data2 = MidPointMethod[fp, -5.0, 0.1, 0, 5]; Plot[x, {t, 0, 5}, Epilog -> {PointSize[Large], Point[Data2]}, AxesOrigin -> {0, 0}, AxesLabel -> {"t", "x"}, PlotRange -> All] Title = {"t_i", "x_i"}; Data2 = Prepend[Data2, Title]; Data2 // MatrixForm
View Python Code
# UPGRADE: need Sympy 1.2 or later, upgrade by running: "!pip install sympy --upgrade" in a code cell # !pip install sympy --upgrade import numpy as np import sympy as sp import matplotlib.pyplot as plt sp.init_printing(use_latex=True) def MidPointMethod(fp, x0, h, t0, tmax): n = int((tmax - t0)/h + 1) xtable = [0 for i in range(n)] xtable[0] = x0 for i in range(1,n): xi120 = xtable[i - 1] + h/2*fp(xtable[i - 1], t0 + (i - 1)*h) xtable[i] = xtable[i - 1] + h*(fp(xi120, t0 + (i - 1/2)*h)) Data = [[t0 + i*h, xtable[i]] for i in range(n)] return Data x = sp.Function('x') t = sp.symbols('t') sol = sp.dsolve(x(t).diff(t) - t*x(t)**2 - 2*x(t), ics={x(0): -5}) display(sol) def fp(x, t): return t*x**2 + 2*x Data = MidPointMethod(fp, -5.0, 0.1, 0, 5) x_val = np.arange(0,5,0.01) plt.plot(x_val, [sol.subs(t, i).rhs for i in x_val]) plt.scatter([point[0] for point in Data],[point[1] for point in Data],c='k') plt.xlabel("t"); plt.ylabel("x") plt.grid(); plt.show() print(["t_i", "x_i"],"\n",np.vstack(Data))
The following tool provides a comparison between the explicit Euler method and the midpoint method. The midpoint method behaves very similar to Heun’s method. Notice that around , the function
varies highly in comparison to the rest of the domain. The biggest difference between midpoint method and the Euler method can be seen when
around this area. The midpoint method is able to trace the curve while the Euler method has higher deviations.
Lecture Video
The following lecture video covers both Heun and the Midpoint Method