多项式拟合程序matlab,matlab练习程序(最小二乘多项式拟合)

最近在分析一些数据,就是数据拟合的一些事情,用到了matlab的polyfit函数,效果不错。

因此想了解一下这个多项式具体是如何拟合出来的,所以就搜了相关资料。

这个文档介绍的还不错,我估计任何一本数值分析教材上讲的都非常清楚。

推导就不再写了,我主要参考下面两页PPT,公式和例子讲的比较清楚。

公式:

c661e255571f4b0b9af20e5695a5bbab.png

例子:

81df78227d041bf8a67b5899c1348481.png

matlab代码如下:

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函数结果:

786a802374dbc9ebcced25f281d97bbc.png

自己的结果:

6d78688ce8422829cc885d405f57e6cf.png

在阶数较低的时候两种方法结果基本一致,阶数很高的时候,自己的方法结果就差一些了,matlab原生函数效果还是好一些啊。

关注公众号: MATLAB基于模型的设计 (ID:xaxymaker) ,每天推送MATLAB学习最常见的问题,每天进步一点点,业精于勤荒于嬉。

打开微信扫一扫哦!

拟合功能说明: 对于形如y=a1*x^n+a2*x^(n-1)+...+an*x+a(n+1)的函数,若a1,a2,...,a(n+1)未知,则可以由n+1对不同的(x,y)值求出这些a的值。更进一步的说,给你一条X-Y轴平面里的曲线,或是,已知一系列的(x,y)值,要你用一个近似的一元函数拟合它,该怎么办?这个时候你不知道该一元函数的最高次数是多少,即不知道未知数系数a1,a2,...,a(n+1)的个数。在这里显然要先假设一个n的值,再来算出这些系数值:有n+1个未知数系数要求,就得有n+1对(x,y)的值,这样可以精确算出唯一的解。但是,如果给你的(x,y)值对数多于n+1对该怎么办(因为你碰到的情况几乎都是这样的)?你算出来的近似函数得兼顾所有的(x,y)取样点,使得误差最小。你不能只取所有(x,y)取样点中的n+1对计算,而扔掉了多出来的那些取样点。该程序的拟合功能就是完成这个任务的。它会计算所有的取样点,最后得出一个误差最小的函数。 执行过程如下: 先读取右边两个编辑框内的(x,y)取样点,再弹出一个对话框让你假设一个一元函数,即最高次数n,然后程序会开始计算。注意,若n设的太大,计算过程可能会很久,会造成程序假死现象。得出的结果会直接以函数的形式显示在下面的长条形编辑框内。你可以通过点击“←画图”和“画图→”来进行比较拟合的近似程度。注意,你设置的n值不是越大,就拟合得越好,也不是越小,拟合得越好,原因你细想一下就会明白。程序所用的计算原理是最小二乘法,所用的计算方法是矩阵运算。你可以百度相关知识。 该程序的另外一个“辨识”功能,用到的也是最小二乘法,传递函数等相关知识是大学工科学生会学到的。 其他不懂的问题请联系作者:hastings1986@163.com。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值