MATLAB在数学建模中的应用 随手笔记(二)----- 数据拟合方法
* b+ r' n) J/ r5 c9 l一、多项式拟合
: D( u( U6 Y2 f6 j# ?7 o将数据点按多项式的形式进行拟合,使用最小二乘法,可以确定多项式的系数。多项式拟合有指令语句和图形窗口两种方法:
; E/ [3 x: Q; X w0 E1、多项式拟合指令
) l5 E" K: A6 C9 T1 m/ u0 O7 e6 }polyfit(x,y,n) :多项式拟合,返回降幂排列的多项式系数。+ |( @( h k/ o. ?
polyval(p,xi) :计算多项式的值。0 |* `4 |! _; P9 P
其中,x,y是数据点的值;n是拟合的最高次幂;p是返回的多项式系数;xi是要求的点的横坐标。$ a! x4 R. @) p
2、图像窗口的多项式拟合8 J* u q( i' `& _: U0 h# M
在图形窗口中可以用菜单的方式对数据进行简单、快速、高效的拟合。
2 V/ Y/ H% G! ~/ p具体步骤(2017b):, X/ F( Y; ], c7 u' P( w+ P3 l6 X
![]()
' i, K+ p* ]* j' u- [ `
D/ H0 ?0 ?# W& `5 O & A9 o& c' U# H" W
![]()
( t5 l9 m: T& ` 6 A) m) t( V( y9 M! q
二、指定函数拟合
! c% t$ ~9 B. d/ }8 P在MATLAB中也可以用用户自定义的函数进行拟合,通过下面的例子读者可以了解指定函数进行数据拟合的基本方法。
5 M/ P( |$ }5 I9 D, A- N+ \对该数据进行指定拟合:
; F: d: ?- [& C- ]x=[0;0.4;1.2;2;2.8;3.6;4.4;5.2;6;7.2;8;9.2;10.4;11.6;12.4;13.6;14.4;15];%列向量
' U( d7 L% I; G$ I `y=[1;0.85;0.29;-0.27;-0.53;-0.4;-0.12;0.17;0.28;0.15;-0.03;-0.15;-0.071;0.059;0.08;0.032;-0.015;-0.02];
- @/ n- y" x, K) i在MATLAB中可以用如下命令画出上述点的散点图! q/ y1 M& A$ d' k: ^5 v
9 N3 m+ Y' v. z/ w $ C7 `8 p7 u1 b
知道其对应的函数形式为f(t)=acos(kt)e^wt,则可用MATLAB进行拟合。编写如下M文件:
5 `' I( \7 }6 {0 n) G
. A( `' b4 H% w" B运行此程序,结果如下:
3 L3 p# B4 ^+ o% O3 w1 V/ W
) z/ ?2 C* [: @7 j
![]()
( j: T9 Y* ]# k程序中,fittype函数是自定义拟合函数;cfun=fit(x,y,f)是根据自定义的拟合函数f来拟合数据x,y。注意:此处数据必须为列向量的形式。fittype函数和fit函数的用法和参数规则可参考Help
* l9 n8 _, g7 j* v* ^( _/ w从结果可以看出,拟合的曲线为f(x)=0.9987cos(1.001t)e^-0.2066t。拟合曲线给出了数据的大致趋势,效果很好,并给出了各参数的置信区间。 d! Y9 f, Q0 `: s6 _+ k
注意:command window里给出了warning,是由a,k,w三个参数的初始值未给出导致的,因此如果拟合结果不理想,可以多运行几次。
6 z" Q* p6 J3 Q) i/ W( Y三、曲线拟合工具箱
" u# \- }6 _; |# Y @$ kMATLAB的曲线拟合工具箱功能非常的强大,使用也很方便。 详细步骤:![]() 5 @) Y9 ]- }) l
$ p' @$ h8 r" I2 N* J! f- j
' `' I1 v, P; w9 \界面中有五个按钮,功能是:- r, m" }. t2 {3 ^* [- A
Data:输出、查看和平滑数据;. K: k- h' s/ J0 S1 \+ M
Fitting:拟合数据、比较拟合曲线和数据集;( v2 z( w' L" ]% A
Exclude:可从拟合曲线中排除特殊的数据点;/ L0 G( C* N; [* o' ?$ T
Plotting:选定区间后,单击按钮可选择原始数据和拟合数据作图;' A1 I# S5 h7 ]- ?" C6 {
Analysis:对拟合进行满意度、偏差等分析。- [2 R2 b7 ?* o' Y; M
曲线拟合工具箱中包含了各种常用的数据拟合方法,可以对各种函数进行拟合,具体的操作方法请参考Help。
: I1 b, t( u* B: l6 X6 f& y- }1 B) E0 _6 [, \+ l: K) L6 M* H1 Y
' G, D- Z/ a, N% b/ J; @$ o# e
|