En algèbre linéaire, une
matrice circulante est une matrice carrée dans laquelle on passe d'une ligne à la suivante par permutation circulaire (décalage vers la droite) des coefficients.
Une matrice circulante de taille n est donc de la forme
nC = n | ┌ │ | nc 0 | c 1 | c 2 | | c n - 1 | ┐ │ | │ | nc n - 1 | c 0 | c 1 | | c n - 2 | │ | │ | nc n - 2 | c n - 1 | c 0 | | c n - 3 | │ | │ │ | n ⋮ | | | | ⋮ | │ │ | │ └ | nc 1 | c 2 | c 3 | | c 0 n | │ ┘ |
| n |
où les coefficients ci sont des complexes.
Une matrice circulante constitue un cas particulier de Matrice de Toeplitz, et aussi un cas particulier de Carré latin.
La réduction des matrices circulantes fait intervenir les formules de la transformation de Fourier discrète. En analyse numérique, les systèmes circulants peuvent être résolus très efficacement par transformée de Fourier rapide.
On parle parfois de matrice anticirculante ou circulante gauche quand on effectue un décalage à gauche des coefficients en passant d'une ligne à la suivante.
Algèbre des matrices circulantes
Pour alléger les notations, on désigne par
C (c 0 ,...,c n - 1 ) la matrice circulante précédente.
En notant J = C (0,1,0,...,0), on peut constater que toute matrice circulante est un polynôme en J
C | ( | c 0 , | . s | ,c n - 1 | ) | = | n - 1 Σ j = 0 | c j J j = P C (J) |
Réciproquement, comme J n est la Matrice identité, tout polynôme en J est une matrice circulante.
Ainsi la somme, le produit de matrices circulantes sont circulantes, et un tel produit est commutatif. L'ensemble des matrices circulantes n'est autre que l'Algèbre commutative des polynômes en J.
Réduction des matrices circulantes
Diagonalisation de J
La matrice
J vérifiant
J n = I, elle est
diagonalisable sur
C avec pour valeurs propres des racines
n-èmes de l'unité.
On appelle donc , racine primitive de l'unité. On vérifie alors sans peine que pour tout k
X k = | ( | ┌ | 1 | ┐ | ) | | ω k | | | ω 2k | | | ⋮ | | └ | ω ( n - 1 ) k | ┘ |
|
est vecteur propre de J associé à la valeur propre ω k .
On a donc exhibé, pour k allant de 0 à n-1, une famille de n vecteurs propres associés à des valeurs propres distinctes, soit une base de diagonalisation de J.
Diagonalisation d'une matrice circulante
Par conséquent, c'est une base de diagonalisation aussi pour tout polynôme en
J, c'est-à-dire toute matrice circulante. Les valeurs propres de
C (c 0 ,...,c n - 1 ) sont donc les
λ k = | n - 1 Σ j = 0 | c j ω kj = P C ( ω k ) |
qui, cette fois, ne sont plus nécessairement distinctes.
On peut prendre pour matrice de passage de la base canonique à la base de diagonalisation la matrice U
| ( | ┌ | n1 | 1 | | 1 | ┐ | ) | | 1 | ω | | ω n - 1 | | | ⋮ | ⋮ | | ⋮ | | └ | n1 | ω n - 1 | | ω ( n - 1 ) 2 | ┘ |
|
Alors cette matrice U est unitaire (U*U=I) et les formules de passage précédentes s'écrivent, en notant Λ la matrice diagonale de coefficients les valeurs propres
C = U Λ U -1 = U Λ U * Λ = U -1 CU = U * CU
Une nouvelle définition possible pour l'ensemble des matrices circulantes est l'ensemble des matrices de la forme UDU * avec D diagonale. Géométriquement, cela correspond aux endomorphismes qui admettent la base orthonormale des Xk comme base de vecteurs propres.
Déterminant circulant
Le
déterminant circulant est le déterminant de la matrice circulante ; il est égal au produit des valeurs propres
det C = | n - 1 Π k = 0 | P C ( ω k ) |
La matrice est inversible si et seulement si son déterminant est non nul, et dans ce cas son inverse est lui aussi une matrice circulante.
Intervention de la transformée de Fourier discrète
Les formules de changement de base à l'aide de la matrice
U ont un intérêt particulier. La formule de passage des coefficients aux valeurs propres est la définition classique d'une transformée de Fourier discrète. On peut retrouver les coefficients à partir des valeurs propres en effectuant cette fois une transformée inverse
c k = | 1 –– n | n - 1 Σ j = 0 | λ j ω - k j |
Système circulant
Soit le système circulant
Cx=b, avec
C matrice circulante de taille
n. Ce système peut se réécrire à l'aide d'un produit de convolution discret
c * x = b
en notant c la première colonne de la matrice C et en périodisant les composantes des vecteurs c, x et b. La transformée de Fourier discrète transforme cette équation de convolution en un produit composante par composante.
F n (c * x) = F n (c) F n (x) = F n (b)
et ainsi
Cet alogrithme de résolution est bien plus rapide que l'élimination de Gauss-Jordan, et l'est d'autant plus si on a recours à la transformée de Fourier rapide.
Voir aussi