软件环境: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。

  1. >> x = :0.1:1.0;
  2. >> y = log(+x);

(2)调用函数polyfit对观测数据x、y作三阶多项式拟合。

  1. >> P = polyfit(x,y,)

运行结果如下:

P对应的多项式为0.1079 - 0.3974x + 0.9825x+ 0.004x3.

(3)分别作拟合曲线和理论曲线

  1. >> xi = :0.01:1.0;
  2. >> yi = polyval(P,xi); %多项式求值
  3. >> plot(x,y,'ro'); %观测数据点
  4. >> hold on;
  5. >> plot(xi,yi,'k'); %作拟合曲线
  6. >> plot(xi,log(+xi),'g'); %理论曲线
  7. >> xlabel('x');
  8. >> ylabel('y');
  9. >> legend('采样数据','拟合曲线','精确曲线');

效果如下:

二、指数函数拟合

1,指数函数拟合示例:对 1 - √x 在[0,1]的采样数据作指数函数拟合。

(1)对 1 - √x 在[0,1]内采样得到观测数据 x、y。

  1. >> x = :0.01:0.99;
  2. >> y = - sqrt(x);

(2)调用函数polyfit对 x 、lny 作一阶多项式拟合。

  1. >> P = polyfit(x,log(y),)

运行结果如下:

(3)求得拟合曲线。

  1. >> yi = exp(polyval(P,x));

(4)分别作观测数据点、拟合曲线和理论曲线。

  1. >> yi = exp(polyval(P,x));
  2. >> plot(x,y,'k.');
  3. >> hold on;
  4. >> plot(x,yi,'r');
  5. >> xlabel('x');
  6. >> ylabel('y');
  7. >> legend('采样数据','拟合曲线');
  8. >> hold off;

运行结果如下:

(5)分析拟合误差。

  1. >> e = yi - y;
  2. >> plot(x,e);
  3. >> xlabel('x');
  4. >> ylabel('误差');

运行结果如下:

三、交互式曲线拟合工具

MATLAB为用户提供了一个交互式曲线拟合工具 Basic Fitting interface。通过该工具,我们无须编写代码就可以完成一些常用的曲线拟合。

(1)载入census data数据。

  1. >> load census

此时MATLAB基本工作空间生成两个double型列向量 cdate 和 pop,cdate 表示1790~1990内10年为间隔的年份,pop为对应年份美国的人口。

  1. >> whos

运行结果如下:

(2)作census data点图。

  1. >> 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进行曲线拟合的更多相关文章

  1. [转] 利用Matlab提取图片中曲线数据

    原文地址 网易博客 前一段时间看到一篇文章"利用Matlab提取图图片中的数据",觉得思路挺好,遂下载下来研究了一番,发现作者所编写的程序没有考虑原始图片非水 平放置的情况,而实际 ...

  2. 利用Matlab生成一个网格化的三维球面(生成直角坐标)

    利用Matlab生成一个网格化的三维球面,分别对径向方向.经度方向和纬度方向进行网格化,代码如下: %生成一个笛卡尔坐标系下球面网格的x,y,z坐标 %r为球面距离 %nJingdu,nWeidu分别 ...

  3. 【转】利用matlab生成随机数函数

    原文地址:利用matlab生成随机数函数 rand(n):生成0到1之间的n阶随机数方阵  rand(m,n):生成0到1之间的m×n的随机数矩阵 (现成的函数) betarnd:贝塔分布的随机数生成 ...

  4. 模式识别:利用MATLAB生成模式类

    近期開始了模式识别的学习,在此之前须要对模式和模式类的概念有一个了解,这里使用MATLAB实现一些模式类的生成.在此之前,引用百科上对于模式识别和模式类的定义.也算加深以下了解: 模式识别(Patte ...

  5. 【caffe-windows】 caffe-master 之 卷积核可视化(利用matlab)

    此篇是利用matlab对caffemodel的卷积核进行可视化.只介绍了卷积核的可视化,不涉及特征图的可视化. 是参考此博客: http://blog.csdn.net/zb1165048017/ar ...

  6. 利用matlab自带函数快速提取二值图像的图像边缘 bwperim函数

      clear all;close all;clc; I = imread('rice.png'); I = im2bw(I); J = bwperim(I); % 提取二值图像图像边缘 figure ...

  7. 利用Matlab快速绘制栅格地图

    代码演示 % 基于栅格地图的机器人路径规划算法 % 第1节:利用Matlab快速绘制栅格地图 clc clear close all %% 构建颜色MAP图 cmap = [1 1 1; ... % ...

  8. Matlab的曲线拟合工具箱CFtool使用简介

    http://phylab.fudan.edu.cn/doku.php?id=howtos:matlab:mt1-5 一. 单一变量的曲线逼近Matlab有一个功能强大的曲线拟合工具箱 cftool ...

  9. 利用matlab摄像机标定

    (1)输入图像 "Image names"键 Matlab的图形窗口显示出20幅靶标图像 (2) 提取角点 "Extract grid corners"键. 输 ...

随机推荐

  1. FFmpeg(6)-通过av_find_best_stream()来获取音视流的索引

    也可以通过av_find_best_stream()函数来获取流的索引: 例: audioStream = av_find_best_stream(ic, AVMEDIA_TYPE_AUDIO, -, ...

  2. 在ZP的HA模式下 JM 重启失败

    https://issues.apache.org/jira/browse/FLINK-10030 https://issues.apache.org/jira/browse/FLINK-10011 ...

  3. 每日英语:Are Smartphones Turning Us Into Bad Samaritans?

    In late September, on a crowded commuter train in San Francisco, a man shot and killed 20-year-old s ...

  4. 01_MUI之Boilerplate中:HTML5演示样例,动态组件,自己定义字体演示样例,自己定义字体演示样例,图标字体演示样例

     1安装HBuilder5.0.0,安装后的界面截图例如以下: 2 依照https://www.muicss.com/docs/v1/css-js/boilerplate-html中的说明,创建上 ...

  5. for语句查看js对象

    for (var obj in o.curform) { document.write("<p>" + obj + " = " + o.curfor ...

  6. [Linux]基本I/O重定向

    在我们设置定时任务的时候经常会使用标准输出和标准错误输出.这个在Linux是一个非常重要的概念,而且这个很有用.程序应该有数据库的来源端.数据的目的端,以及报告问题的地方,它们被称为标准输入.标准输出 ...

  7. Spring高级装配(二) 条件化的bean

    如果你希望一个bean在特定的条件下才会出现: 应用的类路径下包含特定的库时才创建 只有当某个特定的bean也声明之后才会创建 某个特定的环境变量设定之后才创建某个bean 在Spring 4之前,很 ...

  8. java获取上周任意一天的日期

    /** * 获取上周周几的日期,默认一周从周一开始 * @param dayOfWeek * @param weekOffset * @return */ public static Date get ...

  9. led子系统

    最简单的led驱动就是从端口输出0或1来关闭或点亮灯.而我们这里讲的led子系统,主要是对led事件进行了分装和优化,这里我们主要讲的是可 以实现跨平台的led驱动.不管你是使用三星的平台,还是Atm ...

  10. C/C++中的static关键字详解

    C++的static有两种用法:面向过程程序设计中的static和面向对象程序设计中的static.前者应用于普通变量和函数,不涉及类:后者主要说明static在类中的作用.一.面向过程设计中的sta ...