Stabilité de Von Neumann

De testwiki
Aller à la navigation Aller à la recherche

En analyse numérique, l'analyse de stabilité de von Neumann est un procédé permettant de vérifier la stabilité numérique de schémas utilisant la méthode des différences finies pour des équations aux dérivées partielles[1]. Cette analyse est basée sur la décomposition de l'erreur numérique en série de Fourier et fut développée au Laboratoire national de Los Alamos après avoir été brièvement décrite dans un article de Crank et Nicolson[2]. Plus tard, la méthode fut traitée de manière plus rigoureuse dans un article[3] coécrit par von Neumann.

Stabilité numérique

La stabilité d'un schéma numérique est intimement liée à l'erreur numérique. Un schéma de différences finies est dit stable si les erreurs commises en un pas de temps ne font pas augmenter les erreurs au fil des itérations. Si les erreurs diminuent et finissent par s'estomper, le schéma numérique est dit stable. Si au contraire, l'erreur croît à chaque itération, le schéma est dit instable. La stabilité d'un schéma peut être déterminée grâce à l'analyse de von Neumann. Pour des problèmes dépendants du temps, la stabilité garantit qu'une méthode numérique produise une solution bornée lorsque la solution de l'équation différentielle exacte est bornée. La stabilité d'un schéma peut être ardue, surtout lorsque l'équation considérée est non linéaire.

Dans certains cas, la stabilité de von Neumann est suffisante et nécessaire pour la stabilité au sens de Lax–Richtmyer (comme utilisée dans le théorème de Lax): l'EDP et le schéma aux différences finies sont linéaires ; l'EDP est à coefficients constants avec des conditions de bord périodiques et dépend de deux variables indépendantes ; et le schéma n'utilise pas plus de deux niveaux de temps[4]. La stabilité de von Neumann est nécessaire dans une bien plus vaste variété de cas. La relative simplicité de cette méthode implique qu'elle est souvent utilisée à la place d'une analyse de stabilité plus détaillée afin de donner une bonne idée des restrictions sur les tailles des pas.

Illustration de la méthode

La méthode de von Neumann est basée sur la décomposition de l'erreur en séries de Fourier. Afin d'illustrer cette procédure, considérons l'équation de la chaleur uni-dimensionnelle

ut=α2ux2

définie sur L, qui peut dans ce cas être discretisée de la manière suivante

(1)ujn+1=ujn+r(uj+1n2ujn+uj1n)

r=αΔtΔx2

et la solution ujn de l'équation discrète approxime la solution analytique u(x,t) de l'EDP sur les points de grille.

Définissons l'erreur d'arrondi ϵjn par

ϵjn=Njnujn

ujn est la solution de l'équation discrétisée (1) qui serait implémentée en l'absence d'erreurs d'arrondi, et Njn est la solution numérique obtenue par précision arithmétique finie. Comme la solution exacte ujn doit vérifier la solution discrétisée, l'erreur ϵjn doit elle aussi vérifier l'équation discrétisée[5]. Ainsi

(2)ϵjn+1=ϵjn+r(ϵj+1n2ϵjn+ϵj1n)

est une relation de récurrence pour l'erreur. Les équations (1) et (2) montrent que l'erreur et la solution numérique ont le même comportement en fonction du temps. Pour des équations différentielles linéaires avec des conditions de bord périodiques, la variation spatiale de l'erreur peut être décomposée en une série de Fourier finie sur l'intervalle L, par

(3)ϵ(x)=m=1MAmeikmx

où le nombre d'onde km=πmL avec m=1,2,,M et M=L/Δx. La dépendance du temps de l'erreur est incluse en supposant que l'amplitude de l'erreur Am est une fonction du temps. Sachant que l'erreur tend à croître ou décroître de manière exponentielle avec le temps, il est raisonnable de supposer que l'amplitude varie exponentiellement avec le temps ; d'où

(4)ϵ(x,t)=m=1Meateikmx

a est une constante.

Comme l'équation des différences de l'erreur est linéaire, il est suffisant de considérer la croissance de l'erreur pour un terme choisi:

(5)ϵm(x,t)=eateikmx

Les caractéristiques de stabilité peuvent être étudiées en utilisant cette forme de l'erreur, sans perte de généralité. Pour trouver la variation de l'erreur en fonction du temps, on substitue l'équation (5) dans l'équation (2), après avoir noté que

  • ϵjn=eateikmxϵjn+1=ea(t+Δt)eikmxϵj+1n=eateikm(x+Δx)ϵj1n=eateikm(xΔx),

pour arriver à (après simplification)

(6)eaΔt=1+αΔtΔx2(eikmΔx+eikmΔx2).

En utilisant les identités suivantes

cos(kmΔx)=eikmΔx+eikmΔx2etsin2kmΔx2=1cos(kmΔx)2

on peut réécrire (6) comme

(7)eaΔt=14αΔtΔx2sin2(kmΔx/2)

Définissons le facteur d'amplitude

Gϵjn+1ϵjn

La condition nécessaire et suffisante pour que l'erreur reste bornée est |G|1. Cependant,

(8)G=ea(t+Δt)eikmxeateikmx=eaΔt

Ainsi, des équations (7) et (8) on tire que la condition de stabilité est donnée par

(9)|14αΔtΔx2sin2(kmΔx/2)|1

Afin que la condition ci-dessus soit vraie pour tout sin2(kmΔx/2), on a

(10)αΔtΔx212

L'équation (10) donne la condition de stabilité pour le schéma FTCS appliqué à l'équation de la chaleur uni-dimensionnelle. Elle dit que pour un Δx donné, la valeur de Δt doit être assez petite pour vérifier l'équation (10).

Références

Modèle:Traduction/Référence Modèle:Références

Modèle:Palette Modèle:Portail