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"
Finding a root of f(x) = cos(x):
eps_step = 1e-5; eps_abs = 1e-5; N = 100; xp = 1.0; xc = 1.1; for i=1:N xn = (xc*cos(xp) - xp*cos(xc))/(cos(xp) - cos(xc)); if abs( xc - xn ) < eps_step && abs( cos( xn ) ) < eps_abs break; elseif i == N error( 'the secant method did not converge' ); end xp = xc; xc = xn; end xn
Of course, you can always cheat and use the built-in functions:
for i=1:N px = polyfit( [xp, xc], cos([xp, xc]), 1 ); xn = roots( px ); % there can only be one... ... end
Copyright ©2005 by Douglas Wilhelm Harder. All rights reserved.