MATLAB 插值与拟合

MATLAB 插值与拟合一.1维插值函数1.通用接口:进行1维插值:vq=interp1([x,]v,xq[,method,extrapolation)#参数说明: x,v:分别指定样本点的x,y值;x默认为[1,2…length(v)](v为向量)或[1,2…size(v,1)](v为高维数组) #注意:要求x是单调的 xq:指定查询点(即求该点的插值) method:指定插值方法;可为’linear'(默认值;线性插值)/’nearest'(最近邻点插值)/’next'(下1个邻点

大家好,又见面了,我是你们的朋友全栈君。

一.插值
1.1维插值函数
(1)通用接口:

进行1维插值:vq=interp1([x,]v,xq[,method,extrapolation)
  #参数说明:
  	x,v:分别指定样本点的x,y值;x默认为[1,2...length(v)](v为向量)或[1,2...size(v,1)](v为高维数组)
  	  #注意:要求x是单调的
  	xq:指定查询点(即求该点的插值)
  	method:指定插值方法;可为'linear'(默认值;分段线性插值)/'nearest'(最近邻点插值)/'next'(下1个邻点插值)/'previous'(上1个邻点插值)/'pchip'(保形分段3次插值)/'cubic'(保形分段3次插值)/'v5cubic'(用于MATLAB5的3次卷积)/'makima'(修正了Akima公式的3次埃尔米特插值)/'spline'(3次样条插值)
  	  #注意:x等距时可使用快速插值,此时指定method为'*linear'等
  	extrapolation:指定外插策略;可为'extrap'(使用method计算)/标量值(返回该值)/NaN(默认值;返回NaN)
  	  #即当xq落在x外,如何处理
  	vq:返回插值

#实例:
>> x=[1,2,3,4];
>> v=[1,-1,3,9];
>> interp1(x,v,3.5)

ans =

     6

>> v=[1,1,1;-1,-1,-1;3,3,3;9,9,9];
>> interp1(v,3.5)

ans =

     6     6     6

(2)3次样条插值:

进行3次样条插值:s=spline(x,y[,xq])
  #参数说明:
  	x,y:分别指定样本点的x,y值

######################################################################################################################

csape()

(3)分段3次埃尔米特插值(保型分段3次插值):

pchip()

(4)分段多项式插值:

mkpp()

2.2维插值
(1)通用接口:

interp2()

二.拟合
1.1元多项式曲线拟合(Polynomial Curve Fitting):

进行1元多项式曲线拟合:[p,S,mu] = polyfit(x,y,n)
  #参数说明:
  	x,y:分别指定数据的x,y值
  	n:指定多项式的次数
  	p:返回按降幂排列的多项式系数
  	S:返回1个结构体,可用作polyval()的输入来获取误差估计值
  	mu:返回1个二元素向量,mu(1)为mean(x),mu(2)为std(x)
  	  #要求返回mu时,polyfit()会对x进行Z-Score Standarlization,这会改善多项式和拟合算法的数值属性

#实例:
>> polyfit([1,2,3],[1,4,9],1)

ans =

    4.0000   -3.3333

>> [p,S,mu]=polyfit([1,2,3],[1,4,9],1)

p =

    4.0000    4.6667


S = 

  包含以下字段的 struct:

        R: [2×2 double]
       df: 1
    normr: 0.8165


mu =

     2
     1

2.多元线性回归:

进行多元线性回归:[b,bint,r,rint,stats] = regress(y,X[,alpha])
  #设多元线性方程为y=b1*x1+b2*x2+...+bn*xn
  #参数说明:
  	y:指定数据点的y坐标;为column array
  	X:指定数据点的x坐标;为matrix(每列对应1个变量)
  	  #y,X的行数应相等;X(:,1)对应x1,X(:,2)对应x2...;若方程有常数项,应有某列全为1
  	alpha:指定置信水平;默认为0.05
  	  #将使用100*(1-alpha)%置信水平
  	b:返回超平面的各个系数构成的向量
  	  #b(1)为b1,b(2)为b2...
  	bint:返回1个矩阵,其中包含系数估计值的95%置信区间
  	r:返回由残差组成的向量
  	rint:返回1个矩阵,其中包含可用于诊断离群值的区间
  	stats:返回1个向量,其中包含R2统计量/F统计量及其p值,以及误差方差的估计值
  	  #X应包含1个全为1组成的列,以便正确计算模型统计量

3.曲线拟合工具箱(Curve Fitting Toolbox):

>> cftool%见下图

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136219.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Boltzmann Machine 玻尔兹曼机入门

    Boltzmann Machine 玻尔兹曼机入门GenerativeModels生成模型帮助我们生成新的item,而不只是存储和提取之前的item。BoltzmannMachine就是GenerativeModels的一种。Boltzma

    2022年7月4日
    17
  • 常用的17个运维监控系统(必备知识)

    常用的17个运维监控系统(必备知识)1.ZabbixZabbix作为企业级的网络监控工具,通过从服务器,虚拟机和网络设备收集的数据提供实时监控,自动发现,映射和可扩展等功能。Zabbix的企业级监控软件为用户提供内置的Java应用服务器监控,硬件监控,VMware监控和CPU,内存,网络,磁盘空间性能监控。该企业级网络监控工具能够每分钟进行3,000,000次检查,具有更高的安全性和数据中心监控功能。2….

    2022年7月25日
    9
  • MFC进度条编程「建议收藏」

    MFC进度条编程「建议收藏」1.进度条的主要功能进度条控制(ProgressControl)主要用来进行数据读写、文件拷贝和磁盘格式等操作时的工作进度提示情况,如安装程序等,伴随工作进度的进展,进度条的矩形区域从左到右利用当前活动窗口标题条的颜色来不断填充。进度条控制在MFC类库中的封装类为CProgressCtrl,通常仅作为输出类控制,所以其操作主要是设置进度条的范围和当前位置,并不断地更新当前位置。进度条的范

    2022年7月12日
    26
  • Win10 IIS Web服务器安装与配置

    Win10 IIS Web服务器安装与配置这几天课程实训,使用IIS配置服务器,课本上内容太久,老师也没有讲过,自己摸索了一下,所以记录一下安装IIS打开程序和功能,选择左边启用或关闭Windows功能,建议根据下图勾选,确定后等待安装完成打开IIS直接使用Cortana搜索管理工具,打开选择InternetinformationServices(IIS)管理器点击左边栏,在计算机名下,网站文件夹下已经默认存

    2022年5月30日
    42
  • cv2.fitline_pr自动抽帧

    cv2.fitline_pr自动抽帧cv::fitLine用法定义代码示例y=x+1直线y=-x+1直线定义在opencv官方文档定义如下:voidcv::fitLine(InputArraypoints,OutputArrayline,intdistType,doubleparam,doublereps,doubleaeps)#include<opencv2/imgproc.hpp>Fitsalinetoa2Dor3Dpointset.Paramet

    2025年6月5日
    2
  • fbx文件导入3dmax_3d中z轴的值没办法输入

    fbx文件导入3dmax_3d中z轴的值没办法输入本文通过参考网上资源做的一个例子。本程序的功能就是通过xna将3d图像显示到winfrom对他进行旋转操作。首先我们先准备好两个文件夹model文件夹放fbx文件,textures放渲染文件,操作步骤都是添加现有项,准备好资源文件后,先检查下是否有以下引用下面将定义Ga…

    2022年10月9日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号