The bisection method, which is alternatively called binary chopping, interval halving, or Bolzano’s method, is one type of incremental search method in which the interval is always divided in half. If a function changes sign over an interval, the function value at the midpoint is evaluated. The location of the root is then determined as lying at the midpoint of the subinterval within which the sign change occurs. The process is repeated to obtain refined estimates. A simple algorithm for the bisection calculation is listed in the following figure.
Reference; Numerical Methods for Engineers. Steven C. Chapra and Raymond P. Canale
public static void main (String[] args)
{
//Bisection Method
double a,b,x1,x2,epsilon,midpt,fb;
a=0;
b=3;
x1=a;
x2=b;
fb=fx(b);
epsilon=0.001;
midpt=0;
if(fx(a)*fx(b)>0){System.out.println("Can't do bisection with those values");}
else{
while (Math.abs(x2 - x1) > epsilon) {
midpt = 0.5 * (x1 + x2);
if (fb * fx(midpt) > 0)
{x2 = midpt;}
else
{ x1 = midpt;}
}
}
System.out.println("x = "+ midpt);
}
public static double fx(double x){
double y;
//y=x^2-3
y=Math.pow(x, 2)-3;
return y;
}
No hay comentarios:
Publicar un comentario