Transformation de Fourier rapide

La transformation de Fourier rapide (sigle anglais : FFT ou fast Fourier transform) est un algorithme de calcul de la transformation de Fourier discrète (TFD).

Sa complexité varie en O(n log n) avec le nombre n de points, alors que la complexité de l’algorithme « naïf » s'exprime en O(n2). Ainsi, pour n = 1 024, le temps de calcul de l'algorithme rapide peut être 100 fois plus court que le calcul utilisant la formule de définition de la TFD.

C'est en 1965 que James Cooley et John Tukey publient l’article qui « lance » définitivement l'adoption massive de cette méthode en traitement du signal et dans les télécommunications. On a découvert par la suite que l'algorithme avait déjà été imaginé par Carl Friedrich Gauss en 1805, et adapté à plusieurs reprises (notamment par Lanczos en 1942) sous des formes différentes. L'algorithme a aussi été découvert indépendamment par le chanoine Lemaître[1].

Cet algorithme est couramment utilisé en traitement numérique du signal pour transformer des données discrètes du domaine temporel dans le domaine fréquentiel, en particulier dans les oscilloscopes numériques (les analyseurs de spectre utilisant plutôt des filtres analogiques, plus précis). Son efficacité permet de réaliser des filtrages en modifiant le spectre et en utilisant la transformation inverse (filtre à réponse impulsionnelle finie). Il est également à la base des algorithmes de multiplication rapide (Schönhage et Strassen, 1971), et des techniques de compression numérique ayant mené au format d'image JPEG (1991).

Le développement d'algorithmes rapides pour la FFT remonte au travail non publié de Carl Friedrich Gauss en 1805, alors qu'il en avait besoin pour interpoler l'orbite des astéroïdes Pallas et Junon à partir d'observations d'échantillons. Sa méthode était très similaire à celle publiée en 1965 par James Cooley et John Tukey, à qui l'on attribue généralement l'invention de l'algorithme générique moderne de la FFT. Bien que les travaux de Gauss soient antérieurs aux résultats de Joseph Fourier en 1822, il n'a pas analysé le temps de calcul et a finalement utilisé d'autres méthodes pour atteindre son objectif.

Entre 1805 et 1965, certaines versions de la FFT ont été publiées par d'autres auteurs. En 1932, Frank Yates a publié sa version, qui permettait un calcul efficace des transformées de Hadamard et de Walsh. L'algorithme de Yates est toujours utilisé dans le domaine de la conception statistique et de l'analyse des expériences. En 1942, G. C. Danielson et Cornelius Lanczos ont publié leur version permettant de calculer la FFT pour la cristallographie aux rayons X, un domaine où le calcul des transformées de Fourier présentait un formidable goulot d'étranglement. Dans le passé, de nombreuses méthodes s'étaient concentrées sur la réduction de la constante pour laquelle le nombre d'opérations était équivalent à en tirant parti des "symétries". Mais Danielson et Lanczos ont réalisé que l'on pouvait utiliser la "périodicité" pour réduire encore cette constante, bien que, comme Gauss, ils n'aient pas analysé que cela conduisait à un algorithme en .

James Cooley et John Tukey ont redécouvert de manière indépendante ces algorithmes antérieurs et ont publié en 1965 une version plus générale de la FFT applicable lorsque est composite et pas nécessairement une puissance de 2, ainsi qu'une analyse de complexité en . Tukey a eu cette idée lors d'une réunion du comité consultatif scientifique du président Kennedy, où l'on discutait de la détection des essais nucléaires de l'Union soviétique en installant des capteurs pour encercler le pays de l'extérieur. Les essais nucléaires avaient en effet lieu sous terre[2], et la seule manière de les détecter était d'utiliser une transformée de Fourier. En discutant avec Tukey, Richard Garwin a reconnu l'applicabilité générale de l'algorithme non seulement aux problèmes de sécurité nationale, mais aussi à un large éventail de problèmes, dont un qui l'intéressait immédiatement, à savoir la détermination des périodicités des orientations du spin dans un cristal tridimensionnel d'hélium 3[3]. Comme Tukey ne travaillait pas chez IBM, la brevetabilité de l'idée a été mise en doute et l'algorithme est tombé dans le domaine public, ce qui, grâce à la révolution informatique de la décennie suivante, a fait de la FFT l'un des algorithmes indispensables du traitement numérique du signal.

Formulation mathématique

[modifier | modifier le code]

Soit des nombres complexes. La transformée de Fourier discrète de est définie par la formule suivante :

pour j = 0, ... , n-1. De manière équivalente, soit un polynôme à coefficients complexes. La transformée de Fourier discrète de est définie par la formule suivante :

, où

ou en notation matricielle :

, où l'on reconnaît une matrice de Vandermonde .

Évaluer naïvement coûte (n – 1)2 produits complexes et n(n – 1) sommes complexes alors que seuls produits et sommes sont nécessaires avec la version rapide. En général, de tels algorithmes dépendent de la factorisation de mais contrairement à une idée répandue, il y a des transformées de Fourier rapides de complexité pour tous les , même pour les nombres premiers.

Il est possible de générer la transformation inverse de la même manière pour la version rapide. En effet l'inverse de la matrice de Vandermonde est simplement . Il suffit donc d'appliquer l'algorithme à cet inverse.

Algorithme de Cooley-Tukey

[modifier | modifier le code]

Il s'agit d'un algorithme fréquemment utilisé pour calculer la transformation de Fourier discrète. Il se base sur une approche de type « diviser pour régner » par le biais d'une récursion. Celle-ci subdivise une transformation de Fourier discrète d'une taille composite en plusieurs transformées de Fourier discrètes de tailles inférieures et . Cet algorithme nécessite multiplications par des racines d'unité, plus communément appelés facteurs de rotation. En général, les mises en code essaient d'éviter une récursion pour des questions de performance. Il est aussi possible de mélanger plusieurs types d'algorithme lors des subdivisions.

C'est en 1965 que James Cooley et John Tukey publient cette méthode[4],[5] mais il a été découvert par la suite que l'algorithme avait déjà été inventé par Carl Friedrich Gauss en 1805[6] et adapté à plusieurs reprises sous des formes différentes[7].

Détail d'un cas classique :

[modifier | modifier le code]

L'utilisation la plus classique de l'algorithme de Cooley-Tukey est une division de la transformation en deux parties de taille identique et ceci à chaque étape. Cette contrainte limite les tailles possibles, puisque celles-ci doivent être des puissances de deux. Néanmoins on peut traiter n'importe quel polynôme puisqu'un polynôme de degré peut être vu comme un polynôme de .

Principe de l'algorithme

[modifier | modifier le code]

On décompose le polynôme en , où et . On applique ensuite l'algorithme en et en , pour en déduire l'évaluation de en .

Pseudo-code

[modifier | modifier le code]
Entrée : un polynôme  et  une racine primitive -ième de l'unité.
Sortie : .

fonction FFT() :
|  si  est constant :
|  |  retourner 
|  sinon
|  |  calculer  et 
|  |  calculer  et  via FFT() et FFT() respectivement
|  |  pour k allant de 0 à n-1 :
|  |  |  
|  |  retourner  

Cet algorithme a une complexité en .

Schéma explicatif

[modifier | modifier le code]
Schéma correspondant à la FFT (DFT en anglais) d'un polynôme de degré 7.

Dans le schéma ci-contre, on a représenté la FFT d'un polynôme . On obtient à la fin des valeurs Les polynômes intermédiaires obtenus sont (pour even) et (pour odd) qui représentent et .

On obtiendra ensuite des polynômes et à partir de , ainsi que et à partir de , et on itérera le procédé. Ainsi est formé des coefficients et , des coefficients et , et de même pour les impairs.

Les flèches vers les valeurs signifient que la valeur de départ de la flèche influence la valeur de  : par exemple la valeur de dépend de celles de et .

Autres algorithmes

[modifier | modifier le code]

Il existe d'autres algorithmes qui permettent de calculer la transformée de Fourier discrète. Pour une taille n = n1n2, avec des nombres premiers entre eux n1 et n2, il est possible d'utiliser l'algorithme PFA (Good-Thomas) basé sur le théorème des restes chinois. Le PFA est similaire à celui de Cooley-Tukey.

L'algorithme de Rader-Brenner[8] est aussi une variante de Cooley-Tukey avec des facteurs de rotation purement imaginaires qui améliorent les performances en réduisant le nombre de multiplications mais au détriment de la stabilité numérique et une augmentation du nombre d'additions. Les algorithmes qui procèdent aussi par des factorisations successives sont celui de Bruun (en) et l'algorithme QFT. Les versions originales travaillent sur des fenêtres dont la taille est une puissance de 2 mais il est possible de les adapter pour une taille quelconque. L'algorithme de Bruun considère la transformée de Fourier rapide comme une factorisation récursive du polynôme zn – 1 en des polynômes à coefficients réels de la forme zm – 1 et z2m + azm + 1.

L'algorithme de Winograd factorise zn – 1 en un polynôme cyclotomique, dont les coefficients sont souvent –1, 0 ou 1, ce qui réduit le nombre de multiplications. On peut voir cet algorithme comme la version optimale en termes de multiplications. Winograd a montré que la transformée de Fourier discrète peut être calculée avec seulement O(n) multiplications, et ce minorant est atteint pour les tailles qui sont des puissances de 2. Toutefois, des additions supplémentaires sont nécessaires, ce qui peut être pénalisant sur les processeurs modernes comportant des unités arithmétiques performantes.

L'algorithme de Rader (en) est quant à lui destiné aux fenêtres dont la taille est un nombre premier. Il profite de l'existence d'une génératrice pour le groupe multiplicatif modulo n. La transformation discrète dont la taille est un nombre premier s'exprime ainsi comme une convolution cyclique de taille n – 1. On peut ensuite la calculer par une paire de transformation de Fourier rapide.

Finalement, un autre algorithme destiné aux transformations avec des tailles qui sont des nombres premiers est due à Leo Bluestein, en 1968. On l'appelle plus souvent l'algorithme chirp Z (en). Ici encore, la transformation est vue comme une convolution dont la taille est identique à la fenêtre originale. On utilise à cet effet l'identité de polarisation : jk = –(j – k)2/2 + j2/2 + k2/2.

Algorithmes spécialisés dans le traitement de données réelles ou/et symétriques

[modifier | modifier le code]

Dans beaucoup d'applications, les données en entrée de la transformation discrète de Fourier sont uniquement des nombres réels. Dans ce cas, les sorties satisfont la symétrie suivante : et des algorithmes efficaces ont été conçus pour cette situation, par exemple celui de Sorensen en 1987[9]. Une approche possible consiste à prendre un algorithme classique comme celui de Cooley-Tukey et à enlever les parties inutiles dans le calcul. Cela se traduit par un gain de 50 % en mémoire et en vitesse de calcul. Alternativement, il est possible d'exprimer une transformation discrète sur des nombres réels (avec une taille paire) en une transformation avec des nombres complexes mais dont la taille a été divisée par deux (les parties imaginaires sont les éléments impairs et les parties réelles sont les éléments pairs) suivie d'un décodage dont la complexité est de l'ordre de O(n) opérations.

On pensait que les transformations avec des nombres réels pouvaient être plus efficacement calculées via une transformation de Hartley discrète (en) mais il a été prouvé par la suite qu'une transformation de Fourier discrète modifiée pouvait être plus efficace que la même transformation de Hartley. L'algorithme de Bruun était un candidat pour ces transformations mais il n'a pas eu la popularité escomptée.

Il existe encore d'autres variantes pour les cas où les données sont symétriques (c’est-à-dire des fonctions paires ou impaires) avec un gain supplémentaire de 50%. Dans ce cas, on utilise une transformée en cosinus discrète.

Problèmes numériques et approximations

[modifier | modifier le code]

Par leur nature analytique, tous les algorithmes proposés ci-dessus calculent la transformée sans aucune erreur. Toutefois, il existe des algorithmes qui peuvent s'accommoder d'une marge d'erreur pour accélérer les calculs. En 1999, Edelman et al. proposent une approximation à la transformée de Fourier rapide[10]. Cette version est destinée à une mise en œuvre en parallèle. Une approximation basée sur les ondelettes est proposée en 1996 par Guo et Burrus[11] et tient compte de la répartition dans les entrées/sorties. Un autre algorithme a encore été proposé par Shentov et al. en 1995[12]. Seul l'algorithme de Edelman fonctionne bien avec n'importe quel type de données, il profite de la redondance dans la matrice de Fourier plutôt que de la redondance dans les données initiales.

Toutefois, même les algorithmes décrits de manière analytique présentent des erreurs lorsqu'ils sont codés avec des virgules flottantes dont la précision est limitée. L'erreur est cependant limitée. Une borne supérieure d'erreur relative pour Cooley-Tukey est donnée par alors qu'elle est de pour la formulation triviale de la transformée de Fourier discrète[13]. Le terme représente ici la précision relative en virgule flottante. En fait, l'erreur quadratique moyenne est encore plus limitée avec seulement pour Cooley-Tukey et pour la version triviale. Il ne faut malgré tout pas oublier que la stabilité peut être perturbée par les différents facteurs de rotation qui interviennent dans les calculs. Un manque de précision sur les fonctions trigonométriques peut fortement augmenter l'erreur. L'algorithme de Rader est par exemple nettement moins stable que celui de Cooley-Tukey en cas d'erreurs prononcées.

Avec une arithmétique en virgule fixe, les erreurs s'accumulent encore plus vite. Avec Cooley-Tukey, l'augmentation de l'erreur quadratique moyenne est de l'ordre de . De plus, il faut tenir compte de la magnitude des variables lors des différentes étapes de l'algorithme.

Il est possible de vérifier la validité de l'algorithme grâce à une procédure qui vise à déterminer la linéarité et d'autres caractéristiques de la transformation sur des entrées aléatoires[14].

Exemple d'application : la multiplication de polynômes

[modifier | modifier le code]

Quand on veut multiplier deux polynômes représentés par la liste de leurs coefficients, la multiplication se fait en . En revanche, si on les représente par une liste d'évaluations en des points tous distincts, la multiplication se fait en (en supposant que l'on a assez de valeurs pour avoir défini de manière unique). On a donc intérêt à chercher un algorithme permettant de passer rapidement d'une de ces représentations à l'autre.

Or la FFT permet l'évaluation d'un polynôme en et, inversement, son interpolation en points (comme explicité dans la partie « Formulation mathématique »). Ainsi, la multiplication de deux polynômes représentés par la liste de leurs coefficients s'effectue en .

Notes et références

[modifier | modifier le code]
(en) Cet article est partiellement ou en totalité issu de l’article de Wikipédia en anglais intitulé « Fast Fourier transform » (voir la liste des auteurs).
  1. « Qui était Georges Lemaître? », sur uclouvain.be.
  2. (en) Lif Lund Jacobsen, The seismograph as a diplomatic object: The Soviet–American exchange of instruments, 1958–1964 (lire en ligne)
  3. (en) James W. Cooley, The Re-Discovery of the Fast Fourier Transform Algorithm (lire en ligne)
  4. (en) James W. Cooley et John W. Tukey, « An algorithm for the machine calculation of complex Fourier series », Math. Comp., vol. 19,‎ , p. 297-301 (lire en ligne).
  5. D'après (en) James W. Cooley, « How the FFT Gained Acceptance », dans Stephen G. Nash, A History of Scientific Computing, ACM Press, (lire en ligne), p. 133-140.
  6. Carl Friedrich Gauss, Annexe: Theoria interpolationis methodo nova tractata, vol. 3 : Werke, Göttingen, Königliche Gesellschaft der Wissenschaften, (lire en ligne), p. 265-327.
  7. Cf. l'article de (en) Michael T. Heideman, Donald H. Johnson et C. Sidney Burrus, « Gauss and the History of the Fast Fourier Transform », Arch. Hist. Exact Sci., vol. 34, no 3,‎ , p. 265-277 cité par (en) William L. Briggs et Henson van Emden, The DFT : An owner's manual for the Discrete Fourier Transform, SIAM, , 436 p. (ISBN 0898713420), « Introduction: A Bit of History », p. 5-7. Voir aussi (en) M. T. Heideman, D. H. Johnson et C. S. Burrus, « Gauss and the history of the fast Fourier transform », IEEE ASSP Magazine, vol. 1, no 4, 1984, p. 14-21.
  8. (en) N. Brenner et C. Rader, « A new principle for Fast Fourier Transformation », IEEE Acoustics, Speech & Signal Processing, vol. 24, no 3,‎ , p. 264-266 (DOI 10.1109/TASSP.1976.1162805).
  9. (en) H. V. Sorensen, D. L. Jones, M. T. Heideman et C. S. Burrus, « Real-valued fast Fourier transform algorithms », IEEE Trans. Acoust. Speech Sig. Processing, vol. ASSP-35, 1987, p. 849-863.
  10. (en) Alan Edelman, Peter McCorquodale et Sivan Toledo, « The future fast Fourier transform? », SIAM J. Sci. Comput., vol. 20, 1999, p. 1094-1114, DOI 10.1137/S1064827597316266.
  11. (en) H. Guo et C. S. Burrus, « Fast approximate Fourier transform via wavelets transform », Proc. SPIE Intl. Soc. Opt. Eng., vol. 2825, 1996, p. 250-259.
  12. (en) O. V. Shentov, S. K. Mitra, U. Heute et A. N. Hossen, « Subband DFT. I. Definition, interpretations and extensions », Signal Processing, vol. 41, no 3, 1995, p. 261-277, DOI 10.1016/0165-1684(94)00103-7.
  13. (en) W. M. Gentleman et G. Sande, « Fast Fourier transforms — for fun and profit », Proc. AFIPS, vol. 29,‎ (lire en ligne).
  14. (en) Funda Ergün, « Testing multivariate linear functions: overcoming the generator bottleneck », dans Proc. 27th ACM Symposium on the Theory of Computing, 1995, p. 407-416, DOI 10.1145/225058.225167.

Bibliographie

[modifier | modifier le code]
  • F. Schwartzentruber, « Diviser pour régner », cours d'informatique niveau L3 à l'ENS de Rennes
  • (en) P. Duhamel et M. Vetterli, « A Fast Fourier transforms: a tutorial review and a state of the art », Signal Processing, vol. 19,‎ , p. 259-299
  • (en) H. Guo, G. A. Sitton et C. S. Burrus, « The Quick Discrete Fourier Transform », Proc. IEEE Conf. Acoust. Speech and Sig. Processing (ICASSP), vol. 3, 1994, p. 445-448
  • (en) James C. Schatzman, « Accuracy of the discrete Fourier transform and the fast Fourier transform », SIAM J. Sci. Comput., vol. 17, no 5, 1996, p. 1150-1166
  • (en) A. V. Oppenheim et R. Schafer, Digital Signal Processing, Englewood Cliffs, NJ, Prentice-Hall, 1975
  • (en) Matteo Frigo et Steven G. Johnson, « The Design and Implementation of FFTW3 », Proceedings of the IEEE, vol. 93, no 2, 2005, p. 216-231 — Une version libre (GPL) de la transformée de Fourier rapide (bibliothèque C) pour des données de taille et de dimensions arbitraires.

Articles connexes

[modifier | modifier le code]

Vidéographie

[modifier | modifier le code]