fft
- 出力の逆FFTを手動で計算しようとしています。私は最初にfft
を使ってデータセットのFFTを計算する次のスクリプトを使用しています。私は手動で逆FFTを見つけようとしますが、それはifft
の結果と似ていません。手動で逆FFTを計算する
あなたは自分のエラーを発見できますか?私は単に
data = [
-0.0005
-0.0004
-0.0003
-0.0002
-0.0001
-0.0000
0.0001
0.0001
0.0001
0.0002
0.0002
0.0002
0.0002
0.0002
0.0002
0.0002
0.0002
0.0002
0.0003
0.0004
0.0005
0.0006
0.0007
0.0009
0.0010
0.0011
0.0011
0.0012
0.0011
0.0011
0.0011
0.0010
0.0011];
delta = 0.0125;
fs = 1/delta;
x = (0:1:length(data)-1)/fs;
X=fft(data);
%find fft
N=length(data);
ws = 2*pi/N;
wnorm = -pi:ws:pi;
wnorm = wnorm(1:length(x));
w = wnorm*fs;
figure(2)
plot(w/(2*pi),abs(fftshift(X)))
%find inverse fft manually
for m=1:length(X)
for k=1:length(data)
X_real(m) = X(k)*exp(i*k*ws*(m-1));
end
end
figure(3)
plot(1:length(data), abs(X_real), 1:length(data), ifft(X))
まず、あなたの 'exp'の部分が実際に正しいかどうか分からないうちに、' m'ごとにX_real(k)の 'sum'が足りなくなりました。 – GameOfThrows
@GameOfThrowsは、X_real(m)= X_real(m)+ exp(i * k * ws *(m-1)); (i * k * ws *(m-1)); '(' X_real'をあらかじめゼロの配列に初期化する必要があるかもしれません) –