Misplaced Pages

Bogacki–Shampine method

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

The Bogacki–Shampine method is a method for the numerical solution of ordinary differential equations, that was proposed by Przemysław Bogacki and Lawrence F. Shampine in 1989 (Bogacki & Shampine 1989). The Bogacki–Shampine method is a Runge–Kutta method of order three with four stages with the First Same As Last (FSAL) property, so that it uses approximately three function evaluations per step. It has an embedded second-order method which can be used to implement adaptive step size. The Bogacki–Shampine method is implemented in the ode3 for fixed step solver and ode23 for a variable step solver function in MATLAB (Shampine & Reichelt 1997).

Low-order methods are more suitable than higher-order methods like the Dormand–Prince method of order five, if only a crude approximation to the solution is required. Bogacki and Shampine argue that their method outperforms other third-order methods with an embedded method of order two.

The Butcher tableau for the Bogacki–Shampine method is:

0
1/2 1/2
3/4 0 3/4
1 2/9 1/3 4/9
2/9 1/3 4/9 0
7/24 1/4 1/3 1/8

Following the standard notation, the differential equation to be solved is y = f ( t , y ) {\displaystyle y'=f(t,y)} . Furthermore, y n {\displaystyle y_{n}} denotes the numerical solution at time t n {\displaystyle t_{n}} and h n {\displaystyle h_{n}} is the step size, defined by h n = t n + 1 t n {\displaystyle h_{n}=t_{n+1}-t_{n}} . Then, one step of the Bogacki–Shampine method is given by:

k 1 = f ( t n , y n ) k 2 = f ( t n + 1 2 h n , y n + 1 2 h n k 1 ) k 3 = f ( t n + 3 4 h n , y n + 3 4 h n k 2 ) y n + 1 = y n + 2 9 h n k 1 + 1 3 h n k 2 + 4 9 h n k 3 k 4 = f ( t n + h n , y n + 1 ) z n + 1 = z n + 7 24 h n k 1 + 1 4 h n k 2 + 1 3 h n k 3 + 1 8 h n k 4 . {\displaystyle {\begin{aligned}k_{1}&=f(t_{n},y_{n})\\k_{2}&=f(t_{n}+{\tfrac {1}{2}}h_{n},y_{n}+{\tfrac {1}{2}}h_{n}k_{1})\\k_{3}&=f(t_{n}+{\tfrac {3}{4}}h_{n},y_{n}+{\tfrac {3}{4}}h_{n}k_{2})\\y_{n+1}&=y_{n}+{\tfrac {2}{9}}h_{n}k_{1}+{\tfrac {1}{3}}h_{n}k_{2}+{\tfrac {4}{9}}h_{n}k_{3}\\k_{4}&=f(t_{n}+h_{n},y_{n+1})\\z_{n+1}&=z_{n}+{\tfrac {7}{24}}h_{n}k_{1}+{\tfrac {1}{4}}h_{n}k_{2}+{\tfrac {1}{3}}h_{n}k_{3}+{\tfrac {1}{8}}h_{n}k_{4}.\end{aligned}}}

Here, z n + 1 {\displaystyle z_{n+1}} is a second-order approximation to the exact solution. The method for calculating y n + 1 {\displaystyle y_{n+1}} is due to Ralston (1965). On the other hand, y n + 1 {\displaystyle y_{n+1}} is a third-order approximation, so the difference between y n + 1 {\displaystyle y_{n+1}} and z n + 1 {\displaystyle z_{n+1}} can be used to adapt the step size. The FSAL—first same as last—property is that the stage value k 4 {\displaystyle k_{4}} in one step equals k 1 {\displaystyle k_{1}} in the next step; thus, only three function evaluations are needed per step.

References

Category: