原文:https://docs.scipy.org/doc/numpy/reference/generated/numpy.interp.html
校对:(虚位以待)
numpy.
interp
(x, xp, fp, left=None, right=None, period=None)[source]一维线性插值。
将离散数据点处的给定值的函数返回到一维分段线性插值。
参数: | x:array_like
xp:浮点数一维序列
fp:1-D序列的浮点数
左:float,可选
右:float,可选
周期:无或浮动,可选
|
---|---|
返回: | y:float或ndarray
|
上升: | ValueError
|
笔记
不检查x坐标序列xp是否增加。如果xp不增加,结果是无义的。增加的简单检查是:
np.all(np.diff(xp) > 0)
例子
>>> 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()
周期性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])