The Dft And Fft
By the halving lemma, the list of values (30.10) consists not of n distinct values but only of the n/2 complex (n/2)th roots of unity, with each root occurring exactly twice. Therefore, the polynomials A[0] and A[1] of degree-bound n/2 are recursively evaluated at the n/2 complex (n/2)th roots of unity. These subproblems have exactly the same form as the original problem, but are half the size. We have now successfully divided an n-element DFTn computation into two n/2-element DFTn/2 computations. This decomposition is the basis for the following recursive FFT algorithm, which computes the DFT of an n-element vector a = (a0, a1,..., an-1), where n is a power of 2.
RECURSIVE-FFT(a) 1 n ← length[a] ▹ n is a power of 2. 2 if n = 1 3 then return a 4 wn ← eπi/n 5 w ← 1 6 a[0] ← (a0, a2,..., an-2) 7 a[1] ← (a1, a3,..., an-1) 8 y[0] ← RECURSIVE-FFT(a[0]) 9 y[1] RECURSIVE-FFT(a[1]) 10 for k ← 0 to n/2 - 1 11 do
data:image/s3,"s3://crabby-images/02ca9/02ca9bf4fa8a153109b62ea27b90bb27b8222f3a" alt=""
12
data:image/s3,"s3://crabby-images/40411/404117e9a9ca2a12dec11de33a3d7af64f2b3086" alt=""
13 w ← w wn 14 return y ▹ y is assumed to be a column vector.
The RECURSIVE-FFT procedure works as follows. Lines 2 -3 represent the basis of the recursion; the DFT of one element is the element itself, since in this case
data:image/s3,"s3://crabby-images/ec2ad/ec2ad639727d12dee6c90c58dbbd5f86d8f4e99d" alt=""
Lines 6 -7 define the coefficient vectors for the polynomials A[0] and A[1]. Lines 4, 5, and 13 guarantee that w is updated properly so that whenever lines 11 -12 are executed, . (Keeping a running value of w from iteration to iteration saves time over computing
from scratch each time through the for loop.) Lines 8-9 perform the recursive DFTn/2 computations, setting, for k = 0, 1,..., n/2 - 1,
data:image/s3,"s3://crabby-images/1c2ea/1c2ea32e363eb9d937a6d6b068e52103f2179ae1" alt=""
or, since by the cancellation lemma,
data:image/s3,"s3://crabby-images/2f316/2f316e69da9797cc0a9c5c0716c605c9c018a9fe" alt=""
Lines 11-12 combine the results of the recursive DFTn/2 calculations. For y0, y1,..., yn/2-1, line 11 yields
data:image/s3,"s3://crabby-images/f7c77/f7c77c9d04945c982d00f9ad1886fc11edb50f4d" alt=""
For yn/2, yn/2 1,..., yn-1, letting k = 0, 1,..., n/2 - 1, line 12 yields
data:image/s3,"s3://crabby-images/8c384/8c384349c9c814bb5ba7d64d4bc4664f7af56822" alt=""
Thus, the vector y returned by RECURSIVE-FFT is indeed the DFT of the input vector a.