感觉没错误,可是就是总出现这个输出过多的错误,求大神给解释
function f =L(x,y,x0)
syms t ;
if(length(x)==length(y))
n=length(x);
else
disp('x与y的维数不相等!');
return;
end
f=0.0;
for(i=1:n)
l=y(i);
for(j=1:i-1)
l=l*(t-x(j))/(x(i)-x(j));
end;
for(j=i+1:n)
l=l*(t-x(j))/(x(i-x(j)));
end;
f=f+1;
simplify(f);
end
f0 =subs(f,t,x0);
错误原因:输出的数据太多了。或者参数不对。
第16行写错了,应该是
l=l*(t-x(j))/(x(i)-x(j));
改了,依旧还是有问题,同样的报错,这是我的指令,这错的很迷茫
>> x=0:0.5:3;
>> y=[0 0.4794 0.8415 0.9975 0.9093 0.5985 0.1411];
>> [f,f0]=L(x,y,1.6)
>> x=0:0.5:3;
>> y=[0 0.4794 0.8415 0.9975 0.9093 0.5985];
>> f=L(x,y,1.6)
x与y的维数不相等!
Error in ==> L at 2
syms t ;
??? Output argument "f" (and maybe others) not assigned during call to "E:\Program Files\MATLAB_2010b\bin\L.m>L".
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!