特定の周波数の振幅を取得するために Goertzel アルゴリズムを使用しています。私は今、そこからフェーズを取得しようとしていますが、方法がわかりません。
誰かが説明して、このコードから特定の f の位相を取得する方法を教えてもらえますか?
また、サンプルレート44.1で16khzまで使用しています。実行できるサンプルの最小の長さはどれくらいですか?
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;
}