Matlab Code
function
[p1,err,k,y]=secant(f,p0,p1,delta,epsilon,max1)
%Input - f is the object function input as a string 'f'
% - p0 and p1 are the initial
approximations to a zero of
f
% - delta is the
tolerance for p1
% - epsilon is the
tolerance for the function values y
% - max1 is the
maximum number of iterations
%Output - p1 is the secant method approximation to the zero
% - err is the
error estimate for p1
% - k is the
number of iterations
% - y is the
function value f(p1)
for k=1:max1
p2=p1-feval(f,p1)*(p1-p0)/(feval(f,p1)-feval(f,p0));
err=abs(p2-p1);
relerr=2*err/(abs(p2)+delta);
p0=p1;
p1=p2;
y=feval(f,p1);
if
(err<delta)|(relerr<delta)|(abs(y)<epsilon),break,end
end
(c) John H. Mathews 2004