我如何用这个实现Goertzel算法?

时间:2015-01-21 09:17:28

标签: c# algorithm goertzel-algorithm

我在这里得到了代码: https://naudio.codeplex.com/discussions/270762

goertzel算法是这样的:

    public double goertzel(List<double> sngData, long N, float frequency, int samplerate)
    {
        double skn, skn1, skn2;
        skn = skn1 = skn2 = 0;
        samplerate = this.sampleRate;
        frequency = this.freq;

        double c = 2 * pi * frequency / samplerate;
        double cosan = Math.Cos(c);

        for (int i = 0; i < N; i++)
        {
            skn2 = skn1;
            skn1 = skn;
            skn = 2 * cosan * skn1 - skn2 + sngData[i];
        }

        return skn - Math.Exp(-c) * skn1;
    }

我想使用该算法转换音频数据(来自上面链接中的波形文件阅读器)。我怎样才能做到这一点?感谢

1 个答案:

答案 0 :(得分:0)

如果您正在进行DTMF检测,请尝试&#34; phoneToneDecoder&#34; COM。它会检测声卡中的DTMF音。 (我认为它是专有的)