我目前正在尝试编写一些傅里叶变换算法。我从数学定义中描述的简单DFT算法开始:
public class DFT {
public static Complex[] Transform(Complex[] input) {
int N = input.Length;
Complex[] output = new Complex[N];
double arg = -2.0 * Math.PI / (double)N;
for (int n = 0; n < N; n++) {
output[n] = new Complex();
for (int k = 0; k < N; k++)
output[n] += input[k] * Complex.Polar(1, arg * (double)n * (double)k);
}
return output;
}
}
所以我用以下代码测试了这个算法:
private int samplingFrequency = 120;
private int numberValues = 240;
private void doCalc(object sender, EventArgs e) {
Complex[] input = new Complex[numberValues];
Complex[] output = new Complex[numberValues];
double t = 0;
double y = 0;
for (int i = 0; i < numberValues; i++) {
t = (double)i / (double)samplingFrequency;
y = Math.Sin(2 * Math.PI * t);
input[i] = new Complex(y, 0);
}
output = DFT.Transform(input);
printFunc(input);
printAbs(output);
}
转换效果很好,但仅当numberValues是采样频率的倍数时才有效(在本例中为:120、240、360等)。这是我计算240个值的结果:
转换结果正常。
如果我尝试计算280个值,则会得到以下结果:
为什么改变计算值的数量后会得到错误的结果?我不确定我的问题是代码问题还是对DFT数学定义的误解。无论哪种方式,有人能帮助我解决问题吗?谢谢。