numpy.interp#

numpy.interp(x, xp, fp, left=None, right=None, period=None)[源]#

对单调递增的样本点进行一维线性插值。

返回具有给定离散数据点 (xp, fp) 的函数的(在 x 处求值的)一维分段线性插值器。

参数:
xarray_like

要求值的一维坐标。

xp一维浮点数序列

数据点的 x 坐标,如果未指定 period 参数,则必须递增。否则,xp 在使用 xp = xp % period 对周期边界进行归一化后会被内部排序。

fp一维浮点数或复数序列

数据点的 y 坐标,与 xp 长度相同。

left与 fp 对应的可选浮点数或复数

返回 x < xp[0] 的值,默认为 fp[0]

right与 fp 对应的可选浮点数或复数

返回 x > xp[-1] 的值,默认为 fp[-1]

periodNone 或浮点数,可选

x 坐标的周期。此参数允许对角度 x 坐标进行正确插值。如果指定了 period,则会忽略 leftright 参数。

返回:
y浮点数或复数(对应于 fp)或 ndarray

插值后的值,形状与 x 相同。

引发:
ValueError

如果 xpfp 长度不同。如果 xpfp 不是一维序列。如果 period == 0

警告

x 坐标序列应递增,但这并未明确强制执行。但是,如果序列 xp 非递增,则插值结果无意义。

请注意,由于 NaN 是不可排序的,因此 xp 也不能包含 NaN。

一个简单的检查 xp 是否严格递增的方法是:

np.all(np.diff(xp) > 0)

另请参阅

scipy.interpolate

示例

>>> import numpy as np
>>> xp = [1, 2, 3]
>>> fp = [3, 2, 0]
>>> np.interp(2.5, xp, fp)
1.0
>>> np.interp([0, 1, 1.5, 2.72, 3.14], xp, fp)
array([3.  , 3.  , 2.5 , 0.56, 0.  ])
>>> UNDEF = -99.0
>>> np.interp(3.14, xp, fp, right=UNDEF)
-99.0

绘制正弦函数的插值图

>>> x = np.linspace(0, 2*np.pi, 10)
>>> y = np.sin(x)
>>> xvals = np.linspace(0, 2*np.pi, 50)
>>> yinterp = np.interp(xvals, x, y)
>>> import matplotlib.pyplot as plt
>>> plt.plot(x, y, 'o')
[<matplotlib.lines.Line2D object at 0x...>]
>>> plt.plot(xvals, yinterp, '-x')
[<matplotlib.lines.Line2D object at 0x...>]
>>> plt.show()
../../_images/numpy-interp-1_00_00.png

带周期性 x 坐标的插值

>>> x = [-180, -170, -185, 185, -10, -5, 0, 365]
>>> xp = [190, -190, 350, -350]
>>> fp = [5, 10, 3, 4]
>>> np.interp(x, xp, fp, period=360)
array([7.5 , 5.  , 8.75, 6.25, 3.  , 3.25, 3.5 , 3.75])

复数插值

>>> x = [1.5, 4.0]
>>> xp = [2,3,5]
>>> fp = [1.0j, 0, 2+3j]
>>> np.interp(x, xp, fp)
array([0.+1.j , 1.+1.5j])