利用MATLAB进行曲线拟合
软件环境:MATLAB2013a
一、多项式拟合
多项式拟合是利用多项式最佳地拟合观测数据,使得在观测数据点处的误差平方和最小。
在MATLAB中,利用函数ployfit和ployval进行多项式拟合。
函数ployfit根据观测数据及用户指定的多项式阶数得到光滑曲线的多项式表示,polyfit的一般调用格式为:P = polyfit(x,y,n)。其中x为自变量,y为因变量,n为多项式阶数。
polyval的输入可以是标量或矩阵,调用格式为
- pv = polyval(p,a)
 - pv = polyval(p,A)
 
其中,p为多项式表示,a为标量,A为矩阵。当输入参数为M*N矩阵A时,函数返回值pv也是M*N矩阵,且pv(i,j) = polyval(p,A(i,j))。
1,多项式拟合示例:对ln(1+x)在[0,1]的采样数据作多项式拟合
(1)对ln(1+x)在[0,1]内采样得到观测数据x、y。
>> x = :0.1:1.0;
>> y = log(+x);
(2)调用函数polyfit对观测数据x、y作三阶多项式拟合。
>> P = polyfit(x,y,)
运行结果如下:

P对应的多项式为0.1079 - 0.3974x + 0.9825x2 + 0.004x3.
(3)分别作拟合曲线和理论曲线
>> xi = :0.01:1.0;
>> yi = polyval(P,xi); %多项式求值
>> plot(x,y,'ro'); %观测数据点
>> hold on;
>> plot(xi,yi,'k'); %作拟合曲线
>> plot(xi,log(+xi),'g'); %理论曲线
>> xlabel('x');
>> ylabel('y');
>> legend('采样数据','拟合曲线','精确曲线');
效果如下:

二、指数函数拟合
1,指数函数拟合示例:对 1 - √x 在[0,1]的采样数据作指数函数拟合。
(1)对 1 - √x 在[0,1]内采样得到观测数据 x、y。
>> x = :0.01:0.99;
>> y = - sqrt(x);
(2)调用函数polyfit对 x 、lny 作一阶多项式拟合。
>> P = polyfit(x,log(y),)
运行结果如下:

(3)求得拟合曲线。
>> yi = exp(polyval(P,x));
(4)分别作观测数据点、拟合曲线和理论曲线。
>> yi = exp(polyval(P,x));
>> plot(x,y,'k.');
>> hold on;
>> plot(x,yi,'r');
>> xlabel('x');
>> ylabel('y');
>> legend('采样数据','拟合曲线');
>> hold off;
运行结果如下:

(5)分析拟合误差。
>> e = yi - y;
>> plot(x,e);
>> xlabel('x');
>> ylabel('误差');
运行结果如下:

三、交互式曲线拟合工具
MATLAB为用户提供了一个交互式曲线拟合工具 Basic Fitting interface。通过该工具,我们无须编写代码就可以完成一些常用的曲线拟合。
(1)载入census data数据。
>> load census
此时MATLAB基本工作空间生成两个double型列向量 cdate 和 pop,cdate 表示1790~1990内10年为间隔的年份,pop为对应年份美国的人口。
>> whos
运行结果如下:

(2)作census data点图。
>> plot(cdate,pop,'ko');
运行结果如下:

(3)在MATLAB的figure中选择Tool → Basic Fitting,即得到Basic Fitting interface 界面。


用户通过Plot fits面板选择不同的曲线拟合方式,为了便于比较,我们可以选择多种拟合方式,从而选择效果最好的一种拟合。
如果某次拟合的效果较差,MATLAB会给出警告,这时用户可以试着通过 Center and Scale X data 改善拟合效果。
如果Show equations复选框被选中,那么图形窗口会显示拟合方程;如果Plot residuals复选框被选中,那么拟合效果将显示误差余量。此外,还可以选择不同的显示类型,如Bar Plot(直方图)、Scatter Plot(散点图)、Line Plot(线图)。
如果Show norm of residuals复选框被选中,那么误差余量图将显示误差余量的范数。
单击
,得到如下界面,通过该界面我们能看到拟合的数值结果:

再次单击
,得到如下界面。通过该界面右侧的面板,我们可以得到任意点处拟合函数的值,如在编辑框中输入 2000:10:2080,并单击Evaluate按钮,计算结果将显示在列表框中。如果Plot evaluated result复选框被选中,那么计算结果将显示在拟合曲线中。

利用MATLAB进行曲线拟合的更多相关文章
- [转] 利用Matlab提取图片中曲线数据
		
原文地址 网易博客 前一段时间看到一篇文章"利用Matlab提取图图片中的数据",觉得思路挺好,遂下载下来研究了一番,发现作者所编写的程序没有考虑原始图片非水 平放置的情况,而实际 ...
 - 利用Matlab生成一个网格化的三维球面(生成直角坐标)
		
利用Matlab生成一个网格化的三维球面,分别对径向方向.经度方向和纬度方向进行网格化,代码如下: %生成一个笛卡尔坐标系下球面网格的x,y,z坐标 %r为球面距离 %nJingdu,nWeidu分别 ...
 - 【转】利用matlab生成随机数函数
		
原文地址:利用matlab生成随机数函数 rand(n):生成0到1之间的n阶随机数方阵 rand(m,n):生成0到1之间的m×n的随机数矩阵 (现成的函数) betarnd:贝塔分布的随机数生成 ...
 - 模式识别:利用MATLAB生成模式类
		
近期開始了模式识别的学习,在此之前须要对模式和模式类的概念有一个了解,这里使用MATLAB实现一些模式类的生成.在此之前,引用百科上对于模式识别和模式类的定义.也算加深以下了解: 模式识别(Patte ...
 - 【caffe-windows】 caffe-master 之 卷积核可视化(利用matlab)
		
此篇是利用matlab对caffemodel的卷积核进行可视化.只介绍了卷积核的可视化,不涉及特征图的可视化. 是参考此博客: http://blog.csdn.net/zb1165048017/ar ...
 - 利用matlab自带函数快速提取二值图像的图像边缘 bwperim函数
		
clear all;close all;clc; I = imread('rice.png'); I = im2bw(I); J = bwperim(I); % 提取二值图像图像边缘 figure ...
 - 利用Matlab快速绘制栅格地图
		
代码演示 % 基于栅格地图的机器人路径规划算法 % 第1节:利用Matlab快速绘制栅格地图 clc clear close all %% 构建颜色MAP图 cmap = [1 1 1; ... % ...
 - Matlab的曲线拟合工具箱CFtool使用简介
		
http://phylab.fudan.edu.cn/doku.php?id=howtos:matlab:mt1-5 一. 单一变量的曲线逼近Matlab有一个功能强大的曲线拟合工具箱 cftool ...
 - 利用matlab摄像机标定
		
(1)输入图像 "Image names"键 Matlab的图形窗口显示出20幅靶标图像 (2) 提取角点 "Extract grid corners"键. 输 ...
 
随机推荐
- rpmverify命令用来验证已安装的rpm软件包的正确性
			
-Va:验证所有软件包: 来自: http://man.linuxde.net/rpmverify -Va:验证所有软件包: [root@DB ~]# rpmverify -Va ....L.... ...
 - how to build jdk 9 source code
			
http://hg.openjdk.java.net/build-infra/jdk9/raw-file/tip/README-builds.html#vs2013 http://royvanrijn ...
 - how-apache-flink-enables-new-streaming-applications-part-1
			
https://data-artisans.com/blog/how-apache-flink-enables-new-streaming-applications-part-1 http://www ...
 - 微信小程序启动过程分析
			
1.微信客户端在打开小程序之前,会把整个小程序的代码包下载到本地. 2.紧接着通过 app.json 的 pages 字段就可以知道你当前小程序的所有页面路径: { "pages" ...
 - vim复制,粘贴,删除,撤销,替换,光标移动等用法
			
我接触linux的时候,用的是nano这个文本编辑器,个人觉得他的最大优点就是方便,快速.打开文件,修改文件,到退出都十分的快速,简单.这一点上比vi,vim要强,但是nano不能显示彩色字,不能进行 ...
 - pthread之线程堆栈
			
转:http://blog.csdn.net/horstlinux/article/details/7666032 //先来讲说线程内存相关的东西,主要有下面几条: //进程中的所有的线程共享相同的地 ...
 - django使用email进行身份验证(转载)
			
版权所有,转载请注明出处:http://guangboo.org/2013/03/27/authentication-using-email-in-django django自带的验证功能免去了我们的 ...
 - Error Installing Tivoli Directory Server (TDS) for TNPMW1.3
			
Install TDS with error "GLPCTL004E Failed to create database instance: 'ldapdb2'." Error ...
 - 【WPF】右键菜单ContextMenu可点击区域太小的问题
			
问题描述 正常使用右键菜单ContextMenu时,如果菜单项是不变的,可以直接在XAML中写死,如下是给一个Button按钮添加了右键菜单功能. <Button Content="T ...
 - EhCache 配置信息
			
How to Size Caches 官方文档:http://ehcache.org/documentation/configuration/cache-size [maxEntriesLocalHe ...