MATLAB在数学建模中的应用 随手笔记(二)----- 数据拟合方法: @; S7 y* C8 r9 ?4 a$ B
一、多项式拟合6 m [* n: Q+ V9 o0 J
将数据点按多项式的形式进行拟合,使用最小二乘法,可以确定多项式的系数。多项式拟合有指令语句和图形窗口两种方法:0 M& C. C$ e; k @
1、多项式拟合指令' _* j4 e( Y; T4 {. V2 c- D
polyfit(x,y,n) :多项式拟合,返回降幂排列的多项式系数。) w3 N0 }) L. x N. K
polyval(p,xi) :计算多项式的值。5 V: c: E' T2 V3 l0 }9 t6 Y: K" x, n% r
其中,x,y是数据点的值;n是拟合的最高次幂;p是返回的多项式系数;xi是要求的点的横坐标。. Z) A( \% y6 U g: ~4 o) b1 D( A
2、图像窗口的多项式拟合* }6 ]7 P D2 a5 m
在图形窗口中可以用菜单的方式对数据进行简单、快速、高效的拟合。
# |0 \+ n* R3 D5 H; q9 l0 Q4 f7 u具体步骤(2017b):" q& }5 I' w! M% Q* ^: i8 i
![]()
; b& K; P0 H- z* _, m2 I) d' i
5 ~ S, e; K; ^ O- X; N; v' A![]()
- |) o" x0 n0 w) v 7 Z' e" x3 l) Y9 M1 D; \
, ?/ L4 M0 s6 ]+ R9 p0 m: d) N4 I* w
二、指定函数拟合. E3 S- j _' ]8 B
在MATLAB中也可以用用户自定义的函数进行拟合,通过下面的例子读者可以了解指定函数进行数据拟合的基本方法。6 X0 {* v& H% i( I: q2 x
对该数据进行指定拟合:$ h& x5 q3 D- g2 X: R# f% _. L
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];%列向量$ ^* G9 g7 p# g/ g# Y0 G- p
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];/ {! a1 N; t+ B% D
在MATLAB中可以用如下命令画出上述点的散点图
$ ^# G5 x# l, O+ Y# ]
- ^2 X5 ^) \, ?![]()
' j6 [$ ?: O/ c2 {知道其对应的函数形式为f(t)=acos(kt)e^wt,则可用MATLAB进行拟合。编写如下M文件:
2 o1 ]; y5 d$ t2 t
- u; K, z% L& E( h6 K
运行此程序,结果如下:
3 I5 T& e; G- a* B0 @. M
+ a/ |% u7 @( S$ ^/ G$ l, D6 r9 W
![]()
8 g# X+ G$ Q: u# T5 t/ h程序中,fittype函数是自定义拟合函数;cfun=fit(x,y,f)是根据自定义的拟合函数f来拟合数据x,y。注意:此处数据必须为列向量的形式。fittype函数和fit函数的用法和参数规则可参考Help; q( ?& k# G: t( F+ M
从结果可以看出,拟合的曲线为f(x)=0.9987cos(1.001t)e^-0.2066t。拟合曲线给出了数据的大致趋势,效果很好,并给出了各参数的置信区间。/ v" }& l( |& ^1 m* y
注意:command window里给出了warning,是由a,k,w三个参数的初始值未给出导致的,因此如果拟合结果不理想,可以多运行几次。8 q& P* s. e' t+ X
三、曲线拟合工具箱 B+ `! l* s0 \) |
MATLAB的曲线拟合工具箱功能非常的强大,使用也很方便。 详细步骤:![]() 6 O( R+ `& a8 S6 D1 U
) `9 Z9 f2 e6 i
( P% K3 N8 i8 _
界面中有五个按钮,功能是:
% [1 I" c) N6 P) @# W9 ~8 z7 j1 _Data:输出、查看和平滑数据;+ D* b& X9 k4 c+ q2 }, E2 O
Fitting:拟合数据、比较拟合曲线和数据集;+ D: F: L6 z% K9 n7 K
Exclude:可从拟合曲线中排除特殊的数据点;
) U3 t9 X- S, \- F) f; F0 VPlotting:选定区间后,单击按钮可选择原始数据和拟合数据作图;7 }) x2 J' w1 e4 ]5 V
Analysis:对拟合进行满意度、偏差等分析。/ E% s( Y: p6 @7 y- S. s
曲线拟合工具箱中包含了各种常用的数据拟合方法,可以对各种函数进行拟合,具体的操作方法请参考Help。
) g# f. b4 B- M9 m6 x- \" N; l. f. A# v0 x! V# A& P
1 B4 u3 H# o" T' H! x! T# e# q
|