好了,我已经定义了函数MetBisectiei,它包含以下代码:
function [xaprox] = MetBisectiei(Fun,a,b,eps)
Fa = Fun(a);
Fb = Fun(b);
if Fa*Fb>0
xaprox = ('Error: The function has the same sign at points a and b.');
else
N=ceil((log10(b-a)-log10(eps))/log10(2));
for i = 1:n
xaprox = (a+b)/2;
Fxaprox=Fun(xaprox);
if(Fxaprox == 0)
break
end
if Fa*Fxaprox<0
b=Fxaprox;
else
a=xaprox;
Fa=Fxaprox;
end
end
end当我尝试使用这个函数来求一个方程的解时,我得到了下面的错误,这实际上并不能解释问题所在:
Error in tema2_2 (line 8)
xaprox = MetBisectiei(f,0,1,eps);找到方程的解的代码是这个:
syms x
f = x^3-7*x^2+14*x-6;
f = matlabFunction(f);
x = 0:4;
y = f(x);
plot(x,y);
eps = 10^(-5);
xaprox = MetBisectiei(f,0,1,eps);发布于 2019-03-17 02:04:53
我在这里看到的错误很少。首先,您应该终止
function [xaprox] = MetBisectiei(Fun,a,b,eps)使用end,只需关闭if语句即可。第二个问题是n没有定义,你可能忽略了matlab是区分大小写的,并且N不等于n。所以你应该:
n=ceil((log10(b-a)-log10(eps))/log10(2));如果你修复了这两件事-你的代码完成时没有任何错误,(xaprox = 0.5210)在Matlab R2017b上测试。
https://stackoverflow.com/questions/55199787
复制相似问题