Hi, I am having a hard time finding the root to a polynomial function using the bisection method

Hi,
I am having a hard time finding the root to a polynomial function using the bisection method with the precision of 0.001. This is not a homework question. I am new at this and just trying to learn. This is what I have, but I have errors. I do appreciate any help or advice.
function root[x_lower,x_upper] 3*x.^3-10;
x_lower=-5;
x_upper=5;
x_mid= (x_lower* X_upper)/2;
while abs (f(x_mid))>0.001
if (f(x_mid)*f(x_upper))<0
x_lower=x_mid
else
x_upper=x_mid
end
x_mid=(x_lower+x_upper)/2;
end
fprintf('the root is %g\n', x_mid)

2 Comments

what is this last command used for "fprintf('the root is %g\n', x_mid)"
The fprintf() in that form displays to the command window the text
the root is
followed on the same line by the value of the variable x_mid, with the value represented in direct decimal notation if its absolute value is in the range 0.0001 to 999999, and otherwise representing it in scientific notation. After that, newline is output to move on to the next line

Sign in to comment.

 Accepted Answer

Change
function root[x_lower,x_upper] 3*x.^3-10;
to
function root(x_lower,x_upper)
f = @(x) 3*x.^3-10;

3 Comments

Thank you, it helped clear up some confusion, but I get the following error: Undefined function or variable 'X_upper'.
Error in root (line 5) x_mid= (x_lower+ X_upper)/2;
X_upper and x_upper are different variable names. You have used both. You need to be consistent.

Sign in to comment.

More Answers (0)

Categories

Find more on Mathematics in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!