Python函数:生动解释二维插值函数:griddata()

通常来说,一维插值有很多方法,也比较容易实现。griddata()函数则是可以方便实现二维插值。

例:图中有9个网格点,横坐标为a,纵坐标为b,蓝色的数字是这个点的函数值。

(不好意思,例子比较简单,我直接手画了)

由于整个网格由离散点组成,当我们想知道 (1.5, 1.5) 或者 (2.5, 2.5) 的坐标值的时候,是无法直接获取的,只能通过二维的插值来得到,如下图。

 这个时候就可以采用griddata()函数,代码如下:

import numpy as np
from scipy.interpolate import griddata

a = [1,2,3]
b = [1,2,3]
ans = [4,5,6,3,4,5,2,3,4]
A,B = np.meshgrid(a,b)
# print(A)
# print(B)
X_star = np.hstack((A.flatten()[:,None], B.flatten()[:,None]))
# print(X_star)

m = [1.5,2.5]
n = [1.5,2.5]
M,N = np.meshgrid(m,n)
U = griddata(X_star, ans, (M, N), method='cubic')
print(U)

打印出U,为:

[[4.00000001 5.00000007]
 [2.99999996 3.99999998]]

为了方便检验,其实例子中的函数值就是两个坐标点加一块的值。这四个坐标的正确值应该为4、5、3、4,可以看到插值的结果还挺准确的。

注意事项:此函数只能对在原本网格范围内的点进行插值,超出原本网格范围的值则会被设置为nan。

比如初始的网格是[1,2,3], [1,2,3],而我去插入 (1.5, 999) 处的值,这明显不可能,函数就直接输出nan。

  • 17
    点赞
  • 87
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
griddata函数是一个用于插值函数,可以用于二维或三维散点数据的插值。它有三种形式: 1. vq = griddata(x,y,v,xq,yq) 2. vq = griddata(x,y,z,v,xq,yq,zq) 3. vq = griddata(___,method) 其中,x、y、v是包含分散(非均匀)样本点和数据的向量。x和y表示样本点的坐标,v表示样本点对应的值。xq和yq表示要进行插值的点的坐标,vq表示插值得到的值。method参数表示插值方法,可以是'linear'、'nearest'或'cubic'。 与interp2函数的区别在于,interp2的插值数据必须是矩形域,要求xy规则排列,而griddata可以处理非均匀的样本点。 举个例子,如果有一个采样点分布在经度121-125度,纬度30-34.5度之间的5x5矩阵,采样点采集的是农作物的亩产量数据。现在有一个20x20的矩阵,表示每个点有多少亩这种农作物,需要求矩阵范围内的总产量,就可以使用griddata函数进行插值计算。 具体的使用方法可以参考引用\[1\]和引用\[3\]中的代码示例。 #### 引用[.reference_title] - *1* [Matlab中griddata函数拟合三维散点](https://blog.csdn.net/m0_64007201/article/details/126562100)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MATLAB中griddatagriddatan插值函数简单说明](https://blog.csdn.net/qq_33660295/article/details/110866735)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Python函数生动解释二维插值函数griddata()](https://blog.csdn.net/huozhiran/article/details/120269875)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值