lagrange插值的MATLAB实现
2个回答
2014-03-14
展开全部
function f=Language(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+l;
simplify(f);
if(i==n)
if(nargin==3)
f=subs(f,'t',x0);
else
f=collect(f);
f=vpa(f,6);
end
end
end
看看对不对,很早做的,自己也不太清楚了,呵呵.
% 拉格朗日
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+l;
simplify(f);
if(i==n)
if(nargin==3)
f=subs(f,'t',x0);
else
f=collect(f);
f=vpa(f,6);
end
end
end
看看对不对,很早做的,自己也不太清楚了,呵呵.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2014-03-14
展开全部
用计算器算好像更简单呢,呵呵
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询