Use the Bisection Method to find the first root of f(x) = -12 – 21x + 18x² – 2.75a. In doing so, use the initial guesses (bracket) of a = – -1 and b = 0 with a stopping criterion of 1% relative error (also known as relative or approximation error), as given by xnew pold Crel = x 100% < a = 1% xnew where xew is the midpoint for the current interval (really, the current estimate of the root) and xold is that for the latest previous iteration. After you have implemented the Bisection Method to find the first root, plot the function f(x) from x = -2 to x = 7 (i.e. these are the x-limits). Using the hold on command, plot your estimate of the root on top of the original plot using a single marker that is of a different style and color than the main plot (for example, plot the range of values in blue with x-markers, and overlay the first root with a red circle marker). This plotting serves as a "sanity check" for the reasonableness of your results. Hints: • You can treat f as an anonymous function so that you can easily pass values of x to f as an argument without having to re-define the expression for f. Example syntax: my_fun = @(x) 2 + 5*x • If you are going to pass a vector of input values to your function f (for example, when plotting) then make sure to use the "dot" operator for element-wise operations (e.g., "*" instead of "*" etc. to avoid non-conformable errors). Explore the documentation for the built-in function plot or the plotting examples from class to beautify your figure.
data:image/s3,"s3://crabby-images/6ba13/6ba13083c5b27fa4f1c87a78b9e7e7aac0370e34" alt="Use the Bisection Method to find the first root of f(x) = -12 – 21x + 18x² – 2.75a³. In
doing so, use the initial guesses (bracket) of a = –
-1 and b = 0 with a stopping criterion
of 1% relative error (also known as relative or approximation error), as given by
xnew
pold
Crel =
x 100% < E =
1%
xnew
where xew is the midpoint for the current interval (really, the current estimate of the root) and
xold is that for the latest previous iteration.
After you have implemented the Bisection Method to find the first root, plot the function f(x)
from x = -2 to x = 7 (i.e. these are the x-limits). Using the hold on command, plot your
estimate of the root on top of the original plot using a single marker that is of a different
style and color than the main plot (for example, plot the range of values in blue with x-markers,
and overlay the first root with a red circle marker). This plotting serves as a "sanity check"
for the reasonableness of your results.
Hints:
You can treat f as an anonymous function so that you can easily pass values of x
to f as an argument without having to re-define the expression for f. Example syntax:
my_fun = @(x) 2 + 5*x
• If you are going to pass a vector of input values to your function f (for example, when
plotting) then make sure to use the "dot" operator for element-wise operations (e.g., ".*"
instead of "*" etc. to avoid non-conformable errors).
Explore the documentation for the built-in function plot or the plotting examples from
class to beautify your figure."
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Following is the Matlab code for the given problem:
%clear the command window
clc;
clear all;
%given function
f=@(x)-12-21*x+18*x^2-275*x^3;
low=-1;
high=0;
tol=0.00000001;
% Evaluate both ends of the interval
y1 = feval(f, low);
y2 = feval(f, high);
i = 0;
% Display error and finish if signs are not different
if y1 * y2 > 0
disp('Have not found a change in sign. Will not continue...');
m = 'Error'
return
end
% Work with the limits modifying them until you find
% a function close enough to zero.
disp('Iter low high x0');
while (abs(high - low) >= tol)
i = i + 1;
% Find a new value to be tested as a root
m = (high + low)/2;
y3 = feval(f, m);
if y3 == 0
fprintf('Root at x = %f \n\n', m);
return
end
fprintf('%2i \t %f \t %f \t %f \n', i-1, low, high, m);
% Update the limits
if y1 * y3 > 0
low = m;
y1 = y3;
else
high = m;
end
end
% Show the last approximation considering the tolerance
w = feval(f, m);
fprintf('\n x = %f produces f(x) = %f \n %i iterations\n', m, y3, i-1);
%plot
hold on;
fplot(f,[-2 7]);
xlabel('x');
ylabel('f(x)');
hS1 =
scatter(m,f(m),300,'*','MarkerEdgeColor',[0 .5 .5],'MarkerFaceColor',[0 .7 .7]);
Code demo for reference:
Step by step
Solved in 5 steps with 4 images
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"