MATLAB 问题求救~ 20

function[yy,c]=lagrange(x,y,z)nx=length(x);ny=length(y);n=min(nx,ny);yy=0;fori=1:np=1... function [yy,c]=lagrange(x,y,z)
nx=length(x);ny=length(y);
n=min(nx,ny);
yy=0;
for i=1:n
p=1.0;
for j=1:n
if i~=j
if abs(x(i)-x(j))<eps
error('error');
return;
end
ll=[1.0-x(j)]/(x(i)-x(j));
p=conv(p,ll);
end
end
yy=pplus(yy,p*y(i));
end
if nargout=2
c=polyval(yy,2);
end
x=[1 2 3 4 5]
y=1.30 1.80 2.20 2.9 3.5]
p=lagrange(x,y)

已运行它,就会出现??? Strings passed to EVAL cannot contain function declarations

谁帮我修改一下,拜托了。。。。。
展开
 我来答
艾丝凡怠速放缓
2013-09-01 · TA获得超过730个赞
知道答主
回答量:111
采纳率:100%
帮助的人:19.1万
展开全部
07年问的!我现在才挖出来,楼主,不好意思回答晚了

正确的应该如下

function [yy,c]=lagrange(x,y,z)
nx=length(x);ny=length(y);
if nx~=ny
warning('The lengths of X and Y should be equal');
end
n=min(nx,ny);
if n<2
error('the number of the DATA should be greater than 1');
return;
end
yy=0;
for i=1:n
p=1.0;
for j=1:n
if i~=j
if abs(x(i)-x(j))<eps
error('the DATA is error!');
return;
end
ll=[1 0-x(j)]/(x(i)-x(j)); %这边是1 0 不是1.0
p=conv(p,ll);
end
end
yy=plus(yy,p*y(i)); %现在pplus函数matlab里面没有了,变为plus。我以前看到的一些比较老的书里写的也是pplus,实际上就是相加,可以写成yy=yy+p*y(i)
end
if nargout==2
c=polyval(yy,z);
end

楼主,我验算过,应该没问题了!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
意法半导体(中国)投资有限公司
2023-06-12 广告
单片机,即单片微控制器,也称为单片微型计算机,是将中央处理器(CPU)、存储器(ROM,RAM)、输入/输出接口和其他功能部件集成在一块 在一个小块的集成电路上,从而实现对整个电路或系统的数字式控制。单片机不是完成某一个逻辑功能的芯片,而是... 点击进入详情页
本回答由意法半导体(中国)投资有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式