We first change the intermediate polynomials.
Let
be a power of
, let
be a primitive
-th
root of unity and
.
We define
![\begin{displaymath}\begin{array}{rcl} A^{[0]}(x) & = & a_0 + a_2 x + a_4 x^2 + \...
... + a_3 x + a_5 x^2 + \cdots + a_{n-1} x^{n/2 -1} \\ \end{array}\end{displaymath}](img329.png) |
(55) |
such that we have
![$\displaystyle A(x) \ = \ A^{[0]}(x^2) + x \, A^{[1]}(x^2).$](img330.png) |
(56) |
Hence evaluating
at
is reduced to evaluate
and
at
.
But this second sequence of powers of
consists
of two identical sequences of length
.
Indeed, for every integer
we have
data:image/s3,"s3://crabby-images/f92fc/f92fc82a296703d01f1097ee16a2f0fa721956ad" alt="$\displaystyle ({\omega}^{k+ n/2})^2 \ = \ ({\omega}^{k})^2$" |
(57) |
Since
holds, we obtain
data:image/s3,"s3://crabby-images/3322b/3322b2d2122fd6480ba93cfdcc9ecec691748bda" alt="$\displaystyle {\omega}^{k+ n/2} \ = \ - {\omega}^{k}$" |
(58) |
Hence we only need to evaluate
and
at
data:image/s3,"s3://crabby-images/f4763/f4763fa3373bf43bbb80e3cf6691c35500449a44" alt="$\displaystyle 1, {\omega}^2, {\omega}^4, \ldots, {\omega}^{n-2}.$" |
(59) |
This provides us directly with the values of
at
data:image/s3,"s3://crabby-images/20c67/20c6711bb2e20597d6942552503b30c33ac957fe" alt="$\displaystyle 1, {\omega}, {\omega}^2, \ldots, {\omega}^{n/2-1}$" |
(60) |
and the values of
at
data:image/s3,"s3://crabby-images/d6fba/d6fba9d36fb4011056eae4133a80913663ae9392" alt="$\displaystyle {\omega}^{n/2}, {\omega}^{n/2+1}, \ldots, {\omega}^{n-1}$" |
(61) |
by using the fact these numbers are respectively equal to
data:image/s3,"s3://crabby-images/b8a63/b8a636c9aa0334485807560597c21d4aef2fdac5" alt="$\displaystyle -1, -{\omega}, -{\omega}^2, \ldots, -{\omega}^{n/2-1}.$" |
(62) |
To summarize, for
we have
![\begin{displaymath}\begin{array}{rcl} A({\omega}^i) & = & A^{[0]}({\omega}^{2i})...
...ga}^{2i}) - {\omega}^i \, A^{[1]}({\omega}^{2i}) \\ \end{array}\end{displaymath}](img343.png) |
(63) |
Algorithm 3
The validity of Algorithm 3
follows from the two following observations.
- Formulas (63).
- If
is a primitive
-root of unity, with
,
then
is a primitive
-root of unity.
Observe that the recursive calls of
defines
an ordering of the coefficients of
shown
on Figure 2 for
.
Let us call this ordering the DFT ordering of
.
Observe that if the input array
is sorted w.r.t. this
DFT ordering, one can describe easily the
recursive calls with a binary tree.
If this tree is traversed bottom-up, from left to right,
we are led to an iterative algorithm working in place!
For instance, for
, assuming that the input array
is
We obtain the desired result in
using the following straigth-line program
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
:=
Figure 2:
Recursive calls for
.
![\begin{figure}\htmlimage
\centering
\includegraphics[scale=.5]{fft8.eps}\end{figure}](img372.png) |
Algorithm 4
Remark 8
To get the DFT ordering for
,
that is
,
observe that this ordering changes
data:image/s3,"s3://crabby-images/eae1b/eae1b252a71b527eab988859dcff063d52298505" alt="$\displaystyle 000, 001, 010, 011, 100, 101, 011, 111$" |
(64) |
to
data:image/s3,"s3://crabby-images/65b04/65b04bc29d8fdfb0afb098e44bd7bd8fcb641c0c" alt="$\displaystyle 000, 100, 010, 110, 001, 101, 110, 111$" |
(65) |
Remark 9
The ring
does not have any interesting roots of unity.
In order to take advantage of the FFT-based multiplication
one could use a modular approach as follows.
Marc Moreno Maza
2008-01-07