``` function [x,y] = ab3(f, tspan, y0, n) a = tspan(1); b = tspan(2); h = (b - a) / n; x = (a : h : b); y(1) = y0; for i = 1 : 2 k_1 = h * feval(f, x(i), y(i)); k_2 = h * feval(f, x(i) + h / 2, y(i) + k_1/2); y(i+1) = y(i) + k_2; end z0 = feval(f, a, y0); z(1) = feval(f, x(1), y(1)); z(2) = feval(f, x(2), y(2)); y(3) = y(2) + h / 12 * (23 * z(2) - 16 * z(1) + 5 * z0); for i = 3 : n z(i) = feval(f, x(i), y(i)); y(i+1) = y(i) + h / 12 * (23 * z(i) - 16 * z(i-1) + 5 * z(i-2)); end ``` ``` function [t, y] = euler(f, tspan, y0, N) yy = [y0]; xx = [0]; a = tspan(1); b = tspan(2); h = (b - a) / N; for i = 2:N current_x = xx(i-1) + h; current_y = yy(i-1) + h * f(current_x, yy(i-1)); xx = [xx current_x]; yy = [yy current_y]; if current_x > 20 break; end; end t = xx; y = yy; ``` ``` function [t, y] = euler_m(f, tspan, y0, N) yy = [y0]; xx = [0]; a = tspan(1); b = tspan(2); h = (b-a)/N; for i = 2:N current_x = xx(i-1) + h; current_y = yy(i-1) + h * f(current_x, yy(i-1)); xx = [xx current_x]; yy = [yy current_y]; if current_x > 20 break; end; end t = xx; y = yy; ``` ``` syms y(x) dsolve(diff(y) == x+y, y(0) == 1) dsolve(diff(y) == x^2 - y, y(0) == 1) fn1 = @(x, y) x+y fn2 = @(x, y) x^2 * x - y * x fd1 = @(x) 2 * exp(x) - x -1 fd2 = @(x) x^2 -exp(-x) - 2 * x +x a = 0 b = 10 tspan = [0 10]; [x1a, y1a] = euler(fn1, tspan, 1, (b - a) / 0.01) [x1b, y1b] = euler(fn2, tspan, 1, (b - a) / 0.01) [x2a, y2a] = euler_m(fn1, tspan, 1, (b - a) / 0.01) [x2b, y2b] = euler_m(fn2, tspan, 1, (b - a) / 0.01) [x3a, y3a] = ab3(fn1, tspan, 1, (b-a) / 0.01) [x3b, y3b] = ab3(fn2, tspan, 1, (b-a) / 0.01) hold on plot(x1a, y1a) plot(x2a, y2a) plot(x3a, y3a) plot(x4a, y4a) hold off hold on plot(x1b, y1b) plot(x2b, y2b) plot(x3b, y3b) plot(x4b, y4b) hold off plot(x1a, y1a) err1 = abs(y4a - y1a) err2 = abs(y4a - y1a) err3 = abs(y4a - y1a) ```