data:image/s3,"s3://crabby-images/48836/488360ef9b8db417190755f5b779687091d923f8" alt="New Picture"
The similarity to the Backward Euler’s method is evident. The solution of the Trapezoidal method requires an iterative procedure at each time step to arrive at a solution for yn. A root-finding algorithm once again comes in handy for this iterative process.
A simplified algorithm for the Trapezoidal method can be:
1) % Define step size (h), initial function y(0), initial time t0, final time tf, eps
2) nosteps = (tf – t0)/h
3) for i ← 1 to nosteps
- Calculate derivative function f[t0,y[i]]
- Iterate until y[i] – (y[i-1] + 0.5*h*{ f[x(i-1), y(i-1)] + f[x(i), y(i)]}) < eps
- t0 ← t0 + h
- Iterate until y[i] – (y[i-1] + 0.5*h*{ f[x(i-1), y(i-1)] + f[x(i), y(i)]}) < eps
- t0 ← t0 + h
4) % Display results
Eq. 203(a) from J.C.Butcher, Numerical Solution of ODE’s, 2nd Edition, was solved using the Trapezoidal method. The equations for the IVP are:
data:image/s3,"s3://crabby-images/76860/76860360176cb043d42c35a821e9e0b9108e18f1" alt="New Picture (1)"
data:image/s3,"s3://crabby-images/fa701/fa70173bc96f2c008262e90c0cb23a46abe9e09f" alt="New Picture (2)"
With y1(0)=1 and y2(0)= 0. A step size of 0.005, and eps of 1E-8 were used for the solver. The plots for y1 and y2 are shown below.
data:image/s3,"s3://crabby-images/d81e7/d81e7d8f704ab30066880963ac36b3292aa1dcf0" alt="New Picture (3)"
No comments:
Post a Comment