私は一般的にMatlab/プログラミングの初心者です。切り捨て誤差が確実に $< 0.5 \times 10 ^{ -5}$ を実行し、反復回数と根の推定値を出力します。
これが私のコンピューターを壊したように見える私の試みです...
%Approximating the root of f(x) = 2*x - 3*sin(x) + 5 by binary search
%Define variables
low = input('Enter lower bound of range: ');
high = input('Enter upper bound of range: ');
mid = (low + high)/2;
%Define f_low & f_high
f_low = 2*low - 3*sin(low) + 5;
f_high = 2*high - 3*sin(high) + 5;
f_mid = 2*mid - 3*sin(mid) + 5;
%Check that the entered range contains the key
while (f_low * f_high) > 0 || low > high
disp('Invalid range')
low = input('Enter lower bound of range: ');
high = input('Enter upper bound of range: ');
end
%The new range
while abs(f_mid) > 0.5*10^(-5)
if f_mid < 0
low = mid;
elseif f_mid > 0
high = mid;
end
end
fprintf('mid = %.4f \n', mid)
私は反復回数のカウントビットを追加していません(これを行う方法がよくわかりません)、すでに行き詰まっています。
助けてくれてありがとう。