matlab練習程序(最小二乘多項式擬合)

最近在分析一些數據,就是數據擬合的一些事情,用到了matlab的polyfit函數,效果不錯。html

所以想了解一下這個多項式具體是如何擬合出來的,因此就搜了相關資料。數組

這個文檔介紹的還不錯,我估計任何一本數值分析教材上講的都很是清楚。函數

推導就再也不寫了,我主要參考下面兩頁PPT,公式和例子講的比較清楚。spa

公式:code

例子:htm

matlab代碼以下:blog

clear all;
close all;
clc;

N=10;                %設置擬合階數
x=1:0.5:10;
y=cos(x);           %生成待擬合點

p=polyfit(x,y,N);   %使用matlab函數擬合數據

xx=min(x):0.01:max(x);
yy=polyval(p,xx);
            
plot(xx,yy);        %畫出擬合結果
hold on;
plot(x,y,'r.')

%下面是使用公式來作最小二乘多項式擬合
F=zeros(N+1,length(x));
F(1,:)=1;
for i=2:N+1
   for j=1:length(x) 
        F(i,j) = x(j)^(i-1);      
   end
end
F=F*F';

[m ~]=size(F);
Y=zeros(m,1);
Y(1) = sum(y);
for i=2:m
    for j=1:length(y)
        Y(i) = Y(i)+y(j)*x(j)^(i-1);
    end  
end

Re = F\Y;
Re=Re(end:-1:1)';  %數組反序
figure;
plot(x,y,'r.')
hold on;
yyy=polyval(Re,xx);
plot(xx,yyy,'g')

p
Re

matlab的polyfit函數結果:文檔

本身的結果:get

在階數較低的時候兩種方法結果基本一致,階數很高的時候,本身的方法結果就差一些了,matlab原生函數效果仍是好一些啊。it

相關文章
相關標籤/搜索