高速フーリエ変換(FFT)の計算式の原理・意味

この記事では、高速フーリエ変換(FFT)の公式と原理について入門者向けに紹介します。

高速フーリエ変換(FFT)

コンピュータでフーリエ変換を実装する場合、離散フーリエ変換を利用します。
しかし、離散フーリエ変換は計算量が多く、処理時間が掛かるという欠点があるためあまり実用的ではありません。
そこで、実際には計算量の少ない「高速フーリエ変換(FFT:Fast Fourier Transform)」が用いられます。
高速フーリエ変換では、回転子W^kn_Nの「周期性」「指数性」を使って、計算式の結合・分解を行い、計算量を削減します。

(1)   \begin{eqnarray*} W^{kn}_N=W^{kn\pm mN}\\ W^{kn}_N=W^l_NW^{k-l}_N \end{eqnarray*}

計算量の比較

離散フーリエ変換(DFT)と高速フーリエ変換(FFT)の計算量を比較します。
離散信号のサンプル数がNのときの計算回数を以下にまとめました。

乗算回数 加算回数
DFT N^2 N(N-1)
FFT Nlog_2(N) Nlog_2(N)

特に乗算はコンピュータにとって重い処理なので、この回数をN^2からNlog_2(N)に削減できることは大きな利点です。
ただし、FFTはサンプル数Nが2のべき乗の時にしか利用できません。

実装例・関連記事

フーリエ変換の原理に関してはこちら
フーリエ変換の原理・意味
逆フーリエ変換の原理・意味
離散フーリエ変換の原理・意味
高速フーリエ変換の原理・意味
【フーリエ変換】サンプリング周波数とナイキスト周波数の関係性・違い
実装例に関してはこちら
Python FFTの実装例, IFFTの実装例, パワースペクトル解析の実装例, ローパスフィルタでノイズ除去
C言語
C# FFTの実装例

コメント

  1. わたる より:

    分かりやすいサイトをありがとうございます。勉強させていただいております。
    離散フーリエ変換(DFT)と高速フーリエ変換(FFT)の計算量についてですが、他のサイトなどではFFTの乗算回数が(N/2)log2_Nと書かれているものが多いのですが、筆者の先生はどのような計算や参考資料でこちらの式を求められましたか?ご回答いただけますと幸いです。