MATLAB:插值函数之interp与griddata

MATLAB 提供了多种插值函数来处理不同维度的数据。其中,interp1、interp2 和 griddata 是常用的插值函数,分别用于一维、二维和多维(不规则)数据的插值

之前有对interp1进行过详细介绍,如需详细了解,请查看另一篇博客。

一、函数介绍

下面是这三个函数的用法和实际例子:

1.interp1

功能:对一维数据进行插值。

语法

vq = interp1(x, v, xq)
vq = interp1(x, v, xq, method)
vq = interp1(x, v, xq, method, extrapolation)

参数

  • x: 原始数据的 x 坐标向量。
  • v: 原始数据的值向量。
  • xq: 需要插值的查询点向量。
  • method: 插值方法(可选,默认为 'linear'),如 'linear'(线性插值)、 'nearest'(最近邻插值)、 'spline'(样条插值)等。
  • extrapolation: 外推方法(可选)。
x = 0:10;          % 原始数据点 x
v = sin(x);        % 原始数据的值
xq = 0:0.5:10;     % 查询点
vq = interp1(x, v, xq, 'spline'); % 使用'spline'方法进行插值% 绘图
plot(x, v, 'o', xq, vq, '-');
legend('原始数据', '插值数据');

 

2.interp2

功能:对二维数据进行插值。

语法

Vq = interp2(X, Y, V, Xq, Yq)
Vq = interp2(V, Xq, Yq)
Vq = interp2(..., method)

参数

  • XY: 原始数据的网格坐标矩阵(由 meshgrid 生成)。
  • V: 原始数据值的矩阵。
  • XqYq: 查询点的坐标矩阵。
  • method: 插值方法(可选),如 'linear''nearest''spline''cubic' 等。
[X, Y] = meshgrid(1:5, 1:5);       % 原始数据网格
V = peaks(5);                      % 原始数据值
[Xq, Yq] = meshgrid(1:0.1:5, 1:0.1:5); % 查询点
Vq = interp2(X, Y, V, Xq, Yq, 'cubic'); % 使用“cubic”插值% 绘图
mesh(Xq, Yq, Vq); 
hold on;
plot3(X, Y, V, 'o');  % 添加原始数据点

 

3.griddata

功能:对不规则数据进行插值,并生成规则网格上的插值值。

语法

Vq = griddata(x, y, v, xq, yq)
Vq = griddata(x, y, v, xq, yq, method)
x = rand(10, 1) * 10;       % 随机 x 坐标
y = rand(10, 1) * 10;       % 随机 y 坐标
v = sin(x) + cos(y);        % 原始数据值
[xq, yq] = meshgrid(0:0.1:10, 0:0.1:10); % 查询点网格
vq = griddata(x, y, v, xq, yq, 'cubic'); % 使用“cubic”插值% 绘图
mesh(xq, yq, vq); 
hold on;
plot3(x, y, v, 'o');  % 添加原始数据点

 

二、实践

请绘制电机效率MAP二维图。

题目说是二维图,是应该使用interp1进行插值吗?实际上,电机效率MAP是指电机的效率与转矩和转速的关系,将三维平面投影到了二维图,具体代码如下:

%% 绘制电机效率MAP二维图
clc
clear
% 定义原始数据
n = [300 300 700 700 700 900 900 900 1500 1500 3000 3000 4000 4000 5000 5000 6000 6000 7000 7000];
T = [138 50 328 138 50 328 138 50 138 50 138 50 50 30 50 30 50 30 40 30];
nt = [0.748 0.844 0.749 0.922 0.925 0.794 0.927 0.926 0.922 0.921 0.952 0.941 0.939 0.915 0.898 0.886 0.882 0.879 0.846 0.841];% 创建插值网格
n1 = linspace(300, 7000, 1000);  % 在300到7000之间生成1000个点的数组
T1 = linspace(30, 350, 1000);    % 在30到350之间生成1000个点的数组
[n1, T1] = meshgrid(n1, T1);     % 生成网格矩阵% 对原始数据进行插值以生成网格点上的效率数据
nt1 = griddata(n, T, nt, n1, T1);% 绘制插值后的伪彩色图
pcolor(n1, T1, nt1)
shading interp  % 插值方式显示伪彩色图,让颜色在相邻单元之间平滑过渡hold on  % 保持当前图形,允许在上面添加更多图形% 添加颜色条(色条)
colorbar% 绘制等高线图并设置等高线的数量
[C, h] = contourf(n1, T1, nt1, 7);% 设置x轴和y轴标签
xlabel("转速/(r/min)")
ylabel("转矩/N.m")% 手动添加等高线标签
clabel(C, h, 'manual')

请绘制电机效率MAP三维图 

%% 绘制电机效率MAP三维图
clc
clear
% 定义原始数据
n = [300 300 700 700 700 900 900 900 1500 1500 3000 3000 4000 4000 5000 5000 6000 6000 7000 7000];
T = [138 50 328 138 50 328 138 50 138 50 138 50 50 30 50 30 50 30 40 30];
nt = [0.748 0.844 0.749 0.922 0.925 0.794 0.927 0.926 0.922 0.921 0.952 0.941 0.939 0.915 0.898 0.886 0.882 0.879 0.846 0.841];% 创建插值网格
n1 = linspace(300, 7000, 50);  % 在300到7000之间生成1000个点的数组
T1 = linspace(30, 350, 50);    % 在30到350之间生成1000个点的数组
[n1, T1] = meshgrid(n1, T1);     % 生成网格矩阵% 对原始数据进行插值以生成网格点上的效率数据
nt1 = griddata(n, T, nt, n1, T1);mesh(n1, T1, nt1)
xlabel('转速/(r/min)')
ylabel('转矩/N.m')
zlabel('效率')

 

参考资料:《Matlab编程与汽车仿真应用》 ——崔胜民

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/15329.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

会声会影调速怎么用 会声会影如何调整音频速度

会声会影是一款功能强大的视频编辑软件,可以帮助我们轻松的实现剪辑。 会声会影的操作简单易懂,界面简洁明快。适合家庭使用, 我们使用会声会影可以在家就能将视频剪辑成好莱坞大片。但是在使用的过程中,仍然会遇到一些操作上的问…

洛谷 P3803 【模板】多项式乘法(FFT)

【模板】多项式乘法(FFT) 题目背景 这是一道多项式乘法模板题。 注意:本题并不属于中国计算机学会划定的提高组知识点考察范围。 题目描述 给定一个 n n n 次多项式 F ( x ) F(x) F(x),和一个 m m m 次多项式 G ( x ) G(…

C语言--指针数组和数组指针的区别

指针数组 就是一个数组,由指针构成的数组,每一个元素都是指针,每个指针可以指向不同的内存地址,这些地址可以是数组、变量。 int var1 10; int var2 20; int var3 30;int *ptrArray[3]; // 定义一个指针数组,包含…

2024年上半年软件系统架构师论文【回忆版】

文章目录 考试时间考试地点案例分析1、微服务架构的优点和缺点2、质量属性的6个元素3、分布式锁 Redis的缺点4、MongoDB 存储矢量图的优势 论文回忆版论文一、论单元测试的设计与应用论文二、论大数据模型的设计与应用论文三、论模型驱动的架构设计及应用论文四、论云原生运维的…

Mybatis-Plus-Join

1. 简介 官网 https://mybatisplusjoin.com/ 2. 基本用法 步骤&#xff1a; 添加依赖 <!--mybatis-plus-join--> <dependency><groupId>com.github.yulichang</groupId><artifactId>mybatis-plus-join-boot-starter</artifactId><ve…

探索LangGraph:如何创建一个既智能又可控的航空客服AI

这种设计既保持了用户控制权&#xff0c;又确保了对话流程的顺畅。但随着工具数量的增加&#xff0c;单一的图结构可能会变得过于复杂。我们将在下一节中解决这个问题。 第三部分的图将类似于下面的示意图&#xff1a; 状态定义 首先&#xff0c;定义图的状态。我们的状态和L…

homography原理和图像相似度计算

1. homography 讲homography原理 讲homography应用 2. 图像相似度计算 20230621-计算两幅图像的相似度 20221205-有史以来最全的图像相似度算法 20231112-图像相似度对比方法

C++:List的使用和模拟实现

✨✨✨学习的道路很枯燥&#xff0c;希望我们能并肩走下来! 文章目录 目录 文章目录 前言 一 list的介绍及使用 1.1 list的介绍 1.2 list的使用 1.2.1 list的构造 1.2.2 list iterator的使用 1.2.3 list capacity 1.2.4 list element access 1.2.5 list modifiers …

golang+redis的延时队列

网址 https://github.com/cfanbo/delay-queue-redis 代码结构很简单&#xff0c;简单代表着自由度很高&#xff0c;使用过程中出现问题也很好修改。 我很喜欢这样的代码&#xff0c;至少我看的懂&#xff0c;该有的都有。 //package main // //import ( // "context&q…

leetcode209_长度最小的子数组

要求某个连续的区间内的元素值总和>S . 思路&#xff1a;滑动窗口&#xff1a;本质上是一种双指针法。 &#xff08;1&#xff09;初始化left right 0&#xff1b; &#xff08;2&#xff09;left不动&#xff0c;right移动&#xff0c;扩大窗口&#xff0c;直至符合要…

selinux的安全策略可以影响ntp的方式

SELinux 是一个灵活而强大的模块化安全策略框架&#xff0c;它允许管理员定义和执行非常具体的访问控制策略。这些策略可以限制程序和进程对系统资源的访问&#xff0c;包括文件、网络端口、进程间通信等。 对于NTP&#xff0c;SELinux 策略可以影响以下几个方面&#xff1a; …

网络空间安全数学基础·整除与同余

主要内容&#xff1a; 整除的基本概念&#xff08;掌握&#xff09; 素数&#xff08;掌握&#xff09; 同余的概念&#xff08;掌握&#xff09; 1.1整除 定义&#xff1a;设a&#xff0c;b是任意两个整数&#xff0c;其中b≠0&#xff0c;如果存在一个整数q&#xff0c;使 …

12306技术内幕

公司内部做的一次技术分享 文章目录 12306的成就12306系统特点12306系统难点解决思路产品角度技术角度余票库存的表如何设计&#xff1f; 抢票软件推荐巨人的肩膀 对于未公开的技术部分&#xff0c;只能结合已公开的信息&#xff0c;去做大胆的猜想。 本文提到的一些解决方案&…

SpringBoot + Mybatis-Plus中乐观锁实现

悲观锁 悲观锁是一种悲观思想&#xff0c;它认为数据很可能会被别人所修改 所以总会对数据进行上锁&#xff0c;读操作和写操作都会上锁&#xff0c;性能较低&#xff0c;使用较少&#xff01; 乐观锁 乐观锁是一种乐观思想&#xff0c;它认为数据并不一定会被别人所修改 所以…

成为程序员后我都明白了什么?从入行到弃坑?

作为一个入行近10年的php程序员&#xff0c;真心感觉一切都才刚开始&#xff0c;对计算机&#xff0c;编程语言的理解也好&#xff0c;程序员中年危机也罢&#xff0c;之前都是听别人说的&#xff0c;真的自己到了这个水平&#xff0c;这个年龄才深刻体会到这其中的种种。 我一…

测试基础05:软件测试的分类

课程大纲 1、两种架构&#xff08;Architecture&#xff09; 1.1、B/S&#xff08;Browser/Server&#xff09; 浏览器服务器架构&#xff08;大体3步&#xff09;&#xff1a;用户通过浏览器向服务器发出请求&#xff0c;服务器处理请求&#xff0c;将结果通过网络返回到用户…

使用Webcam实现摄像头的开启和关闭,并保存和复制图片

实现思路 0&#xff0c;将webcam的jar文件传入项目中 1&#xff0c;显示摄像头的地方&#xff1a;创建一个画板&#xff0c;在画板上添加开启和关闭按钮 2&#xff0c;设置开启和关闭功能&#xff1a;创建一个类实现动作监听器&#xff0c;进而实现监听动作按钮 3&#xff…

【数据结构与算法篇】二叉树链式结构及实现

【数据结构与算法篇】二叉树链式结构及实现 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 4. 二叉树链式结构的实现 4.1 前置说明 4.2 二叉树的遍历 4.2.1 前序、中序以及…

通过ssh在本地打开远程服务器的网页

用途 在远程服务器使用jupyter notebook或者tensorboard等时&#xff0c;在本地打开服务器端的网页的方式有很多比如可以使用MobaXterm工具等&#xff0c;此方法可参考https://blog.csdn.net/cc__cc__/article/details/108060618?spm1001.2014.3001.5502。 若直接使用ssh则可…