MATLAB自带插值函数

MATLAB自带插值函数一 interp11 函数简介 MATLAB 中的插值函数为 interp1 其调用格式为 yi interp1 x y xi method 其中 x y 为初始插值点 xi 为给定的插值点 yi 为在被插值点 xi 处的插值结果 method 表示采用的插值方法 MATLAB 提供的插值方法有几种 nearest 是最邻近插值 linear 线性插值 sp

一、interp1

1、函数简介

   MATLAB中的插值函数为interp1,其调用格式为:yi= interp1(x,y,xi,’method’),

   其中x,y为初始插值点,xi为给定的插值点,yi为在被插值点xi处的插值结果。

2、用法示例

% 绘制散点图 clc clear close tem=[2 2 0 2 2 2 2 3 5 7 9 10 11 12 12 11 10 9 7 7 6 6 5 5]; time=1:24; plot(time,tem,'o') hold on % 第一种用法 xq=1:0.1:24; vq=interp1(time,tem,xq); plot(xq,vq) %绘制插值曲线 close %第二种用法 % linear 线形(默认) % nearest 临近点 % next 下一个 % previous 前一个 % pchip 保形分段三次插值 % cubic % v5cubic % spline 三次方样条数据插值 % 线性 subplot(2,3,1) xq=1:0.5:24; vq=interp1(time,tem,xq,'linear'); plot(xq,vq,'*') title('linear') % 临近点 subplot(2,3,2) xq=1:0.5:24; vq=interp1(time,tem,xq,'nearest'); plot(xq,vq,'*') title('nearest') % next subplot(2,3,3) xq=1:0.5:24; vq=interp1(time,tem,xq,'next'); plot(xq,vq,'*') title('next') % previous subplot(2,3,4) xq=1:0.5:24; vq=interp1(time,tem,xq,'previous'); plot(xq,vq,'*') title('previous') % pchip subplot(2,3,5) xq=1:0.5:24; vq=interp1(time,tem,xq,'pchip'); plot(xq,vq,'*') title('pchip') % spline subplot(2,3,6) xq=1:0.5:24; vq=interp1(time,tem,xq,'spline'); plot(xq,vq,'*') title('spline'); close % 第三种 取出插值多项式的系数 %v = ppval(pp,xq) 在查询点 xq 处计算分段多项式 pp。 x=0:0.5:2*pi; y=sin(x); p=interp1(x,y,'spline','pp'); %% 返回各个分段插值多项式p的系数 yy=ppval(p,linspace(0,2*pi,101)); plot(x,y,'o',linspace(0,2*pi,101),yy); % 第四种 x=0:0.5:2*pi; y=sin(x); xi=-1:0.2:7; p=interp1(x,y,xi,'spline') ;%插值区间xi超出样本区间x自动外推 p=interp1(x,y,xi,'linear','extrap'); %加上'extrap'自动外推 plot(x,y,'o',xi,p); p=interp1(x,y,xi,'next','extrap'); %加上'extrap'自动外推 p=interp1(x,y,xi,'nearest',9);%令超出范围的数值为9

二、spline三次样条插值

1、函数简介

MATLAB中的插值函数为interp1,其调用格式为:yi= spline(x,y,xi),

其中x,y为初始插值点,xi为给定的插值点,yi为在被插值点xi处的插值结果。

2、用法示例

%第一种 单条曲线插值 x=0:0.5:2*pi; y=sin(x); xx=0:0.1:2*pi; yy=spline(x,y,xx); plot(x,y,'o',xx,yy,'-') close % 第二种 多条曲线插值 x=0:0.5:2*pi; y=[sin(x);cos(x)]; xx=0:0.1:2*pi; yy=spline(x,y,xx); plot(x,y,'o',xx,yy,'-') % 第三种 取出插值多项式的系数 x=0:0.5:2*pi; y=sin(x); p=spline(x,y); %返回各个分段插值多项式p的系数 xx=0:0.1:2*pi; yy=ppval(p,xx); %v = ppval(pp,xq) 在查询点 xx 处计算分段多项式 p。 plot(x,y,'o',xx,yy) 

三、pchip 分段三次 Hermite 插值多项式

1、函数简介

其函数使用方法跟以上的类似,我们这里直接上代码。

2、函数代码

%第一种 x=0:0.5:2*pi; y=sin(x); xx=0:0.1:2*pi; yy=pchip(x,y,xx); plot(x,y,'o',xx,yy,'-') % 第二种 取出插值多项式的系数 x=0:0.5:2*pi; y=sin(x); p=pchip(x,y); xx=0:0.1:2*pi; yy=ppval(p,xx); %v = ppval(pp,xq) 在查询点 xx 处计算分段多项式 pp。 plot(x,y,'o',xx,yy)

 

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

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

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


相关推荐

  • 国产FPGA现状_fpga未来发展前景

    国产FPGA现状_fpga未来发展前景原文:https://www.sohu.com/a/229245757_132567来源:内容来自财通证券TMT组,谢谢。2018年上半年对于中国半导体行业而言是多事之秋,发生了几件让国人深入思考的大事。我作为IC产业的逃兵,最近也在思考很多的问题,包括资本市场、集成电路行业和研究所的一些不成熟的想法。2008年进入华中科技大学电子系,中科院半导体所毕业后进入联发科从事手机芯片开发(没错,就是卖的不怎么好的X30)。离开MTK之前有一段小插曲,招我进联发科的老大后来自己出来创业做安防芯片,当时喊

    2022年4月19日
    46
  • 播放.avi后缀视频报出0xc00d5212,编码格式不支持

    播放.avi后缀视频报出0xc00d5212,编码格式不支持以avi后缀的格式视频文件,在win10系统上播放可能会报如下如下错误:最普遍的现象就是高版本Windows媒体播放器播放不了采用早期编码编辑的AVI格式视频,而低版本Windows媒体播放器又播放不了采用最新编码编辑的AVI格式视频解决方案:这里我总结了两种方案:第一种:安装一个插件名字叫格式工厂,这款插件可以很好的支持大批量的文件格式转换,它会把avi视频转换成mp4格式视频,…

    2022年9月30日
    6
  • 系统安装失败如何恢复原系统_安装失败显示其他原因

    系统安装失败如何恢复原系统_安装失败显示其他原因按照博客上的方法安装了npm,但是安装cnpm出现了“cnpm不是内部命令”那么我就详细的来说下解决方法;1,node.js的安装在node.js官网下载,根据你电脑的选择版本,我的安装路径是D盘,D:\ProgramFiles\nodejs输入npm-v检测是否安装成功。2.安装cnpmnpminstall-gcnpm–registry=https://registry.npm.taobao.org(注意要对环境变量配置)在系统变量path下添加该路径D:\Prog

    2022年10月15日
    3
  • docker的常用命令汇总_常用docker命令

    docker的常用命令汇总_常用docker命令文章目录Docker命令总结Docker命令总结还在百度Docker命令?推荐一套我用起来特顺手的命令!简介:Docker是一个开源的应用容器引擎,让开发者可以打包应用及依赖包到一个可移植的镜像中,然后发布到任何流行的Linux或Windows机器上。使用Docker可以更方便地打包、测试以及部署应用程序。Docker镜像官网阿里云镜像中心Docker环境安装:#安装yum-utilsyuminstall-yyum-utilsdevice-mapper-persistent-dat

    2022年9月18日
    2
  • maven学习笔记—–jar查找groupid、artifactid

    maven学习笔记—–jar查找groupid、artifactid在 pom xml 文件中加入我们需要 jar 包的依赖 往往不知道是哪个目录下的 也就是 groupid 是什么 解决方法如下 http mvnrepositor com 登录该网站 输入你想引入的 jar 包 然后根据结果集点击进去 举例比如说 hibernate commons annotations 点击进去看到页面最上面一行如下所示 home org hibernate hiber

    2025年7月12日
    2
  • 3万计算机配置清单,电脑组装知识网预算2万至3万元电脑主机推荐九代酷睿i9-9900K搭RTX2080Ti全能型高配电脑主机配置清单…

    3万计算机配置清单,电脑组装知识网预算2万至3万元电脑主机推荐九代酷睿i9-9900K搭RTX2080Ti全能型高配电脑主机配置清单…本文转自:http://www.dn010.com/peizhi/710.html近日,一位网友联系了小编,说他要配一套高配置的电脑主机,主机预算约为2万至3万元,针对该网友的预算要求,小编提供一套九代酷睿i9-9900K搭RTX2080Ti全能型高配电脑主机配置清单,用户还可根据自己的喜好调整电脑配置。电脑配置清单:注意:由于更新电脑硬件的速度更快,如果产品停产,请使用新产品。另外,硬件价格会随…

    2022年7月16日
    17

发表回复

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

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