Difference between quadratic and 2nd order spline interpolation in scipy
我正在编写使用scipy.interpolate函数在python中计算一维插值的函数。 利用文档的帮助,我为三次和三次样条插值编写了2个不同的函数
1 2 3 4 5 6 7 8 9 | # calculate cubic interpolation def linear_interpolation(x): linear = interpolate.interp1d(support_x, support_y, 'cubic') return linear(x) # calculate cubic spline interpolation def cubic_spline_interpolation(x): tck = interpolate.splrep(support_x, support_y) return interpolate.splev(x, tck) |
我对这里的方法有些困惑。 如果我使用
该文档说,("线性","最近","零","线性","二次","三次",其中"线性","二次"和"三次"是指第一,第二或第三样条插值) 顺序),那么为什么我必须为三次样条写不同的函数,而不仅仅是将其更改为
它们在内部都返回相同的样条,尽管内部实现方式不同(与几乎所有Fortran代码的
-
splrep 及其紧密相对的UnivariateSpline是功能更丰富的样条构造例程;它们允许创建非插值样条曲线的平滑参数。 -
如果不需要平滑,则
interp1d 可能更易于使用。
无论如何,这都不是SciPy中唯一的冗余功能实例。添加了新的方法和参数,但保留了旧方法和参数以实现向后兼容。
历史记录:在较旧的SciPy版本(例如0.15.1)中,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | import numpy as np from scipy.interpolate import interp1d, splrep, splev x = np.linspace(0, 6, 7) y = np.array([3, 1, 4, 1, 5, 5, 2]) # some data xx = np.linspace(0, 6, 100) # evaluation points y1 = interp1d(x, y, kind='cubic')(xx) y2 = splev(xx, splrep(x, y, k=3)) print(np.abs(y1-y2).max()) y1 = interp1d(x, y, kind='quadratic')(xx) y2 = splev(xx, splrep(x, y, k=2)) print(np.abs(y1-y2).max()) |
输出显示,这两个例程在典型的数字误差范围内一致。
1 2 | 2.6645352591e-15 1.7763568394e-15 |