MATLAB在数学建模中的应用 随手笔记(二)----- 数据拟合方法- E! ~( u& D4 _: j* R5 D
一、多项式拟合
- ~4 }7 B3 i+ Z f& C将数据点按多项式的形式进行拟合,使用最小二乘法,可以确定多项式的系数。多项式拟合有指令语句和图形窗口两种方法:2 u& P6 E- b7 S
1、多项式拟合指令' {8 D- i2 _$ m8 a' e: e3 A
polyfit(x,y,n) :多项式拟合,返回降幂排列的多项式系数。# j9 y. A- P' _" I8 ?1 ?0 F+ S
polyval(p,xi) :计算多项式的值。$ p0 l, F7 G* ]) {6 C
其中,x,y是数据点的值;n是拟合的最高次幂;p是返回的多项式系数;xi是要求的点的横坐标。
, X& S. c/ f- a: q2 m3 T7 y$ H }6 V2、图像窗口的多项式拟合' {5 b" h7 G% W( { T }1 j$ ]
在图形窗口中可以用菜单的方式对数据进行简单、快速、高效的拟合。
5 K" e- w9 I8 _7 V具体步骤(2017b):6 V( t% F' s* `1 `& A4 \
![]()
$ L2 S( V& p% B1 l% c
5 Q! L+ k2 a1 U![]()
7 n& _* S) T+ t![]()
& c, @0 ]# t+ U4 ?- ~3 j9 L7 W 7 ?' u* J4 G0 j9 D O( }$ J5 ?
二、指定函数拟合
& g& [ V' o% [( x) {- V7 E在MATLAB中也可以用用户自定义的函数进行拟合,通过下面的例子读者可以了解指定函数进行数据拟合的基本方法。
2 h; S" i+ N) N2 Y7 ^对该数据进行指定拟合:! i) R+ [6 ^* G2 V
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];%列向量2 {6 o( [0 A l
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];
e' v+ Q3 D" N( D- h在MATLAB中可以用如下命令画出上述点的散点图8 L8 t4 Y2 h$ x( n6 }$ V5 ] p; g
# v" ]1 b5 ]+ y! e. h" T![]()
! m4 D4 ]3 t/ K9 }1 C* Z1 Y知道其对应的函数形式为f(t)=acos(kt)e^wt,则可用MATLAB进行拟合。编写如下M文件:6 P$ [# q5 \7 y+ D7 }5 Z
. N6 I! k7 g L7 T: E9 E' ]" _ U
运行此程序,结果如下:
, T+ _& ]; X" ~5 ^3 s
- ?" g7 z! R! t" P9 x![]()
9 C' @: _: m4 p, y9 v# O" D程序中,fittype函数是自定义拟合函数;cfun=fit(x,y,f)是根据自定义的拟合函数f来拟合数据x,y。注意:此处数据必须为列向量的形式。fittype函数和fit函数的用法和参数规则可参考Help! K/ d% ~- d3 ]" f+ T
从结果可以看出,拟合的曲线为f(x)=0.9987cos(1.001t)e^-0.2066t。拟合曲线给出了数据的大致趋势,效果很好,并给出了各参数的置信区间。- `' `0 Z( i; G& j% }2 ` L
注意:command window里给出了warning,是由a,k,w三个参数的初始值未给出导致的,因此如果拟合结果不理想,可以多运行几次。
2 b. t- K% E9 v& ~' b- {. G7 G: G三、曲线拟合工具箱
# k9 @; v7 R9 b( O- w; Y* Z6 ZMATLAB的曲线拟合工具箱功能非常的强大,使用也很方便。 详细步骤:![]() 3 X; v+ d$ @1 A5 Q0 n6 ]* ^
* @' Z5 \! v! B4 s5 @+ `
\- Y4 d0 [8 _
界面中有五个按钮,功能是:. t9 u5 n$ G" `2 w f7 F) s
Data:输出、查看和平滑数据;9 q) v5 \/ G1 [0 O
Fitting:拟合数据、比较拟合曲线和数据集;) w; J$ ]3 B+ z. d
Exclude:可从拟合曲线中排除特殊的数据点;3 Q$ C; }1 y$ u, g
Plotting:选定区间后,单击按钮可选择原始数据和拟合数据作图;1 s* c, {) d6 r: `3 |* ]
Analysis:对拟合进行满意度、偏差等分析。& k, `' }% H4 Q1 z4 [% p
曲线拟合工具箱中包含了各种常用的数据拟合方法,可以对各种函数进行拟合,具体的操作方法请参考Help。2 @1 v2 g0 A$ H- }% Q
5 h' E% f! R" ?( e6 k" l9 ?
3 @- q# @+ W5 W" t/ y9 b& ? |