是的,有几个建议(在下面的版本 1 中实现):if
循环可以与for
上面结合(只需通过类似下面的方式index
跳过);总是相等的,总是相等的(因为你有数据点,带有系数的多项式),所以最后一个循环和下一行也可以用简单的替换k
jr(jr~=j)
polynomialSize
length(outputConv)
n
n
(n-1)th
n
for
L(k,:) = multiplier * outputConv;
所以我在http://en.wikipedia.org/wiki/Lagrange_polynomial上复制了这个例子(并采用了他们的j-m
表示法,但对我来说j
是1:n
and m
is 1:n
and m~=j
),因此我的初始化看起来像
clear; clc;
X=[-9 -4 -1 7]; %example taken from http://en.wikipedia.org/wiki/Lagrange_polynomial
Y=[ 5 2 -2 9];
n=length(X); %Lagrange basis polinomials are (n-1)th order, have n coefficients
lj = zeros(1,n); %storage for numerator of Lagrange basis polyns - each w/ n coeff
Lj = zeros(n); %matrix of Lagrange basis polyns coeffs (lj(x))
L = zeros(1,n); %the Lagrange polynomial coefficients (L(x))
然后 v 1.0 看起来像
jr=1:n; %j-range: 1<=j<=n
for j=jr %my j is your k
multiplier = 1;
outputConv = 1; %numerator of lj(x)
mr=jr(jr~=j); %m-range: 1<=m<=n, m~=j
for m = mr %my m is your index
outputConv = conv(outputConv,[1 -X(m)]);
multiplier = multiplier * ((X(j) - X(m))^-1);
end
Lj(j,:) = multiplier * outputConv; %jth Lagrange basis polinomial lj(x)
end
L = Y*Lj; %coefficients of Lagrange polinomial L(x)
如果您意识到 l_j(x) 的分子只是具有特定根的多项式,则可以进一步简化 - 因为 matlab 中有一个很好的命令 - poly
。类似地,分母就是在 X(j) 处评估的那个多边形 - 因为存在polyval
。因此,v 1.9:
jr=1:n; %j-range: 1<=j<=n
for j=jr
mr=jr(jr~=j); %m-range: 1<=m<=n, m~=j
lj=poly(X(mr)); %numerator of lj(x)
mult=1/polyval(lj,X(j)); %denominator of lj(x)
Lj(j,:) = mult * lj; %jth Lagrange basis polinomial lj(x)
end
L = Y*Lj; %coefficients of Lagrange polinomial L(x)
为什么是 1.9 版而不是 2.0 版?好吧,可能有一种方法可以摆脱最后一个 for 循环,并将其全部写在 1 行中,但我现在想不起来 - 这是 v 2.0 的待办事项 :)
而且,对于甜点,如果您想获得与维基百科相同的图片:
figure(1);clf
x=-10:.1:10;
hold on
plot(x,polyval(Y(1)*Lj(1,:),x),'r','linewidth',2)
plot(x,polyval(Y(2)*Lj(2,:),x),'b','linewidth',2)
plot(x,polyval(Y(3)*Lj(3,:),x),'g','linewidth',2)
plot(x,polyval(Y(4)*Lj(4,:),x),'y','linewidth',2)
plot(x,polyval(L,x),'k','linewidth',2)
plot(X,Y,'ro','linewidth',2,'markersize',10)
hold off
xlim([-10 10])
ylim([-10 10])
set(gca,'XTick',-10:10)
set(gca,'YTick',-10:10)
grid on
生产
享受并随意重用/改进