MATLAB在非线性曲线拟合中的应用研究_第1页
MATLAB在非线性曲线拟合中的应用研究_第2页
MATLAB在非线性曲线拟合中的应用研究_第3页
MATLAB在非线性曲线拟合中的应用研究_第4页
MATLAB在非线性曲线拟合中的应用研究_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、MATLAB在非线性曲线拟合中的应用小结摘要:归纳总结了非线性曲线拟合的方法、求解步骤和上机操作过程关键词:曲线拟合非线性MATLAB正文:1曲线拟合的基本原理已知一组测定的数据(例如N个点(xi,yi)去求得自变量x和因变量y的一个近似解析表达式y=(x)。若记误差i=(xi)-yi,i=1,2,N,则要使误差的平方和最小,即要求:为最小,这就是常用的最小二乘法原理。2 .MATLAB曲线拟合的相关方法.函数形式:(1)多项式拟合函数polyfit,调用格式为:p=polyfit(x,y,n)其中x,y为参与曲线拟合的实验数据,n为拟合多项式的次数,函数返回值为拟合多项式的系数(按降幂排列)

2、。n=1时,就为线性拟合。例1:给出表1数据,试用最小二乘法求一次和二次拟合多项式。表1 数据x0y在MATLAB命令窗口中输入:clear;close;x=-1:0.25:1;y=-0.2209,0.3295,0.8826,1.4392,2.0003,2.5645,3.1334,3.7061,4.2836p1=polyfit(x,y,1)p2=polyfit(x,y,2)y1=polyval(p1,x);y2=polyval(p2,x);plot(x,y,+,x,y1,r:,x,y2,k-.) 运行结果:拟合多项式为:y*和y*(2)非线性数据拟合函数lsqcurvefit调用格式为:c=l

3、sqcurvefi(tfun,x0,xdata,ydata)其中fun为拟合函数的M-函数文件名,x0为初始向量,xdata,ydata为参与曲线拟合的实验数据。函数返回值c为非线性函数fun的拟合系数。例2:2004年全国大学生数学建模竞赛C题(酒后驾车)中给出某人在短时间内喝下两瓶啤酒后,间隔一定的时间测量他的血液中酒精含量y(毫克/百毫升),得到数据如表2。表2 酒精含量与饮酒时间的实验数据时间(小时)12345酒精含量306875828277686858515041时间(小时)678910111213141516酒精含量3835282518151210774通过建立微分方程模型得到短时

4、间内喝酒后血液中酒精浓度与时间的关系为: (2)根据实验数据,利用非线性拟合函数lsqcurvefit,确定模型(2)式中的参数c1,c2,c3。求解过程为:先编写一个M-函数文件Example2_1:function f=Example2_1(c,tdata)f=c(1)*(exp(-c(2)*tdata)-exp(-c(3)*tdata);保存后,在命令窗口中输入:cleartdata=0.25 0.5 0.75 1 1.5 2 2.5 3 3.5 4 4.5 5 6 7 8 9 10 11 12 13 14 15 16;ydata=30 68 75 82 82 77 68 68 58 5

5、1 50 41 38 35 28 25 8 15 12 10 7 7 4;c0=1 1 1;for i=1:50;c=lsqcurvefit(Example2_1,c0,tdata,ydata);c0=c;end得到最优解为:c=从而得出拟合曲线: .图形窗口形式(1)利用多项式拟合的交互图命令(GUI)polytool,调用格式为:polytoo(lx,y)其中x,y分别为实验数据构成的向量,例如利用polytool求解例1的MATLAB命令如下:x=-1:0.25:1y=-0.2209,0.3295,0.8826,1.4392,2.0003,2.5645,3.1334,3.7061,4.2

6、836;polytool(x,y)打开多项式拟合的交互式界面,由于要拟合的函数为线性函数,因此在多项式拟合交互式界面中的Degree中输入1,点击导出数据Export,出现保存对话框ExporttoWorkspace,选中Parameters(参数),Residuals(残差)后点击OK,在MATLAB的Workspace窗口中可以看到参数为:和,即拟合函数为Y*。同样如果拟合的函数为二次函数,则只要在Degree中输入2,其它步骤相同,可得拟合函数为:Y*通过查看Residuals(残差)值,可以发现二次函数拟合的残差值比线性函数的要小一些,从拟合的效果看,可以选择二次函数作为拟合函数,但由

7、于线性函数较简单,残差值也很小,从简单出发,也可选择线性函数作为拟合函数。(2)基本拟合界面MATLAB提供了一个方便简洁的拟合界面。具有拟合快速和操作简便的优势,只能拟合多项式。例如用基本拟合界面求解例1的过程如下:clear;close;x=-1:0.25:1;y=-0.2209,0.3295,0.8826,1.4392,2.0003,2.5645,3.1334,3.7061,4.2836;plot(x,y,+);运行结果:在散点图的图形窗口上分别点击菜单档中的ToolsBasic Fitting,在Plots Fits中分别选中linear、quadratic、Show equation

8、s、plot residuals、show norm of residuals,所得拟合直线方程为:y*=2.3x+2;拟合二次多项式为:Y*=0.031x2+2.3x+2(3)曲线拟合工具界面cftool曲线拟合工具界面cftool是一个可视化的图形界面,具有强大的图形拟合功能,下面通过一个具体例子来介绍cftool的用法。例3某生化系学生为研究嘌呤霉素在某项酶促反应中对反应速度与底物浓度之间关系的影响,设计了一个实验,所得的实验数据见表3。根据问题的背景和数据建立一个合适的数学模型,来反映这项酶促反应的速度与底物浓度之间的关系。表3 嘌呤霉素实验中的反应速度与底物浓度数据底物浓度(ppm)

9、x002006011022056110反应速度y764797107123139159152191201207200酶促反应的速度y与底物浓度x之间的关系可用下面两个简单模型描述:Michaelis-Menten模型:y=f(x,)= (4)指数增长模型:y=f(x,)=1(1-e) (5)使用曲线拟合工具界面cftool来确定模型(4)和(5)中的参数,并比较模型(4)、(5)的拟合效果。在MATLAB命令窗口中输入以下语句:clear;close;x=0.02 0.02 0.06 0.06 0.11 0.11 0.22 0.22 0.56 0.56 1.10 1.10;y=76 47 97

10、107 123 139 159 152 191 201 207 200;cftool(x,y);在Curve Fitting Tool对话框中单击Fitting,打开Fitting对话框,点击New fit,在Fit Name:中输入有理函数,在Type of fit中选中Rational,在Numerator中选中linear polynomial,在Denominator中选中linear polynomial,然后点击Apply,完成有理函数拟合。然后,再次点击New fit,在Fit Name:中输入指数函数,在Type of fit中选中Custom Equation,点击New e

11、quation,打开用户自定义方程对话框,点击General Equation,在Equation中输入y=a*(1-exp(-b*x),点击Ok后回到拟合窗口,点击Apply,完成指数函数拟合,参数计算结果见表4。表4 模型(4)、(5)计算结果拟合图为:通过表4可以看出,有理函数(Michaelis-Menten模型)拟合剩余标准差较小,R-square较大(越接近1越好),故用有理函数拟合数据比用指数函数()拟合的效果好。3结束语利用MATLAB的绘图功能和曲线拟合功能,可以很方便地进行多项式拟合和其它非线性曲线拟合,并可以通过比较剩余标准差和可决系数R2的大小,来对比不同曲线的拟合效果。从而在不知

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论