我一直试图绘制一条线,以及样条拟合。以下是我的代码的通用版本。 'x_coord'和'y_coord'是包含浮点值列表的列表。
import matplotlib.pyplot as plt
from scipy import interpolate as ipl
for a in range(len(x_coord)):
plt.plot(x_coord[a],y_coord[a],label='Label')
yinterp = ipl.UnivariateSpline(x_coord[a],y_coord[a],s=1e4)(x_coord[a])
plt.plot(x_coord[a],yinterp,label='Spline Fit')
虽然我认为这在过去对我有用,但我现在收到一条错误消息:
/.../Library/Enthought/Canopy_64bit/User/lib/python2.7/site-packages/scipy/interpolate/fitpack2.pyc in __init__(self, x, y, w, bbox, k, s, ext)
165
166 data = dfitpack.fpcurf0(x,y,k,w=w,
--> 167 xb=bbox[0],xe=bbox[1],s=s)
168 if data[-1] == 1:
169 # nest too small, setting to maximum bound
error: (m>k) failed for hidden m: fpcurf0:m=0
我见过类似错误消息的情况(例如dfitpack.error: (m>k) failed for hidden m: fpcurf0:m=1),只是在这种特殊情况下似乎存在涉及字典的问题,其中没有一个在我的代码中使用。
对此事的任何建议都将不胜感激。
答案 0 :(得分:6)
您正尝试使用零长度数组
实例化UnivariateSpline
对象
>>> from scipy.interpolate import UnivariateSpline
>>> UnivariateSpline([], [])
<snip>
dfitpack.error: (m>k) failed for hidden m: fpcurf0:m=0
>>>
>>> UnivariateSpline([1], [2])
Traceback (most recent call last):
<snip>
dfitpack.error: (m>k) failed for hidden m: fpcurf0:m=1
错误很可能由this line触发,它将隐藏变量m
设置为x
的长度,并检查您至少有k+1
个点k
1}}是样条度(默认为立方,k = 3)。
>>> spl = UnivariateSpline(range(4), range(4))
>>> spl(2)
array(2.0)