필터 지우기
필터 지우기

Using the Bisection Method,calculating xr and approximate errors???

조회 수: 9 (최근 30일)
Onur Aytan
Onur Aytan 2015년 11월 6일
댓글: Dipankar Dutta 2021년 4월 22일
Hi, I tried to solve a question using the bisection method, trying to find out xr (root of eq.) and aprroximate error, but there is a problem with my program that I need to define xrold anyhow as the value of xr changes in every iteration. In addition, I need to find Ea=((xr-xrold)/xr))*100 using the old and new values for xr in each step once again. I don't know how to employ this circle for each values of xr. Could you possibly help?
That was the program I made where I got an error at xrold value that obviously, it hasn't been defined properly;
In the question we have the given values of Es, xl, xu and a polynomial function which is f(x)=26+85*x-91*x^2+44*x^3-8*x^4+x^5
%Solve the equation using the bisection method.
xl=0.5;
xu=1;
Es=10;
iter=0;
while(1)
xrold=xr;
f=@(x) -26+85*x-91*x^2+44*x^3-8*x^4+x^5;
xr=(xl+xu)/2;
iter=iter+1;
if xr~=0;
Ea=abs((xr-xrold)/xr)*100;
end
test=f(xl)*f(xr);
if test<0;
xu=xr;
elseif test >0;
xl=xr;
else
Ea=0;
end
if Ea<Es
break
end
end
  댓글 수: 5
Onur Aytan
Onur Aytan 2015년 11월 7일
편집: Onur Aytan 2015년 11월 7일
Ohh, trying to find out xr (root of eq.) and aprroximate errors.
But the root we predict with our iterations doesn't give us the exact root since we just make use of approximations, recalculating xr in each turn, and finally finding a suitable value for xr after some iterations which is supposed to be so close to the real root.
And as you can see our approximated root must be determined based on the method we use and the iterations, and iterations are repeated based on the criteria that we must check for each iteration(step) that approximate error should be greater than Prespecified error (given in the problem).From the moment, they either start to be equal or prespecified error(Es) becomes greater than approximate error we halt iterating and setting the final value of xr as the alternative value from this iteration.
Dipankar Dutta
Dipankar Dutta 2021년 4월 22일

2. Make an octave code to integrate ex with respect to dx from 0 to 1, by Simpson’s ⅓ rule. Divide the limits into 6 equal parts.

Please solve this

댓글을 달려면 로그인하십시오.

채택된 답변

Geoff Hayes
Geoff Hayes 2015년 11월 7일
편집: Geoff Hayes 2015년 11월 7일
Onur - if the problem is because you don't have an xr on the first iteration of the while loop, then just wait until you do. And so allow one iteration to pass without you calculating the Ea value. Try the following
f=@(x) -26+85*x-91*x^2+44*x^3-8*x^4+x^5;
while iter<1000
xr=(xl+xu)/2;
iter=iter+1;
test=f(xl)*f(xr);
if test<0;
xu=xr;
elseif test >0;
xl=xr;
end
if iter > 1
if abs(xr)>0
Ea=abs((xr-xrold)/xr)*100;
if abs(Ea)<Es
break
end
end
end
xrold=xr;
end
In the above, note the following:
  • define the anonymous function outside of the while loop (no need to do it on every iteration);
  • cap the number of iterations in the while loop to 1000 so that we don't get stuck in an infinite loop;
  • only calculate Ea on every iteration after the first one; and
  • initialize xold at the end of the iteration
  댓글 수: 4
Onur Aytan
Onur Aytan 2015년 11월 8일
done, thanks once again!
Dipankar Dutta
Dipankar Dutta 2021년 4월 22일
3. Make an octave code to find the root of cos(x) – x * ex = 0 by using bisection method. The answer should be corrected up to four decimal places

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Utilities for the Solver에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by