Butterfly diagram: Difference between revisions
"The Butterfly DIT FFT scheme" is added (nothing else in the text has not been changed); two images were uploaded; citations were added for the clarity of article. |
|||
Line 25: | Line 25: | ||
corresponding to a decimation-in-frequency FFT algorithm. |
corresponding to a decimation-in-frequency FFT algorithm. |
||
== The Butterfly DIT FFT scheme == |
|||
All of DFT's frequency outputs <math>X_k</math> can be computed as the sum of the outputs of two length-N/2 DFTs, of the even-indexed <math>E_k</math> and odd-indexed <math>O_k</math> discrete-time samples, where the odd-indexed short DFT is multiplied by a so-called ''twiddle factor'' |
|||
<ref>{{Cite conference | last1 = Gentleman | first1 = W.M. | last2 = Sande | first2 = G. | title = Fast Fourier Transforms: for fun and profit | booktitle = Proceedings of the fall joint computer conference | pages = 563-578 | year = November 7-10, 1966}}</ref> term <math> W_N^k = e^{-\frac{2\pi i}{N} k}</math>. The equation |
|||
:<math> |
|||
\begin{matrix} X_k & = & \left\{ \begin{matrix} E_k + e^{-\frac{2\pi i}{N}k} O_k & \mbox{if } k < N/2 \\ \\ E_{k-N/2} - e^{-\frac{2\pi i}{N} (k-N/2)} O_{k-N/2} & \mbox{if } k \geq N/2. \end{matrix} \right. \end{matrix} </math> |
|||
is referred as the ''FFT butterfly'' |
|||
<ref>{{Citation |
|||
| last = Chernenko |
|||
| first = Serge |
|||
| title = Fourier volume rendering on the GPU using a split-stream-FFT |
|||
| url=http://www.librow.com/articles/article-10 |
|||
| accessdate = 5 January 2010 }}</ref> |
|||
<ref>{{Cite conference |
|||
| last1 = Jansen |
|||
| first1 = T. |
|||
| last2 = von Rymon-Lipinski |
|||
| first2 = B. |
|||
| last3 = Hanssen |
|||
| first3 = N. |
|||
| last4 = Keeve |
|||
| first4 = E. |
|||
| title = Fast Fourier Transforms: for fun and profit | booktitle = Vision, modeling and visualization | pages = 395--403 | year =2004}}</ref> |
|||
operation and is graphically shown in Fig.1. |
|||
[[Image:DIT-FFT-butterfly1.png|thumb| alt=Fig.1 The FFT butterfly is the most essential operation of the Fast Fourier Transform.| Fig.1 The FFT butterfly is the most essential operation of the Fast Fourier Transform.]] |
|||
Figure 2 illustrates how the FFT algorithm works by showing the implementation of the decimation-in-time FFT. The frequency outputs of the length-N/2 DFT of the even-indexed time samples are denoted <math>E_k</math> and those of the odd-indexed samples as <math>O_k</math>. |
|||
[[Image:DIT-FFT-butterfly.png|thumb|center| alt=Fig.2 Decimation in time of a length-N DFT into two length-N/2 DFTs followed by a combining stage.| Fig.2 Decimation in time of a length-N DFT into two length-N/2 DFTs followed by a combining stage.]] |
|||
Because of the periodicity with N/2 frequency samples of these length-N/2 DFTs, <math>E_k</math> and <math>O_k</math> can be used to compute two of the length-N DFT frequencies, namely <math>X_k</math> and <math>X_{k + N/2}</math> but with different twiddle factor <math>W_N^k</math>. Such a reuse of these short-length DFT outputs gives the FFT its computational savings.<ref>{{Citation |
|||
| last = Jones |
|||
| first = D. |
|||
| title = Decimation-in-time (DIT) Radix-2 FFT, |
|||
| url=http://cnx.org/content/m12016/1.7/ |
|||
|date =Sep 15, 2006 |
|||
| accessdate = 5 January 2010 }}</ref> |
|||
== See also == |
== See also == |
||
Line 72: | Line 31: | ||
== References == |
== References == |
||
{{Unreferenced|date=August 2008}} |
|||
<references/> |
|||
==External links== |
==External links== |
Revision as of 18:21, 5 January 2010
- This article is about butterfly diagrams in FFT algorithms; for the sunspot diagrams of the same name, see Solar cycle.
In the context of fast Fourier transform algorithms, a butterfly is a portion of the computation that combines the results of smaller discrete Fourier transforms (DFTs) into a larger DFT, or vice versa (breaking a larger DFT up into subtransforms). The name "butterfly" comes from the shape of the data-flow diagram in the radix-2 case, as described below. The same structure can also be found in the Viterbi algorithm, used for finding the most likely sequence of hidden states.
Most commonly, the term "butterfly" appears in the context of the Cooley-Tukey FFT algorithm, which recursively breaks down a DFT of composite size into smaller transforms of size where is the "radix" of the transform. These smaller DFTs are then combined with size- butterflies, which themselves are DFTs of size (performed times on corresponding outputs of the sub-transforms) pre-multiplied by roots of unity (known as twiddle factors). (This is the "decimation in time" case; one can also perform the steps in reverse, known as "decimation in frequency", where the butterflies come first and are post-multiplied by twiddle factors. See also the Cooley-Tukey FFT article.)
Radix-2 butterfly diagram
In the case of the radix-2 Cooley-Tukey algorithm, the butterfly is simply a DFT of size 2 that takes two inputs (corresponding outputs of the two sub-transforms) and gives two outputs by the formula (not including twiddle factors):
If one draws the data-flow diagram for this pair of operations, the to lines cross and resemble the wings of a butterfly, hence the name (see also the illustration at right).
More specifically, a decimation-in-time FFT algorithm on inputs with respect to a primitive -th root of unity relies on butterflies of the form:
- ,
where k is an integer depending on the part of the transform being computed. Whereas the corresponding inverse transform can mathematically be performed by replacing with (and possibly multiplying by an overall scale factor, depending on the normalization convention), one may also directly invert the butterflies:
- ,
corresponding to a decimation-in-frequency FFT algorithm.