我正在使用 Goertzel 算法来获得某个频率的幅度。我现在正试图从中获得灵态,但我不知道如何。
有人可以解释一下,并告诉我如何从这段代码中获取某个 f 的相位吗?
另外,我将它用于 16khz,采样率为 44.1。我可以运行它的最小样本长度是多少?
double AlgorithmGoertzel( int16_t *sample,int sampleRate, double Freq, int len )
{
double realW = 2.0 * cos(2.0 * M_PI * Freq / sampleRate);
double imagW = 2.0 * sin(2.0 * M_PI * Freq / sampleRate);
double d1 = 0;
double d2 = 0;
double y;
for (int i = 0; i < len; i++) {
y=(double)(signed short)sample[i] +realW * d1 - d2;
d2 = d1;
d1 = y;
}
double rR = 0.5 * realW *d1-d2;
double rI = 0.5 * imagW *d1-d2;
return (sqrt(pow(rR, 2)+pow(rI,2)))/len;
}