1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
|
/* Written by Charles Harris charles.harris@sdl.usu.edu */
#include <math.h>
#include "zeros.h"
double
bisect(callback_type f, double xa, double xb, double xtol, double rtol,
int iter, default_parameters *params)
{
int i;
double dm,xm,fm,fa,fb;
fa = (*f)(xa,params);
fb = (*f)(xb,params);
params->funcalls = 2;
if (fa*fb > 0) {
params->error_num = SIGNERR;
return 0.;
}
if (fa == 0) {
return xa;
}
if (fb == 0) {
return xb;
}
dm = xb - xa;
params->iterations = 0;
for (i=0; i<iter; i++) {
params->iterations++;
dm *= .5;
xm = xa + dm;
fm = (*f)(xm,params);
params->funcalls++;
if (fm*fa >= 0) {
xa = xm;
}
if (fm == 0 || fabs(dm) < xtol + rtol*fabs(xm)) {
return xm;
}
}
params->error_num = CONVERR;
return xa;
}
|