MATLAB在数学建模中的应用 随手笔记(二)----- 数据拟合方法8 ]6 s/ y9 P7 _; L
一、多项式拟合( i2 \; J! ?+ q) w( w: p" \& ?7 x
将数据点按多项式的形式进行拟合,使用最小二乘法,可以确定多项式的系数。多项式拟合有指令语句和图形窗口两种方法:
/ O4 J, ^2 V$ r: O* Y; s1、多项式拟合指令7 W* v3 i( c+ r* f0 U$ }5 J
polyfit(x,y,n) :多项式拟合,返回降幂排列的多项式系数。4 n& R+ m5 o N
polyval(p,xi) :计算多项式的值。2 \. f U$ C5 D7 [/ {
其中,x,y是数据点的值;n是拟合的最高次幂;p是返回的多项式系数;xi是要求的点的横坐标。
* O; l' e# ^8 T6 v; g: ~7 c2、图像窗口的多项式拟合
1 w/ O( n. a) V+ L. u在图形窗口中可以用菜单的方式对数据进行简单、快速、高效的拟合。
) }5 `3 V" R; n7 R% t A- w4 F具体步骤(2017b):, n% o4 C) F& b) |
. J4 ^# b# B; h: r
9 a. |) Q6 w) l) C. H: j , r3 t) U4 `# {: {8 x3 o
0 P# I, b P4 y1 `8 m7 v
![]()
- C# `) i* ^4 D( v/ o8 e二、指定函数拟合
/ ?' X% ]8 G3 E) P在MATLAB中也可以用用户自定义的函数进行拟合,通过下面的例子读者可以了解指定函数进行数据拟合的基本方法。
, A4 O9 x9 i/ b$ ~8 X% k% U7 Z, A; j对该数据进行指定拟合:
! L5 r$ u6 i2 ~7 I' rx=[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];%列向量
/ m# F8 e+ W" }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];5 _. o0 ^. a1 h m- i+ t) `" U. i
在MATLAB中可以用如下命令画出上述点的散点图
) e. F, ^2 ~& D0 l$ }: j, G `) Z5 k
![]()
1 P1 V! {0 j9 U' P& j知道其对应的函数形式为f(t)=acos(kt)e^wt,则可用MATLAB进行拟合。编写如下M文件:
3 A; c( R0 L: `# r# q. |
_9 X0 b D/ O( k
运行此程序,结果如下:
0 \$ W' Z; d$ K2 S! h
5 n# K: W/ E# G) P![]()
. z( X7 p0 J' `( ], V8 W程序中,fittype函数是自定义拟合函数;cfun=fit(x,y,f)是根据自定义的拟合函数f来拟合数据x,y。注意:此处数据必须为列向量的形式。fittype函数和fit函数的用法和参数规则可参考Help
M9 f$ C' O1 s从结果可以看出,拟合的曲线为f(x)=0.9987cos(1.001t)e^-0.2066t。拟合曲线给出了数据的大致趋势,效果很好,并给出了各参数的置信区间。) H; Y- k* c1 O7 J2 t6 \; }2 K' w- [$ \
注意:command window里给出了warning,是由a,k,w三个参数的初始值未给出导致的,因此如果拟合结果不理想,可以多运行几次。# R: f# V- K, P8 u5 ?' ~
三、曲线拟合工具箱
; `& I/ Z' q1 V9 v* w* P qMATLAB的曲线拟合工具箱功能非常的强大,使用也很方便。 详细步骤:![]() % T; r! V7 I/ ]+ t2 r2 ?5 A
![]()
+ a# z* Q k, k1 F% [, L( l' l2 K' `) U+ U7 [- i2 T8 T
界面中有五个按钮,功能是:) p8 r/ H$ C8 L1 U- L
Data:输出、查看和平滑数据;. @! L/ _5 z6 X
Fitting:拟合数据、比较拟合曲线和数据集;
, L% E# X4 n" z# v" \7 |Exclude:可从拟合曲线中排除特殊的数据点;: w/ s _+ Y8 z4 A. @9 g6 r
Plotting:选定区间后,单击按钮可选择原始数据和拟合数据作图;& }/ \( {+ F) h. N+ h
Analysis:对拟合进行满意度、偏差等分析。8 g0 F+ k2 Z c6 C- B+ I* j
曲线拟合工具箱中包含了各种常用的数据拟合方法,可以对各种函数进行拟合,具体的操作方法请参考Help。
- ^2 d+ e3 j! i! F3 o2 m, Q% R# w8 P5 U) Q
) r1 h: }, l. e3 \
|