Scipy interp1d 和无穷大
Scipys interp1d and infinities
当使用 scipy.interpolate.interp1d
进行线性插值时,我遇到以下行为:
from scipy.interpolate import interp1d
import numpy as np
x = [0,1,2,3,4]
y = [np.inf, 10, 12, 11, 9]
interpolated_function = interp1d(x,y)
现在当然插值在 [0,1)
中没有明确定义,但在 1
我希望它被定义。然而:
In[2]: interpolated_function(1.)
C:\WinPython27\python-2.7.10\lib\site-packages\
scipy\interpolate\interpolate.py:469:
RuntimeWarning: invalid value encountered in add
y_new = slope*(x_new - x_lo)[:, None] + y_lo
Out[2]: array(nan)
In[3]: interpolated_function(1.000000000000001)
Out[3]: array(10.000000000000002)
这是预期的行为吗? 1
处的插值函数不应该被评估为 10
,因为这是传递给 interp1d
的完全有效的数据点吗?
interp1d
不是特例 nan
s 或 inf
s。对于 kind="linear"
它只是在包含输入值的区间上使用您收到的错误消息中打印的公式。
由于在浮点数中完全相等是不可靠的,通过在 1.0
处对其进行评估,您依赖于将其分类为 (0, 1) 或 (1, 2) 的实现细节。
例如,
In [26]: np.interp(1, x, y)
Out[26]: 10.0
In [32]: interp1d(x, y, kind='slinear')(1.)
Out[32]: array(10.0)
在 scipy 的未来版本中,行为将取决于 fill_value
。 (在当前的开发版本中,您可以使用 fill_value="extrapolate"
。)
最好的办法是在用户端过滤掉非有限数字。
In [33]: x, y = map(np.asarray, (x, y))
In [34]: mask = np.isfinite(x) & np.isfinite(y)
In [35]: ii = interp1d(x[mask], y[mask])
In [36]: ii(1.)
Out[36]: array(10.0)
当使用 scipy.interpolate.interp1d
进行线性插值时,我遇到以下行为:
from scipy.interpolate import interp1d
import numpy as np
x = [0,1,2,3,4]
y = [np.inf, 10, 12, 11, 9]
interpolated_function = interp1d(x,y)
现在当然插值在 [0,1)
中没有明确定义,但在 1
我希望它被定义。然而:
In[2]: interpolated_function(1.)
C:\WinPython27\python-2.7.10\lib\site-packages\
scipy\interpolate\interpolate.py:469:
RuntimeWarning: invalid value encountered in add
y_new = slope*(x_new - x_lo)[:, None] + y_lo
Out[2]: array(nan)
In[3]: interpolated_function(1.000000000000001)
Out[3]: array(10.000000000000002)
这是预期的行为吗? 1
处的插值函数不应该被评估为 10
,因为这是传递给 interp1d
的完全有效的数据点吗?
interp1d
不是特例 nan
s 或 inf
s。对于 kind="linear"
它只是在包含输入值的区间上使用您收到的错误消息中打印的公式。
由于在浮点数中完全相等是不可靠的,通过在 1.0
处对其进行评估,您依赖于将其分类为 (0, 1) 或 (1, 2) 的实现细节。
例如,
In [26]: np.interp(1, x, y)
Out[26]: 10.0
In [32]: interp1d(x, y, kind='slinear')(1.)
Out[32]: array(10.0)
在 scipy 的未来版本中,行为将取决于 fill_value
。 (在当前的开发版本中,您可以使用 fill_value="extrapolate"
。)
最好的办法是在用户端过滤掉非有限数字。
In [33]: x, y = map(np.asarray, (x, y))
In [34]: mask = np.isfinite(x) & np.isfinite(y)
In [35]: ii = interp1d(x[mask], y[mask])
In [36]: ii(1.)
Out[36]: array(10.0)