Effacer les filtres
Effacer les filtres

What's wrong with my bisection method function???

1 vue (au cours des 30 derniers jours)
Joe
Joe le 11 Avr 2013
I'm not quite sure what's exactly wrong with my bisection method function that I have written. Can someone please help me figure out what the error is?
function root = bisectIter(f,a,b,tol)
if sign(f(a))==sign(f(b))
error('a and b do not bracket the root');
end
k = 1;
x(k) = (a+b)/2;
while ((k<=tol)&&((b-a)/2)>= tol)
if f(x(k)) == 0
error('bisection condition didnt apply')
end
if (f(x(k))*f(a))<0
b = x(k);
else
a = x(k);
end
k = k + 1;
x(k) = (a+b)/2;
root = x(k);
end
end
  2 commentaires
Matt J
Matt J le 11 Avr 2013
Modifié(e) : Matt J le 11 Avr 2013
Show us what error you're getting and how to reproduce it.
Joe
Joe le 12 Avr 2013
The error "Output argument 'root' not assigned during call..." shows up. I've already checked for the possible causes of this error and none seem to fit. When I alter my code so that it should produce an error when I run it, it does in fact produce that error instead of the output argument error.

Connectez-vous pour commenter.

Réponses (1)

Roger Stafford
Roger Stafford le 12 Avr 2013
In the 'while' condition "((k<=tol)&&((b-a)/2)>= tol)" presumably you have set 'tol' to some very small number to allow a and b to approach each other closely. That means the "k<=tol" part will fail at the very beginning and you will never enter the while-loop. That is why the 'root' argument is never assigned.
In my opinion your 'while' criterion should be based on how close to zero the f function gets instead of the width b-a or the number of trips through the loop.
Also the "f(x(k)) == 0" condition that produces an error message is rather self-defeating. This is the very condition you are striving for, namely to find a root.

Catégories

En savoir plus sur Shifting and Sorting Matrices dans Help Center et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by