在python

时间:2016-05-10 17:46:06

标签: python octave gaussian oct2py

我试图让一些固定宽度的高斯人适应一个宽阔的高峰。我能够做到这一点的唯一方法是使用peakfit.m。样本数据可以下载here

在八度音程中,我使用的代码是:

>>peakfit(data,90.5,3,3,11,0,0,0,0,[1,1,1],0,0)
ans =
  1.0000e+000  9.0012e+001  1.0185e+004  1.0000e+000  1.0749e+004
  2.0000e+000  9.0500e+001  9.3075e+003  1.0000e+000  9.9035e+003
  3.0000e+000  9.0988e+001  1.0186e+004  1.0000e+000  1.0749e+004

这些非常接近我用于创建初始数据集的三个峰值。

这是我使用oct2py时的结果

import oct2py as op
import numpy as np

data=np.loadtxt(file)

octave=op.Oct2Py()
octave.peakfit(data,90.5,3,3,11,0,0,0,0,[1,1,1],0,0)

#Out:
array([[    1,    91,  8873,     1, 14583],
       [    2,    88, 17314,     1,   400],
       [    3,    90, 11011,     1, 18459]])

如果我在两种情况下都适合单个峰值,结果是相同的。

八度

 1.0000e+000  9.0500e+001  2.0576e+004  1.4670e+000  3.2130e+004

Oct2py

array([[  1.00000000e+00,   9.05000004e+01,   2.05763986e+04,
          1.46695147e+00,   3.21304879e+04]])

差异来自哪里?

1 个答案:

答案 0 :(得分:1)

我找到了解决方案。 我必须将oct2py中的参数作为浮点数传递给

octave.peakfit(data,90.5,3.0,3.0,11.0,0.0,0.0,0.0,0.0,[1.0,1.0,1.0],0.0,0.0)