MATLAB--插值

%多项式插值

x=[1 2 3 4 5 6];
y=[2 5 6 9 14 26];
a=duoxiangshi(x,y)

function  D=duoxiangshi(X,Y)

A=vander(X)
Y=Y'
B=[A,Y]
C=rref(B)
D=C(:,end)
fprintf('\n 这是一个%d阶的多项式,从高阶到低阶排列!\n',length(Y)-1);
plot(X,Y,'o');
hold on
x=X(1):0.01:X(end);
y=polyval(D,x)
plot(x,y)
end

%拉格朗日插值

x1=[2 3 5 7 8 9];
y1=[5 9 12 16 23 35];
y=lagrange(x1,y1)

function L=lagrange(X,Y)
if length(X)~=length(Y)
    error('维数不相同');
end
m=length(X)
for i=1:m
    L1(i)=Y(i)*ji(X,i);
end
L=sym2poly(expand(sum(L1)));
x=X(1):0.1:X(end);
y=polyval(L,x)
plot(x,y)
hold on
plot(X,Y,'o')
function D=ji(X,n)
    syms x
%     switch n
%         case 1
%             B=x-X(2:end)
%             C=X(1)-X(2:end)
%         case length(X)
%              B=x-X(1:n-1);
%              C=X(n)-X(1:n-1);
%         otherwise 
%             B=x-X([1:n-1,n+1:end]);
%             C=X(n)-X([1:n-1,n+1:end]);
%     end
%写法二
Xn=X(n);
X(n)=[];
B=x-X;
C=Xn-X;
    D=prod(B)/prod(C);

%牛顿插值

x=[2 3 5 6 9];
y=[4 8 12 15

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值