当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Python SciPy interpolate.LinearNDInterpolator用法及代码示例


本文简要介绍 python 语言中 scipy.interpolate.LinearNDInterpolator 的用法。

用法:

class  scipy.interpolate.LinearNDInterpolator(points, values, fill_value=np.nan, rescale=False)#

N > 1 维的分段线性插值。

参数

points ndarray 浮点数,形状(npoints,ndims);或德劳内

数据点坐标的二维数组,或预先计算的 Delaunay 三角剖分。

values 浮点数或复数的 ndarray,形状(npoints,...),可选

N-D 点数据值数组。沿第一个轴的值的长度必须等于点的长度。与某些插补器不同,插补轴无法更改。

fill_value 浮点数,可选

用于填充输入点凸包之外的请求点的值。如果未提供,则默认值为 nan

rescale 布尔型,可选

在执行插值之前将点重新缩放到单位立方体。如果某些输入维度具有不可比较的单位并且相差许多数量级,这将很有用。

注意

插值是通过使用 Qhull [1] 对输入数据进行三角剖分来构造的,并在每个三角形上执行线性重心插值。

注意

对于常规网格上的数据,请改用 interpn

参考

例子

我们可以在 2D 平面上插值:

>>> from scipy.interpolate import LinearNDInterpolator
>>> import numpy as np
>>> import matplotlib.pyplot as plt
>>> rng = np.random.default_rng()
>>> x = rng.random(10) - 0.5
>>> y = rng.random(10) - 0.5
>>> z = np.hypot(x, y)
>>> X = np.linspace(min(x), max(x))
>>> Y = np.linspace(min(y), max(y))
>>> X, Y = np.meshgrid(X, Y)  # 2D grid for interpolation
>>> interp = LinearNDInterpolator(list(zip(x, y)), z)
>>> Z = interp(X, Y)
>>> plt.pcolormesh(X, Y, Z, shading='auto')
>>> plt.plot(x, y, "ok", label="input point")
>>> plt.legend()
>>> plt.colorbar()
>>> plt.axis("equal")
>>> plt.show()
scipy-interpolate-LinearNDInterpolator-1.png

相关用法


注:本文由纯净天空筛选整理自scipy.org大神的英文原创作品 scipy.interpolate.LinearNDInterpolator。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。