插值方法(一维插值、三次样条插值、二维插值的matlab自带函数,python实现/作图)

2023-05-16

  • 数模比赛中,常常需要根据已知的函数点进行数据、模型的处理和分析,而有时候现有的数据是极少的,不足以支撑分析的进行,这时就需要使用一些数学的方法,“模拟产生”一些新的单又比较靠谱的值来满足需求,这就是插值的作用。
  • 插值法在数值分析课程中有详细介绍。

一维插值函数

  • y = interp1(x0, y0, x, ‘menthod’)
  • **method **指定插值的方法,默认为线性插值。其值可为:
‘nearest’最近项插值
‘linear’线性插值
‘spline’立方样条插值
‘cubic’立方插值
  • 当 x0 为等距时可以用快速插值法,使用快速插值法的格式为‘*nearest’, ‘*linear’, ‘*spline’, ‘*cubic’

三次样条插值

  1. y = interp1(x0, y0, x, ‘spline’)
  2. y = spline(x0, y0, x)
  3. pp = csape(x0, y0, conds)
  4. pp = csape(x0, y0, conds, valconds); y = fnal(pp, x)
  • 对于三次样条插值,提倡使用函数 csape 。
  • condas: csape默认边界条件为Lagrange边界条件,其值可为:
‘complete’一阶导数
‘not-a-knot’非扭结条件(没有边界条件)
‘periodic’周期条件
'second‘二阶导数
  • valconds默认导数值 [ 0, 0 ]

例1

  • 给出下表数据,需要得到 x 坐标每改变0.1时的y坐标,并画出曲线。用分段线性和三次样条插值方法计算。
x035791112131415
y01.21.72.02.12.01.81.21.01.6

matlab求插值

x0=[0   3   5   7   9   11   12   13   14  15];
y0=[0  1.2  1.7  2.0  2.1  2.0  1.8  1.2   1.0  1.6];
x = 0:0.1:15;
y1 = interp1(x0,y0,x);%默认线性插值
y2 = interp1(x0,y0,x,'spline');%三次样条插值
pp1=csape(x0,y0);%边界条件为Lagrange条件
y3=fnval(pp1,x);

subplot(1,3,1)
plot(x0,y0,'+',x,y1)
title('Piecewise linear')

subplot(1,3,2)
plot(x0,y0,'+',x,y2)
title('Spline1')

subplot(1,3,3)
plot(x0,y0,'+',x,y3)
title('Spline2')

image.png

python求插值

import numpy as np
from scipy import interpolate #插值
import matplotlib.pyplot as plt #Pyplot 是 Matplotlib 的子库,提供了和 MATLAB 类似的绘图 API。Pyplot 是常用的绘图模块,能很方便让用户绘制 2D 图表。
x0 = np.array([0, 3, 5, 7, 9, 11, 12, 13, 14, 15])
y0 = np.array([0, 1.2, 1.7, 2.0, 2.1, 2.0, 1.8, 1.2, 1.0, 1.6])
x1 = np.arange(0, 15, 0.1)#numpy.arange(start, stop, step, dtype)  np.linspace(start, stop, num=50, endpoint=True, retstep=False, dtype=None)
plt.figure(figsize=(8, 6))#创建一个8*6点(point)的点图

###将图作在一张图上
for method in [ "slinear", "cubic"]:  # 插值方式
    f = interpolate.interp1d(x0, y0, kind=method) #一维数据的插值运算可以通过方法 interp1d() 完成。kind=method指插值方法
    y1 = f(x1)#得到插值结果
    plt.plot(x1, y1, label=method)
plt.plot(x0,y0,'o',label="datas")
plt.title('Interpolation')
plt.legend(loc="lower right")#图例的位置
plt.show()

###3张子图
i=1
for method in [ "slinear", "cubic"]:  # 插值方式
    f = interpolate.interp1d(x0, y0, kind=method) #一维数据的插值运算可以通过方法 interp1d() 完成。kind=method指插值方法
    y1 = f(x1)#得到插值结果
    plt.subplot(1, 3, i)
    plt.plot(x1, y1)
    plt.title(method)
    i=i+1
plt.subplot(1, 3, i)
plt.plot(x0,y0,'o-')
plt.title("Piecewise linear")
plt.suptitle('Interpolation')
plt.show()

image.png image.png

二维插值

插值节点为网格节点

  • 已知 m × n 个 节 点 : ( x i , y j , z i j ) ( i = 1 , . . . , m , j = 1 , . . . , n ) , 且 x 1 < . . . < x m , y 1 < . . . < y n m\times n个节点:(x_i,y_j,z_{ij})(i=1,...,m,j=1,...,n),且x_1<...<x_m,y_1<...<y_n m×n(xi,yj,zij)(i=1,...,m,j=1,...,n)x1<...<xm,y1<...<yn。求点 ( x , y ) 处 的 插 值 。 (x,y)处的插值。 (x,y)
  • z = interp2( x0, y0, z0, x, y, ’ method ') 注意:x0, y0分别是m维和n维向量,z0是n×m矩阵。x是M维行向量,y是N维列向量,z是N×M矩阵
  • 三次样条插值** pp = csape( {x0, y0}, z0, conds, valconds), z=fnval(pp, {x, y})** 注意:x0, y0分别是m维和n维向量,z0是m×n矩阵。x是M维向量,y是N维向量,z是M×N矩阵

例2

  • 在一丘陵地带测量高程, x x x y y y方向每隔100m 测一个点,得到高程表如下,试插值一个曲面,确定合适的模型,并由此找到最高点和该点的高程。

image.png

matlab求解

clear,clc
x=100:100:500;
y=100:100:400;
z=[636    697    624    478   450  
   698    712    630    478   420
   680    674    598    412   400
   662    626    552    334   310];

xi=100:10:500;yi=100:10:400;
pp=csape({x,y},z');
cz=fnval(pp,{xi,yi});
[i,j]=find(cz==max(max(cz)));
disp(["最高点的地址:" num2str([xi(i),yi(j)])]);
disp(["最高点的高程:" num2str(cz(i,j))]);
[X,Y]=meshgrid(xi,yi);
surf(X,Y,cz')
"最高点的地址:"    "170  180"
"最高点的高程:"    "720.6252"

image.png

python求解

import numpy as np
from scipy import interpolate #插值
import matplotlib.cm as cm #曲面的配色
import matplotlib.pyplot as plt #绘图
from mpl_toolkits.mplot3d import Axes3D #3D图

x0, y0 = np.mgrid[100:500:5j, 100:400:4j]#生成网格图5*4,5j代表5段,没有j代表间距为5
z0 = np.array([636, 697, 624, 478, 450,
               698, 712, 630, 478, 420,
               680, 674, 598, 412, 400,
               662, 626, 552, 334, 310]).reshape((4, 5))
z0=z0.T#注意z是5*4

f = interpolate.interp2d(x0, y0, z0, kind='cubic')#由样本点生成三次样条插值
x1 = np.linspace(100, 500, 100)#np.linspace(start, stop, num=50)
y1 = np.linspace(100, 400, 100)
z1 = f(x1, y1)#插值结果

x1, y1 = np.meshgrid(x1, y1)
fig = plt.figure()
ax=Axes3D(fig)#3D对象
#ax=fig.add_subplot(111,projection='3d')
#ax= plt.subplot(1, 2, 1, projection='3d')
surf = ax.plot_surface(x1, y1, z1, rstride=1, cstride=1,
                         cmap=cm.coolwarm, linewidth=0.5, antialiased=True)#rstride行之间的跨度,cstride列之间的跨度cmap颜色映射表,默认是“rainbow”
plt.title('Interpolation-2D(The peak: {:3f})'.format(np.max(z1)))
ax.scatter(x0,y0,z0,c='r')#三维散点图
ax.contour(x1, y1, z1,zdir='z',offset=300)#投影到z平面的z=300上
ax.set_zlabel('Z')  # 坐标轴
ax.set_ylabel('Y')
ax.set_xlabel('X')
plt.colorbar(surf, shrink=0.5, aspect=5)
plt.show()

#最高点处的地址
x1[np.where(z1==np.max(z1))] #array([144.44444444])
y1[np.where(z1==np.max(z1))] #array([200.])

image.png

插值节点为散乱节点

  • 已知 n n n个节点, ( x i , y i , z i ) , i = 1 , 2 , . . . , n (x_i,y_i,z_i),i=1,2,...,n (xi,yi,zi),i=1,2,...,n,求点 ( x , y ) (x,y) (x,y)处的插值 z z z
  • ZI = griddata(x, y, z, XI, YI ) 注意:x y z 均为n维向量,指明所给数据点的横坐标、纵坐标和竖坐标;向量XI YI是给定的网格点的横坐标和纵坐标,一个是行向量,另一个是列向量;返回值ZI 为网格(XI,YI)处的函数值。

例3

  • 下表是海底水深数据,在适当矩形区域内画出海底曲面的图形。

image.png

matlab求解

clc, clear
clc, clear
x=[129,140,103.5,88,185.5,195,105,157.5,107.5,77,81,162,162,117.5];
y=[7.5,141.5,23,147,22.5,137.5,85.5,-6.5,-81,3,56.5,-66.5,84,-33.5];
z=-[4,8,6,8,6,8,8,9,9,8,8,9,4,9];
xmm=minmax(x);  %求x的最小值和最大值
ymm=minmax(y);  %求y的最小值和最大值
xi=xmm(1):xmm(2);
yi=ymm(1):ymm(2);
zi1=griddata(x,y,z,xi,yi','cubic'); %立方插值
zi2=griddata(x,y,z,xi,yi','nearest'); %最近点插值
zi=zi1;  %立方插值和最近点插值的混合插值的初始值
zi(isnan(zi1))=zi2(isnan(zi1));  %把立方插值中的不确定值换成最近点插值的结果
subplot(1,2,1), plot(x,y,'*');
subplot(1,2,2), mesh(xi,yi,zi);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

插值方法(一维插值、三次样条插值、二维插值的matlab自带函数,python实现/作图) 的相关文章

  • django 管理站点导航侧边栏搞砸了

    我最近在我的项目中添加了一个包并做了一个pip freeze gt requirements txt然后 然后我做了pip install r requirements txt到我的本地 它添加了一个侧边栏 I did a pip inst
  • 计时器显示负的已用时间

    我正在使用一个非常简单的代码来计算每个循环的时间for陈述 它看起来像这样 import time for item in list of files Start timing this loop start time clock Do a
  • 嵌套重组 - Django

    我有一个包含以下字段的模型 日期 员工 和 计划时间 每个员工对于不同的日期都有不同的计划工作时间 我正在尝试构建我的模板 其中员工按行列出 他们的计划工作时间列在正确的相应日期下的列中 像这样的东西 https i stack imgur
  • Windows 中的信号处理

    在Windows中 我试图创建一个等待SIGINT信号的python进程 当它收到SIGINT时 我希望它只打印一条消息并等待SIGINT的另一次出现 所以我使用了信号处理程序 这是我的 signal receiver py 代码 impo
  • 使用 theano 进行多处理

    我正在尝试将 theano 与 cpu 多处理和神经网络库 Keras 结合使用 I use device gpu标记并加载 keras 模型 然后 为了提取超过一百万张图像的特征 我使用多处理池 该函数看起来像这样 from keras
  • 解析器生成

    我正在做一个项目软件抄袭检测 我打算用C语言来做这件事 因为我应该创建一个令牌生成器和一个解析器 但我不知道从哪里开始 任何人都可以帮助我解决这个问题 我创建了一个令牌数据库 并将令牌与我的程序分开 接下来我想做的就是比较两个程序以查明它是
  • 如何在Redis中从hmset()切换到hset()?

    我收到弃用警告 即 Redis hmset 已弃用 请改用 Redis hset 但是 hset 采用第三个参数 我不知道是什么name应该是 info users 10 timestamp datetime utcnow strftime
  • 在 Django 中上传文件

    我在 Django 1 6 版本 中上传文件时遇到问题 当我尝试做的时候new file data save 在我的views py 中我收到此错误 quiz patent 22 medical record 2 exams 处的属性错误
  • BeautifulSoup 抓取街道地址

    我正在使用最底部的代码来获取weblink 以及清真寺名称 不过我也想得到面值 and 街道地址 请帮助我被困住了 目前我得到以下信息 Weblink div class subtitleLink a href http www salat
  • 为什么 PySpark 中的 agg() 一次只能汇总 DataFrame 的一列? [复制]

    这个问题在这里已经有答案了 对于下面的数据框 df spark createDataFrame data Alice 4 300 Bob 7 677 schema name High 当我尝试找到最小值和最大值时 我只得到输出中的最小值 d
  • 显示多索引 pandas 数据帧的前 10 行

    我有一个多级索引 pandasDataFrame第一级在哪里year第二级是username 我只有一列已经按降序排序 我想显示每个索引级别 0 的前 2 行 我拥有的 count year username 2010 b 677 a 50
  • Python Pandas:将参数传递给 agg() 中的函数

    我试图通过使用不同类型的函数和参数值来减少 pandas 数据框中的数据 但是 我无法更改聚合函数中的默认参数 这是一个例子 gt gt gt df pd DataFrame x 1 np nan 2 1 y a a b b gt gt g
  • Google App Engine 开发服务器中的 PyCrypto“ImportError:无法导入名称 blockalgo”

    我有一个使用 PyCrypto 使用 AES 加密字符串的函数 当我在单元测试中调用该函数时 一切正常 在生产环境中 它也运行得很好 但是 在GAE开发服务器上调用该函数时 会抛出错误 ImportError 无法导入名称blockalgo
  • Django:通过外键将两个表连接到第三个表?

    我有三个型号 class A Model class B Model id IntegerField a ForeignKey A class C Model id IntegerField a ForeignKey A 我想要得到 B i
  • 如何检查两个数据集的匹配列之间的相关性?

    如果我们有数据集 import pandas as pd a pd DataFrame A 34 12 78 84 26 B 54 87 35 25 82 C 56 78 0 14 13 D 0 23 72 56 14 E 78 12 31
  • 使用每日频率格式化 x 轴

    我正在尝试获取每日数据图 我有 3 个月的数据 每天都很难指出 如何格式化 x 轴 以便我可以获得每个日期 可以使用以下命令更改主要刻度的频率set major locator mdates DayLocator interval 5 如下
  • Twitter 不再使用请求库 python

    我有一个 python 函数 它使用 requests 库和 BeautifulSoup 来抓取特定用户的推文 import requests from bs4 import BeautifulSoup contents requests
  • 如何在Python中从stdin中逐行读取

    每个人都知道如何在 C 中计算 STDIN 中的字符 但是 当我尝试在 python3 中执行此操作时 我发现这是一个难题 计数器 py import sys chrCounter 0 for line in sys stdin readl
  • 在Python中:检查文件修改时间是否早于特定日期时间

    我用 C 编写了以下代码来检查文件是否已过期 DateTime lastTimeModified file getLastTimeModified if lastTimeModified HasValue File does not exi
  • Python正则表达式:如何用不同的值替换出现的每个实例?

    假设我有这个字符串 s blah blah blah 使用Python正则表达式 如何用不同的值替换 blah 的每个实例 例如 我有一个值列表v 1 2 3 你可以使用re sub打回来 http docs python org libr

随机推荐

  • ES6模块化及ES7新增特新性

    一 babel ES6代码转换为ES5的代码 1 初始化项目 npm init npm init y 不需要配置 xff0c 直接跳过 2 安装转码工具 cnpm install g babel cli cnpm install save
  • GNU Radio中的消息传递机制(Message Passing)

    目录 0 首先看下 GR 中一些常用术语的官方解释 1 定义理解 2 消息传递端口API 3 消息处理函数 4 通过流程图连接消息 5 从外部源发布数据 6 使用消息传送命令 7 一个消息传输的例子 0 首先看下 GR 中一些常用术语的官方
  • 单片机零基础完整攻略-1

    序 xff1a 学习原因 在网上看到各路大神用一个小小的板子就能玩起来一些很有趣的小项目 xff0c 觉得非常之神奇 为什么一个小小的板子就能做到物联网 xff0c 机器人那么多花里胡哨的功能 xff1f 正好赶上学校开设了这门课 xff0
  • HDF5 header version与HDF5 library不匹配问题的解决

    如图 xff1a 试着安装这个 conda install c conda forge hdf5 61 1 10 5 conda不行用pip 还不行就去这个网站下载 xff0c 上面搜索框直接搜hdf5 xff0c 然后找1 10 5版本的
  • Vscode C++的基础配置文件以及无法产生可编译文件exe的处理方法(undefined reference)

    采用排除法 xff1a 1 是否将工作文件夹添加工作区 xff1f 打开vscode 文件 打开文件夹 文件 将文件夹添加工作区 xff08 或者另存为一个 xff09 xff0c 把工作区文件放到工作文件夹里 如下 xff1a Manag
  • Arduino零基础实践2——串口数据发送

    具体的原理在微机开发中详细介绍了 xff0c 下面直接使用arduino进行数据收发 13条消息 单片机攻略4 中断和串口 r135792uuuu的博客 CSDN博客 void setup Serial begin 9600 void lo
  • px4开发bug记录

    一 仿真问题 1 roslaunch无法启动px4 gazebo的无人机仿真 xff0c 但是make px4 sitl gazbeo可以正常启动 2 make px4 sitl gazbeo启动到一半无法启动 xff0c 显示无法连接ga
  • linux无损扩容

    linux笔记本上空间不够用了 xff0c 重新从windows里划分30个g出来给linux xff0c 记录一下 1 准备u盘 xff0c u盘里面全部清空 xff0c 不能有任何东西 下载一个Ubuntu的桌面文件 xff0c 大概有
  • Linux更新源 source.list 自定义第三方源

    1 官方默认源 打开软件和更新 xff0c 直接图形化操作 但是只能设置一个源 xff0c 对于下载多种多样的包可能不够 xff0c 所以需要自定义多个不同源 2 自定义添加源 源的文件 sources list在 etc apt sour
  • 现在没有可用的软件包 *** ,但是它被其它的软件包引用了 和 E: 无法定位软件包 ***问题解决

    root 64 zhouls virtual machine snort src apt get install bison flex 正在读取软件包列表 完成 正在分析软件包的依赖关系树 正在读取状态信息 完成 现在没有可用的软件包 fl
  • sdf文件轨范

    sdf文件规范 xff1a a href https www zhihu com org aigraphx posts page 61 3 title 深圳季连AIGRAPHX 知乎 深圳季连AIGRAPHX 知乎 a span style
  • HBase基本操作

    HBase Java API 操作 Tips xff1a 其实每一个操作都可以简化为 xff1a 1 配置并连接数据库 2 编写 Java API 的 HBase 的操作 3 使用权限 执行操作 要对一个Hbase数据库进行操作的话 xff
  • GNU Radio3.8:编辑yaml文件的方法

    GNU Radio 学习使用 OOT 系列教程 xff1a GNU Radio3 8创建OOT的详细过程 基础 C 43 43 GNU Radio3 8创建OOT的详细过程 进阶 C 43 43 GNU Radio3 8创建OOT的详细过程
  • input上传图片并且实现预览

    文章目录 前言一 确定思路二 书写代码1 HTML部分2 CSS部分3 JS部分 xff08 重点 xff09 3 1 点击选择图片按钮 xff0c 调用input文件框事件的的代码3 2 转换格式3 3 发送图片给后端 三 编写优化1 i
  • hashcode()和equals()方法详解

    hashcode 和equals 方法详解 1 何为hashcode hash是一个函数 xff0c 就是通过一种算法来得到一个hash值 通过hash算法得到的hash值就存放在这张hash表中 xff0c 也就是说hash表示所有的ha
  • ubuntu安装kvm

    kvm是linux下的虚拟机 文章目录 一 电脑硬件支持二 安装ubuntu三 安装kvm 一 电脑硬件支持 首先不用多说啦 xff0c 既然是虚拟机 xff0c 当然要自己的机器支持虚拟技术 xff0c 重启机器进入biso xff0c
  • 类的静态(static)成员

    有时候类需要它的一些成员与类本身直接相关 xff0c 而不是与类的各个对象保持关联 xff08 这意味着无论创建多少个类的对象 xff0c 静态成员都只有一个副本 xff09 我们通过在成员的声明前加上关键字static使得其与类关联在一起
  • Keil uvision5 介绍

    keil 5 Keil uvision5 安装过程Keil uvision5安装包1 Keil uvision5 介绍2 Keil uVision5 特点3 Keil uVision5 功能4 Keil uVision5 快捷键 Keil
  • px4仿真时,/mavros/state现实连接不上

    仿真时 xff0c 使用px4 xff0c 启动 PX4 Firmware launch文件中的launch文件 进入gazebo世界中 xff0c 通过 xff1a rostopic list 查看发布的话题 xff0c 并且打印 mav
  • 插值方法(一维插值、三次样条插值、二维插值的matlab自带函数,python实现/作图)

    数模比赛中 xff0c 常常需要根据已知的函数点进行数据 模型的处理和分析 xff0c 而有时候现有的数据是极少的 xff0c 不足以支撑分析的进行 xff0c 这时就需要使用一些数学的方法 xff0c 模拟产生 一些新的单又比较靠谱的值来