我正在运行一个简单的脚本来估计函数的根。一切都很好,算法的每次迭代都会打印出当前的 x 和 f(x),但是当脚本完成并将 x 的最终估计设置为函数的输出时,该值被返回并四舍五入到小数点后 3 位。 .
while k < maxit
k = k + 1;
dx = b - a;
xm = a + 0.5*dx; % Minimize roundoff in computing the midpoint
fm = feval(fun, xm, diameter, roughness, reynolds);
fprintf('%4d %12.20e %12.4e\n',k,xm,fm);
if (abs(fm)/fref < feps) | (abs(dx)/xref < xeps) % True when root is found
r = xm;
return;
end
这是输出的尾部位:
k xm fm
45 6.77444446476613980000e-003 1.3891e-012
46 6.77444446478035060000e-003 -1.3380e-011
47 6.77444446477324520000e-003 -5.9952e-012
48 6.77444446476969250000e-003 -2.3022e-012
49 6.77444446476791610000e-003 -4.5830e-013
ans =
0.0068
我不知道为什么它会舍入输出....我该如何防止呢?