目录

1.数据拟合

2.一元多次曲线拟合(线性)

polyfit函数

polyval函数

3.多元多次曲线拟合(线性)

regress函数

4.非线性拟合

lsqcurvefit函数

5.强大的曲线拟合工具

6.优秀论文借鉴


1.数据拟合

数据拟合的思想:已知平面n个点互不相同,寻找f(x),使得f(x)在某种准则下与所有点最接近。

曲线拟合的关键问题:
(1)在何种距离准则下讨论函数和已知点的距离?

(2)如何选择拟合函数f (x)?


(3)如何求解拟合函数?

2.一元多次曲线拟合(线性)

polyfit函数

[P,S,mu]=polyfit(X,Y,m)[P,S]=polyfit(X,Y,m)P=polyfit(X,Y,m)

根据样本数据X和Y,

产生一个m次多项式,系数向量P,及其在采样点误差数据S,

mu是一个二元向量,mu(1)是mean(X),而mu(2)是std(X)。

polyval函数

多项式曲线求值函数,通常和polyval一起用

 y=polyval(p,x)[y,DELTA]=polyval(p,x,s)

1.y=polyval(p,x)为返回对应自变量x在给定系数P的多项式的值。

2.[y,DELTA]=polyval(p,x,s) 使用polyfit函数的选项输出s得出误差估计Y DELTA。它假设polyfit函数数据输入的误差是独立正态的,并且方差为常数。则Y DELTA将至少包含50%的预测值。

例题:

x=0: 0.1: 1;
y=[-0.447, 1.978, 3.11, 5.25, 5.02, 4.66, 4.01, 4.58, 3.45, 5, 35];
p = polyfit(x, y, 3) % 三次多项式拟合
xx = 0: 0.01 : 1;
yy = polyval(p, xx) ; % 根据系数向量p计算在xx点处的函数值
plot(xx, yy, '-b', x, y, 'markersize', 20)%作出yuan

3.多元多次曲线拟合(线性)

regress函数

[B,BINT,R,RINT,STATS] = regress(Y,X)
[B,BINT,R,RINT] = regress(Y,X)
[B,BINT,R] = regress(Y,X)
[B,BINT] = regress(Y,X)
B = regress(Y,X)

返回值解释:

B:回归系数,即未知参数,B(1)为常数项,B(2~……)依次为X每一列(从第二列起)对应的项的系数;
BINT:回归系数的置信区间。(置信区间:当给出某个估计值的95%置信区间为[a, b]时,可以理解为我们有95%的信心可以说样本的平均值介于a到b之间,而发生错误的概率为5%)
R:残差(残差是指观测值与预测值(拟合值)之间的差,即是实际观察值与回归估计值的差)
RINT:残差的置信区间。
STATS:用于检验回归模型的统计量。有4个数值:判定系数R ^2(度量拟合优度的统计量,R²的值越接近1,说明回归直线对观测值的拟合程度越好),F统计量观测值,检验的p的值(p < 0.05时回归模型成立),误差方差的估计。
例子:

x1=[3.91 6.67 5.33 5.56 6.12 7.92 5.82 5.5 5.59 6.12 6.68 6.93]';
x2=[9.43 14.5 15.8 19.8 17.4 23.8 31.6 37.1 36.4 32.2 36.6 41.3]';
X=[ones(12,1), x1, x2];
Y=[280 338 405 432 452 582 596 602 606 621 629 656]';[b,bint,r,rint,stats] = regress(Y,X)
rcoplot(r,rint) % 绘制残差图

残差图:残差图中圆圈是每个数据点的实际残差,横线区间是残差置信区间,置信区间穿过原点说明方程拟合的很好;未通过原点,可视为异常点,比如上图中显示第二组数据未通过原点,因此第二组数据拟合结果较差。

之后可将第二组数据去除后再次进行拟合,得到的结果更为准确。

4.非线性拟合

最小二乘法求解非线性拟合问题!!!

lsqcurvefit函数

x = lsqcurvefit(fun,x0,xdata,ydata)x = lsqcurvefit(fun,x0,xdata,ydata,lb,ub)x = lsqcurvefit(fun,x0,xdata,ydata,lb,ub,options)[x,resnorm,residual,exitflag] = lsqcurvefit(…)

参数解释:

x0为待求参数(初始解向量),初始变量的选取影响最终解
xdata,ydata为用于拟合的数据
lb、ub为解向量的下界和上界lb≤x≤ub,若没有指定界,则lb=[ ],ub=[ ]
fun为待拟合函数,计算x处拟合函数值,其参数一般有两类,一类是目标函数的参数,一类是目标函数的未知数

返回值解释:

  • x为待求参数向量
  • resnorm=sum ((fun(x,xdata)-ydata).^2),即在x处残差的平方和
  • residual=fun(x,xdata)-ydata,即在x处的残差
  • exitflag为终止迭代的条件

例子:

%% y=tcos(kx)e^(wx)
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]';
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.07,0.059,0.08,0.032,-0.015,-0.02]';
f= @(c,x) c(1)*cos(c(2)*x).*exp(c(3)*x);
c0= [0 0 0];
[c, fval]= lsqcurvefit(f, c0, x, y);
xx=0:0.1:20;
yy=f(c, xx);
plot(x, y, 'r*', xx, yy, 'b-');
disp(c);

xdata = [3.6,7.7,9.3,4.1,8.6,2.8,1.3,7.9,10.0,5.4];
ydata = [16,150.5,260.1,22.5,206.5,9.9,2.7,165.5,325.0,54.5];
c0=[ 0 0 0];
f_h=@(c, x) c(1)*x.^2 + c(2)*x.*sin(x) + c(3)*x.^3;
[c, resnorm, r]=lsqcurvefit(f_h, c0, xdata, ydata);%% 绘图
xx=0:0.1:11;
yy=f_h(c, xx);
plot(xdata, ydata, 'r*', xx, yy, 'b-');
disp(c);

5.强大的曲线拟合工具

6.优秀论文借鉴

matlab实现数据拟合

clear;clc
year = 1790:10:2000;
population = [3.9,5.3,7.2,9.6,12.9,17.1,23.2,31.4,38.6,50.2,62.9,76.0,92.0,106.5,123.2,131.7,150.7,179.3,204.0,226.5,251.4,281.4];
plot(year,population,'o')
cftool  % 拟合工具箱
% (1) X data 选择 year
% (2) Y data 选择 population
% (3) 拟合方式选择:Custom Equation (自定义方程)
% (4) 修改下方的方框为:x = f(t) = xm/(1+(xm/3.9-1)*exp(-r*(t-1790)))
% (5) 左边的result一栏最上面显示:Fit computation did not converge:即没有找到收敛解,右边的拟合图形也表明拟合结果不理想
% (6) 点击Fit Options,修改非线性最小二乘估计法拟合的初始值(StartPoint), r修改为0.02,xm修改为500
% 有很多同学有疑惑,初始值为什么要这样设置?我们在未来学习微分方程模型和智能算法的课程时再来给大家介绍这里面蕴含的技巧。
% (7) 此时左边的result一览得到了拟合结果:r = 0.02735, xm = 342.4
% (8) 依次点击拟合工具箱的菜单栏最左边的文件—Generate Code(导出代码到时候可以放在你的论文附录),可以得到一个未命名的脚本文件
% (9) 在这个打开的脚本中按快捷键Ctrl+S,将这个文件保存到当前文件夹。
% (10) 在现在这个文件中调用这个函数得到参数的拟合值和预测的效果
[fitresult, gof] = createFit(year, population)
t = 2001:2030;
xm = 342.4;
r =  0.02735;
predictions = xm./(1+(xm./3.9-1).*exp(-r.*(t-1790)));  % 计算预测值(注意这里要写成点乘和点除,这样可以保证按照对应元素进行计算)
figure(2)
plot(year,population,'o',t,predictions,'.')  % 绘制预测结果图% % 注意:代码文件仅供参考,一定不要直接用于自己的数模论文中
% % 国赛对于论文的查重要求非常严格,代码雷同也算作抄袭

数学建模--(2.2)拟合模型相关推荐

  1. python三次样条插值拟合的树行线_数学建模笔记——插值拟合模型(一)

    啊好像距离上次写作又过了七天,啊好像我之前计划的一周两三篇,啊辣鸡小说毁我青春,啊我是一只可怜的鸽子. 不管怎样,我又回来了,并坚定地更新着hhh.再过两三天就是我们学校数学建模选拔,再过八九天就是期 ...

  2. 数学建模笔记——插值拟合模型(一)

    啊好像距离上次写作又过了七天,啊好像我之前计划的一周两三篇,啊辣鸡小说毁我青春,啊我是一只可怜的鸽子. 不管怎样,我又回来了,并坚定地更新着hhh.再过两三天就是我们学校数学建模选拔,再过八九天就是期 ...

  3. 数学建模笔记——插值拟合模型(二)

    今天是8月21日,距离上次写文章好像将近一个月了--这段时间经历了建模校内选拔赛,考试周,以及与网络小说的斗智斗勇--好吧,其实也没干什么,除了考试就是荒废-- 我最近有在思考一个问题,就是我所关注的 ...

  4. 【数学建模】数据处理问题

    一.插值与拟合 常用于数据的补全以及趋势分析 1.插值 总的思想,就是利用函数f (x)若干已知点的函数值,求出适当的特定函数g(x).这样f(x)其他未知点上的值,就可以用g(x)在这一点的值来近似 ...

  5. Python小白的数学建模课-22.插值方法

    Python小白的数学建模课-22.插值方法 插值.拟合.回归和预测,都是数学建模中经常提到的概念,也经常被混淆. 插值,是在离散数据的基础上补插连续函数,使得插值函数通过全部给定的离散数据点,多用于 ...

  6. Python小白的数学建模课-23.数据拟合全集

    拟合是用一个连续函数(曲线)靠近给定的离散数据,使其与给定的数据相吻合. 数据拟合的算法相对比较简单,但调用不同工具和方法时的函数定义和参数设置有所差异,往往使小白感到困惑. 本文基于 Scipy 工 ...

  7. 数学建模中数据处理类型题目的主要处理流程与方法

    本文首发于zhengfei.xin 文章目录 曲线插值与拟合 一维插值 例题1 二维插值 例题2 曲线拟合 多项式拟合 最小二乘拟合 数值微分与积分 数值积分 数值微分 求解常微分方程 标准形式 sc ...

  8. 清风:数学建模算法、编程和写作培训

    清风:数学建模算法.编程和写作培训 一.评价模型 1.1 层次分析法 1.2 代码详解 1.3 模型拓展 1.4 课后作业 二.插值与拟合模型 三.相关性模型 四.回归模型 五.图论模型 六.分类问题 ...

  9. matlab中离开网格的流量,数学建模【数据处理方法(一维、二维插值方法;数据拟合方法;插值and拟合的MATLAB实现)】...

    [学习网址:MOOC---郑州轻工业大学---数学建模与实验]数学建模专栏 笔记01[第1.2章][概述.软件介绍] 笔记02[第3章][数据处理方法] 笔记03[第4章][规划模型] 笔记04[第5 ...

  10. 数学建模有必要论证“合理性”吗 / 数学建模的合理性怎么写

    前言: 参加过一些数学建模比赛,也顺其自然地读了不少参赛论文,对"数学建模有没有必要论证合理性"这个问题发表一点拙见,欢迎捶我. 回答这个问题:数学建模没必要论证合理性. 原因如下 ...

最新文章

  1. ue4 曲线图实现 蓝图_UE4蓝图解析(一)
  2. React.js 小书 Lesson27 - 实战分析:评论功能(六)
  3. 搭建 LAMP 环境
  4. mysql设计与实现_mysql设计与开发
  5. 大端字节序与小端字节序的转换
  6. Cisco *** 完全配置指南-连载-***概述
  7. AD教程系列 | 4 - 创建集成库文件
  8. 理解稀疏编码sparse coding
  9. 国产高速率CameraLink图像采集卡
  10. ptp4l linux,如何使用PTP4l测试PTPV2协议精度?
  11. Vivado IP核之浮点数加减法 Floating-point
  12. 中国跨境平台出海,产业带依然是最大优势
  13. php上传报未定义偏移量,PHP注意:未定义的偏移量:1,当读取数据时带数组
  14. Python的return语句中使用条件判断
  15. 微信小程序开发部署上线流程
  16. OpenGL入门二——变换
  17. 【报告分享】毕马威阿里研究院:迈向万亿市场的直播电商(附下载)
  18. 66个求职应聘技巧性问答(四)
  19. 恋爱百分百-五十条经典的爱情观
  20. Android手机系统版本号、IMEI、手机厂商、手机型号

热门文章

  1. chatbot使用_如何使用Python构建Chatbot项目
  2. oracle各个版本数据库软件下载方法
  3. 神经网络 - BP神经网络与RBF神经网络模型解决实际问题 - (Matlab建模)
  4. LeetCode695. 岛屿的最大面积———海岛
  5. 舔砖加瓦(java)之异常
  6. Perforce warning:Can't clobber writable file ...
  7. 【深度学习】计算机视觉(一)——认识和基础(上)
  8. Windows安装ADB驱动
  9. week07 13.3 NewsPipeline之 三News Deduper之 tf_idf 查重
  10. Type-C与Type-A、Type-B接口