data:image/s3,"s3://crabby-images/1754e/1754e6a66bce8ca0708c3f63a6cb7236c71d91b9" alt="Contents"
data:image/s3,"s3://crabby-images/5204b/5204bfbbe0be33f597909a8c1340c27e70b52983" alt="Previous Chapter"
data:image/s3,"s3://crabby-images/66339/6633958291336c0c485aaf56bd3b15b51139affd" alt="Start of Chapter"
data:image/s3,"s3://crabby-images/0a9ce/0a9cedc45b7b4c383493d3741b2a280cb0220f33" alt="Previous Topic"
data:image/s3,"s3://crabby-images/ec9ec/ec9eca5fa8dc8f1a0579324ba8fe2bd77ebd558d" alt="Next Topic"
data:image/s3,"s3://crabby-images/f6794/f6794bdc1a1b1f6bc681d954a0d2c15baf170fd3" alt="Next Chapter"
Approximate the integral of f(x) = cos(x) until εstep < 1e-10 or N = 10.
Please note, because we cannot begin at R(0, 0), each index will be off by one. This is not optimal code, either.
format long eps_step = 1e-10; N = 10; R = zeros( N + 1, N + 1 ); a = 0; b = 10; h = b - a; R(0 + 1, 0 + 1) = 0.5*(cos(a) + cos(b))*h; for i = 1:N h = h/2; % This calculates the trapezoidal rule with intervals of width h R( i + 1, 1 ) = 0.5*(cos(a) + 2*sum( cos( (a + h):h:(b - h) ) ) + cos(b))*h; for j = 1:i R(i + 1, j + 1) = (4^j*R(i + 1, j) - R(i, j))/(4^j - 1); end if abs( R(i + 1, i + 1) - R(i, i) ) < eps_step break; elseif i == N + 1 error( 'Romberg integration did not converge' ); end end R( i + 1, i + 1 )
The correct answer to 20 decimal digits is sin(10) = -0.54402111088936981340.
Copyright ©2005 by Douglas Wilhelm Harder. All rights reserved.