Jump to content

Butterfly diagram: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Fixed broken link
 
(74 intermediate revisions by 47 users not shown)
Line 1: Line 1:
{{Short description|Computation process in mathematical algorithms}}
[[Image:Butterfly-FFT.png|thumb|200px|right|Data-flow diagram connecting the inputs ''x'' (left) to the outputs ''y'' that depend on them (right) for a "butterfly" step of a radix-2 Cooley-Tukey FFT. This diagram resembles a [[butterfly]] (as in the [[Morpho (butterfly)|Morpho butterfly]] shown for comparison), hence the name.]]
{{about|butterfly diagrams in FFT algorithms|sunspot diagrams|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 transform]]s (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.


[[Image:Butterfly-FFT.png|thumb|200px|right|[[Signal-flow graph]] connecting the inputs ''x'' (left) to the outputs ''y'' that depend on them (right) for a "butterfly" step of a radix-2 Cooley–Tukey FFT. This diagram resembles a [[butterfly]] (as in the [[Morpho (genus)|morpho butterfly]] shown for comparison), hence the name, although in some countries it is also called the hourglass diagram.]] In the context of [[fast Fourier transform]] algorithms, a '''butterfly''' is a portion of the computation that combines the results of smaller [[discrete Fourier transform]]s (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.<ref name=Oppenheim89>Alan V. Oppenheim, Ronald W. Schafer, and John R. Buck, ''Discrete-Time Signal Processing'', 2nd edition (Upper Saddle River, NJ: Prentice Hall, 1989)</ref> The earliest occurrence in print of the term is thought to be in a 1969 [[Massachusetts Institute of Technology|MIT]] technical report.<ref>{{Cite report |author=C. J. Weinstein |date=1969-11-21 |title=Quantization Effects in Digital Filters |url=https://www.ll.mit.edu/sites/default/files/publication/doc/quantization-effects-digital-filters-weinstein-tr-468.pdf |publisher=[[MIT Lincoln Laboratory]] |page=42 |quote=This computation, referred to as a 'butterfly' }}</ref><ref>{{cite web |url=https://mathoverflow.net/q/98804 |title=FFT and Butterfly Diagram|last= Cipra |first= Barry A. |author-link = Barry A. Cipra|date=2012-06-04 |website=mathoverflow.net |access-date=2015-02-10}}</ref> 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 [[recursion|recursively]] breaks down
Most commonly, the term "butterfly" appears in the context of the [[Cooley–Tukey FFT algorithm]], which [[recursion|recursively]] breaks down a DFT of [[composite number|composite]] size ''n''&nbsp;=&nbsp;''rm'' into ''r'' smaller transforms of size ''m'' where ''r'' is the "radix" of the transform. These smaller DFTs are then combined via size-''r'' butterflies, which themselves are DFTs of size ''r'' (performed ''m'' times on corresponding outputs of the sub-transforms) pre-multiplied by [[root of unity|roots of unity]] (known as [[twiddle factor]]s). (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.)
a DFT of [[composite number|composite]] size <math>n = r m</math> into
<math>r</math> smaller transforms of size <math>m</math> where
<math>r</math> is the "radix" of the transform. These smaller DFTs are then
combined with a size-<math>r</math> butterflies, which themselves are DFTs of size
<math>r</math> (performed <math>m</math> times on corresponding outputs of the
sub-transforms) pre-multiplied by [[root of unity|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 comes first and are post-multiplied by twiddle factors. See also the Cooley-Tukey FFT article.)


==Radix-2 butterfly diagram==
==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 (''x''<sub>0</sub>,&nbsp;''x''<sub>1</sub>) (corresponding outputs of the two sub-transforms) and gives two outputs (''y''<sub>0</sub>,&nbsp;''y''<sub>1</sub>) by the formula (not including [[twiddle factor]]s):

:<math>y_0 = x_0 + x_1 \, </math>
:<math>y_1 = x_0 - x_1. \, </math>

If one draws the data-flow diagram for this pair of operations, the (''x''<sub>0</sub>,&nbsp;''x''<sub>1</sub>) to (''y''<sub>0</sub>,&nbsp;''y''<sub>1</sub>) lines cross and resemble the wings of a [[butterfly]], hence the name (see also the illustration at right).

[[Image:DIT-FFT-butterfly.svg|thumb|300px|right|A decimation-in-time radix-2 FFT breaks a length-''N'' DFT into two length-''N''/2 DFTs followed by a combining stage consisting of many butterfly operations.]]
More specifically, a radix-2 decimation-in-time FFT algorithm on ''n''&nbsp;=&nbsp;2<sup>&nbsp;''p''</sup> inputs with respect to a primitive ''n''-th root of unity <math>\omega^k_n = e^{-\frac{2\pi i k}{n}}</math> relies on O(''n''&nbsp;log<sub>2</sub>&nbsp;''n'') butterflies of the form:

:<math>y_0 = x_0 + x_1 \omega^k_n \, </math>
:<math>y_1 = x_0 - x_1 \omega^k_n, \, </math>

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 ''&omega;'' with ''&omega;''<sup>&minus;1</sup> (and possibly multiplying by an overall scale factor, depending on the normalization convention), one may also directly invert the butterflies:

:<math>x_0 = \frac{1}{2} (y_0 + y_1) \, </math>
:<math>x_1 = \frac{\omega^{-k}_n}{2} (y_0 - y_1), \, </math>

corresponding to a decimation-in-frequency FFT algorithm.


==Other uses==
In the case of the radix-2 Cooley-Tukey algorithm, the butterfly is simply a
The butterfly can also be used to improve the randomness of large arrays of partially random numbers, by bringing every 32 or 64 bit word into causal contact with every other word through a desired hashing algorithm, so that a change in any one bit has the possibility of changing all the bits in the large array.<ref>*{{Citation | last1=Press | first1=WH | last2=Teukolsky | first2=SA | last3=Vetterling | first3=WT | last4=Flannery | first4=BP | year=2007 | title=Numerical Recipes: The Art of Scientific Computing | edition=3rd | publisher=Cambridge University Press | publication-place=New York | isbn=978-0-521-88068-8 | chapter=Section 7.2 Completely Hashing a Large Array | chapter-url=http://apps.nrbook.com/empanel/index.html#pg=358 | access-date=2011-08-13 | archive-date=2011-08-11 | archive-url=https://web.archive.org/web/20110811154417/http://apps.nrbook.com/empanel/index.html#pg=358 | url-status=dead }}</ref>
DFT of size 2 that takes two inputs <math>(x_0, x_1)</math> (corresponding outputs of the two sub-transforms) and gives two
outputs <math>(y_0, y_1)</math> by the formula (not including twiddle
factors):


== See also ==
:<math>y_0 = x_0 + x_1</math>
* [[Mathematical diagram]]
:<math>y_1 = x_0 - x_1</math>
* [[Zassenhaus lemma]]
* [[Signal-flow graph]]


== References ==
If one draws the data-flow diagram for this pair of operations, the
<references/>
<math>(x_0, x_1)</math> to <math>(y_0, y_1)</math> lines cross and resemble
somewhat the wings of a [[butterfly]], hence the name. (See also the illustration at right.)


==External links==
==External links==
* [http://www.relisoft.com/Science/Physics/fft.html explanation of the FFT and butterfly diagrams].
* [https://web.archive.org/web/20060423170713/http://www.relisoft.com/science/Physics/fft.html explanation of the FFT and butterfly diagrams].
* [http://www.cmlab.csie.ntu.edu.tw/cml/dsp/training/coding/transform/fft.html butterfly diagrams of various FFT implementations (Radix-2, Radix-4, Split-Radix)].
* [http://astron.berkeley.edu/~jrg/ngst/fft/fftbutfy.html explanation of butterfly diagrams specifically].
<!-- dead link * [http://astron.berkeley.edu/~jrg/ngst/fft/fftbutfy.html explanation of butterfly diagrams specifically].-->


[[Category:FFT algorithms]]
[[Category:FFT algorithms]]
[[Category:Diagrams]]

Latest revision as of 02:34, 9 December 2024

Signal-flow graph connecting the inputs x (left) to the outputs y that depend on them (right) for a "butterfly" step of a radix-2 Cooley–Tukey FFT. This diagram resembles a butterfly (as in the morpho butterfly shown for comparison), hence the name, although in some countries it is also called the hourglass diagram.

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.[1] The earliest occurrence in print of the term is thought to be in a 1969 MIT technical report.[2][3] 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 n = rm into r smaller transforms of size m where r is the "radix" of the transform. These smaller DFTs are then combined via size-r butterflies, which themselves are DFTs of size r (performed m 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

[edit]

In the case of the radix-2 Cooley–Tukey algorithm, the butterfly is simply a DFT of size-2 that takes two inputs (x0x1) (corresponding outputs of the two sub-transforms) and gives two outputs (y0y1) by the formula (not including twiddle factors):

If one draws the data-flow diagram for this pair of operations, the (x0x1) to (y0y1) lines cross and resemble the wings of a butterfly, hence the name (see also the illustration at right).

A decimation-in-time radix-2 FFT breaks a length-N DFT into two length-N/2 DFTs followed by a combining stage consisting of many butterfly operations.

More specifically, a radix-2 decimation-in-time FFT algorithm on n = 2 p inputs with respect to a primitive n-th root of unity relies on O(n log2 n) 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 ω−1 (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.

Other uses

[edit]

The butterfly can also be used to improve the randomness of large arrays of partially random numbers, by bringing every 32 or 64 bit word into causal contact with every other word through a desired hashing algorithm, so that a change in any one bit has the possibility of changing all the bits in the large array.[4]

See also

[edit]

References

[edit]
  1. ^ Alan V. Oppenheim, Ronald W. Schafer, and John R. Buck, Discrete-Time Signal Processing, 2nd edition (Upper Saddle River, NJ: Prentice Hall, 1989)
  2. ^ C. J. Weinstein (1969-11-21). Quantization Effects in Digital Filters (PDF) (Report). MIT Lincoln Laboratory. p. 42. This computation, referred to as a 'butterfly'
  3. ^ Cipra, Barry A. (2012-06-04). "FFT and Butterfly Diagram". mathoverflow.net. Retrieved 2015-02-10.
  4. ^ *Press, WH; Teukolsky, SA; Vetterling, WT; Flannery, BP (2007), "Section 7.2 Completely Hashing a Large Array", Numerical Recipes: The Art of Scientific Computing (3rd ed.), New York: Cambridge University Press, ISBN 978-0-521-88068-8, archived from the original on 2011-08-11, retrieved 2011-08-13
[edit]