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"
Implementing Müller's method in Matlab is not that difficult:
eps_step = 1e-5; eps_abs = 1e-5; p = [1 2 3 4 2]; x = [0 -0.1 -0.2]'; y = polyval( p, x ); while ( true ) V = vander( x - x(2) ); c = V \ y; disc = sqrt( c(2)^2 - 4*c(1)*c(3) ); % if ( real(c(2))*real(disc) + imag(c(2))*imag(disc) > 0 ) if abs( c(2) + disc ) > abs( c(2) - disc ) denom = c(2) + disc; else denom = c(2) - disc; end [roots(c)', -2*c(3)/denom, x']; x = [x(2), x(3), x(2) - 2*c(3)/denom]'; y = [y(2), y(3), polyval( p, x(3) )]'; if ( abs( x(2) - x(3) ) < eps_step && abs( y(3) ) < eps_abs ) break; end end x(3)
Copyright ©2005 by Douglas Wilhelm Harder. All rights reserved.