- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不明白 interpolate.splrep
函数是如何工作的。简单的代码不会抛出任何错误,但 interpolate.splev
会返回意外结果。
degree = 4;
arg = np.linspace(0, 2.0 * np.pi, 1000);
val = np.sin(arg);
m = arg.size - degree - 1;
step = (arg[-1] - arg[0]) / (m + 1);
knots = np.linspace(step, m * step, m);
f = interpolate.splrep(arg, val, k=degree, s=0, t=knots, per=0);
x = 0.123456;
print interpolate.splev(x, f) - np.sin(x);
此代码打印 2.81341438303e+118
,但如果我更改参数 per
,代码运行良好:
...
f = interpolate.splrep(arg, val, k=degree, s=0, t=knots, per=1);
...
结果是 -1.80411241502e-16
。你能解释一下结果吗?不是bug吗?
最佳答案
参数 per
切换周期性边界条件 (pbc)。似乎没有 pbc 拟合不会收敛,但是有 pbc 就可以了。您还可以在绘制数据和样条拟合结果时看到:它只会在边界处发散,数据集的其余部分拟合得很好!
documentation of the function interpolate.splrep
说明具有偶数度的组合不是一个好主意。您有 degree = 4
(偶数)和 s = 0
。
看来你定义了很多结! B 样条是分段拟合。如果你有很多结,每个样条函数将只对非常小的一部分点有效。您有 1000 个横坐标点和 995 海里/小时。样条必须适用的点越少,函数的自由度就越大,因此如果您需要的点很少,样条几乎可以是任何东西...
将行 m = arg.size - degree - 1;
更改为 m = arg.size - degree - 20;
已经产生
>>> print interpolate.splev(x, f) - np.sin(x);
3.08053624276e-10
没有 pbc!
所以,问问自己为什么要这样计算结数!要么你坚持使用它并引入 pbc,即 per=1
,要么你稍微减少结的数量。两者都将稳定拟合并实现收敛!
关于python - 使用指定节点插值 interpolate.splrep — 意外结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27612458/
使用 scipy 的 splrep我可以很容易地适应测试正弦波: import numpy as np from scipy.interpolate import splrep, splev impo
我有一组数据点,想用样条函数对它们进行近似。我使用了两个不同的函数: splrep 来自 scipy 和我发现的三次样条函数here . 结果看起来像this . 代码如下: from matplot
从视频记录中可以提取行人穿过瓶颈的头部轨迹。因为,行人在移动轨迹时会摇摆,所以我想消除这种令人讨厌的振荡。 (平滑算法与本题无关) 结果显示在这个 figure 中。 因此,我的目标是使用蓝点(称为零
我不明白 interpolate.splrep 函数是如何工作的。简单的代码不会抛出任何错误,但 interpolate.splev 会返回意外结果。 degree = 4; arg = np.lin
我正在编写以下代码,非常基础,只是在 scipy.interpolate 中调用 splrep。但是它会在数据集上抛出错误。 代码如下 x_nodesTrial = np.array([ 1321.,
我需要在 x-y 平面中定义的一维线上拟合由三阶多项式组成的样条线。多项式的导数在关节处必须相等。预期输出是三阶多项式列表,由它们的起点(样条结)及其多项式系数定义。 我认为 scipy 的 splr
我正在使用 scipy.interpolate.splrep 进行三次样条插值,如下所示: import numpy as np import scipy.interpolate x = np.lin
使用一些实验数据,我无法终生弄清楚如何使用 splrep 创建 B 样条曲线。数据在这里:http://ubuntuone.com/4ZFyFCEgyGsAjWNkxMBKWD 摘录如下: #Dept
我正在尝试将三次样条拟合到一组给定的点。我的积分没有排序。我无法对这些点进行排序或重新排序,因为我需要该信息。 但由于函数 scipy.interpolate.splrep 仅适用于非重复和单调递增的
我有一个关于 scipy 的 splrep 函数的问题,我认为这是一个错误,所以我将发布每段代码,以便您可以在您的计算机上重现它。假设我想找到一些数据的 b 样条表示,例如,通过以下代码获得的数据,它
scipy.interpolate.splrep(x, y, w=None, xb=None, xe=None, k=3, task=0, s=None, t=None, full_output=0,
[原始问题] 我需要一个曲线方程,它根据以下数据随着时间的推移无限增加。如何获得? [问题更新] 我需要为 scipy.interpolate.splrep 指定正确的参数。有人可以帮忙吗? 还有,有
我有一个 data set第一列是x数据(波长),第二列是y数据(相对强度)。 我希望将它插值到另一个 x_new-data 但我的问题是 splrep 返回 nan-values: >>import
我是一名优秀的程序员,十分优秀!