The second-order equation can be reexpressed as a system of two first-order ODEs, A MATLAB M-file for Heun’s method with iteration can be developed as

196 -4 -3 -2 -1 1 2 3 4 2 4 6 8 10 y h = 0.1 z h = 0.1 y h = 0.2 z h = 0.2

18.9 The second-order equation can be reexpressed as a system of two first-order ODEs,

y dt dz z dt dy 9 − = = a Euler. Here are the first few steps along with the analytical solution. The remainder of the computation would be implemented in a similar fashion and the results displayed in the plot below. t y Euler z Euler dydt dzdt y analytical 0 1 0 0 -9 1 0.1 1 -0.9 -0.9 -9 0.955336 0.2 0.91 -1.8 -1.8 -8.19 0.825336 0.3 0.73 -2.619 -2.619 -6.57 0.62161 0.4 0.4681 -3.276 -3.276 -4.2129 0.362358 -5 -4 -3 -2 -1 1 2 3 4 1 2 3 4 yEuler yanal 197 b RK4. Here are the first few steps along with the analytical solution. The remainder of the computation would be implemented in a similar fashion and the results displayed in the plot below. 9 1 9 9 , 1 , , 1 , 2 2 , 1 1 1 , 1 − = − = − = = = = = y f k z f k 45 . 05 . 9 05 . 1 05 . 1 05 . − = − = = + = z y 9 1 9 45 . , 1 , 05 . 45 . 45 . , 1 , 05 . 2 2 , 2 1 1 , 2 − = − = − = − = − = f k f k 45 . 05 . 9 05 . 9775 . 05 . 45 . 1 05 . − = − = = − + = z y 7975 . 8 9775 . 9 45 . , 9775 . , 05 . 45 . 45 . , 9775 . , 05 . 2 2 , 3 1 1 , 3 − = − = − = − = − = f k f k 8798 . 1 . 7975 . 8 1 . 9550 . 1 . 45 . 1 1 . − = − = = − + = z y 5950 . 8 9550 . 9 8798 . , 9550 . , 1 . 8798 . 8798 . , 9550 . , 1 . 2 2 , 4 1 1 , 4 − = − = − = − = − = f k f k The k’s can then be used to compute the increment functions, 8650 . 8 6 5950 . 8 7975 . 8 9 2 9 4466 . 6 8798 . 45 . 45 . 2 2 1 − = − − − + − = − = − − − + = φ φ These slope estimates can then be used to make the prediction for the first step 8865 . 1 . 8650 . 8 1 . 9553 . 1 . 4466 . 1 1 . − = − = = − = z y The remaining steps can be taken in a similar fashion and the first few results summarized as 198 t y z y anal 0 1.0000 0.0000 1.00000 0.1 0.9553 -0.8865 0.95534 0.2 0.8253 -1.6938 0.82534 0.3 0.6216 -2.3498 0.62161 0.4 0.3624 -2.7960 0.36236 0.5 0.0708 -2.9924 0.07074 As can be seen, the results agree with the analytical solution closely. A plot of all the values can be developed and indicates the same close agreement. -5 -4 -3 -2 -1 1 2 3 4 1 2 3 4 yRK4 yanal

18.10 A MATLAB M-file for Heun’s method with iteration can be developed as

function [t,y] = Heundydt,tspan,y0,h,es,maxit [t,y] = Heundydt,tspan,y0,h: uses the midpoint method to integrate an ODE input: dydt = name of the M-file that evaluates the ODE tspan = [ti, tf] where ti and tf = initial and final values of independent variable y0 = initial value of dependent variable h = step size es = stopping criterion optional default = 0.001 maxit = maximum iterations of corrector optional default = 50 es = optional stopping criterion maxit = optional maximum allowable iterations output: t = vector of independent variable y = vector of solution for dependent variable if necessary, assign default values if nargin6, maxit = 50; end if maxit blank set to 50 if nargin5, es = 0.001; end if es blank set to 0.001 ti = tspan1; tf = tspan2; t = ti:h:tf; n = lengtht; if necessary, add an additional value of t 199 so that range goes from t = ti to tf if tntf tn+1 = tf; n = n+1; end y = y0onesn,1; preallocate y to improve efficiency iter = 0; for i = 1:n-1 hh = ti+1 - ti; k1 = fevaldydt,ti,yi; yi+1 = yi + k1hh; while 1 yold = yi+1; k2 = fevaldydt,ti+hh,yi+1; yi+1 = yi + k1+k22hh; iter = iter + 1; if yi+1 ~= 0, ea = absyi+1 - yoldyi+1 100; end if ea = es | iter = maxit, break, end end end plott,y Here is the test of the solution of Prob. 18.5. First, an M-file holding the differential equation is written as function dp = dpdtt, p dp = 0.0261-p12000p; Then the M-file can be invoked as in [t,p]=Heundpdt,[1950 2000],2555,5,0.1; disp[t,p] 1.0e+003 1.9500 2.5550 1.9550 2.8261 1.9600 3.1165 1.9650 3.4256 1.9700 3.7523 1.9750 4.0953 1.9800 4.4527 1.9850 4.8222 1.9900 5.2012 1.9950 5.5868 2.0000 5.9759 The following plot is generated 200

18.11 A MATLAB M-file for the midpoint method can be developed as