Thomas-Algorithmus
Der Thomas-Algorithmus (nach Llewellyn Thomas) oder auch Tridiagonalmatrix-Algorithmus (TDMA) ist eine vereinfachte Form des Gaußschen Eliminationsverfahrens, der zum schnellen Lösen von linearen Gleichungssystemen mit einer Tridiagonalmatrix benutzt wird.
Verfahren
Ein tridiagonales System mit n Unbekannten kann geschrieben werden als
wobei gelten soll: und .
In Matrizenform wird das System geschrieben als:
Beispiele für diese Matrizen entstehen üblicherweise aus der Diskretisierung der eindimensionalen Poisson-Gleichung (z. B. eindimensionale Diffusionsprobleme) und aus der natürlichen kubischen Spline-Interpolation.
Für solche Systeme kann die Lösung mit dem Thomas-Algorithmus nach Operationen gefunden werden: Ein erster Durchlauf eliminiert die s, anschließend erhält man die Lösung mit Hilfe eines Rückwärts-Einsetzverfahrens.
Der erste Schritt ist es, die Koeffizienten folgendermaßen rekursiv zu modifizieren (die „neuen“ modifizierten Koeffizienten sind mit einem Strich gekennzeichnet):
Dies ist der vorwärts gerichtete Durchlauf. Die Lösung ergibt sich dann durch ein Rückwärts-Einsetzverfahren:
Varianten
In manchen Situationen, insbesondere in solchen mit periodischen Randbedingungen, kann es sein, dass eine leicht veränderte Form des tridiagonalen Systems zu lösen ist:
In Matrizenform:
In diesem Fall kann die Sherman-Morrison-Woodbury-Formel benutzt werden, um den Thomas-Algorithmus zu nutzen und die zusätzlichen Operationen des Gaußschen Eliminationsverfahrens zu vermeiden.
In anderen Fällen kann das Gleichungssystem block-tridiagonal sein, d. h. die Elemente des obigen Gleichungssystems sind kleinere Blockmatrizen (z. B. bei der zweidimensionalen Poisson-Gleichung). Für diese Fälle wurden ebenfalls vereinfachte Varianten der Gauß-Elimination entwickelt.
Eine weitere Variante des Thomas-Algorithmus ist der Hu-Gallash-Algorithmus, der statt des Rückwärts-Einsetzverfahrens ein Vorwärts-Einsetzverfahren nutzt.
Herleitung
Die Unbekannten seien . Die zu lösenden Gleichungen seien:
Die zweite Gleichung () wird nun wie folgt mit der ersten Gleichung modifiziert:
Dies ergibt:
Dadurch wurde aus der zweiten Gleichung eliminiert. Mit einer analogen Vorgehensweise ergibt sich aus der modifizierten zweiten und der dritten Gleichung:
Jetzt wurde eliminiert. Wird diese Vorgehensweise bis zur -ten Zeile wiederholt, enthält die modifizierte -te Gleichung nur eine Unbekannte. Diese Gleichung wird nun gelöst und das Ergebnis genutzt, um die -te Gleichung zu lösen. Dies wird so lange fortgeführt, bis alle Unbekannten bekannt sind.
Verständlicherweise werden die Koeffizienten mit jedem Schritt komplizierter, wenn sie explizit dargestellt werden. Die Koeffizienten können jedoch auch rekursiv dargestellt werden:
Um den Lösungsprozess weiter zu beschleunigen, wird herausdividiert (wenn ). Die neuen Koeffizienten lauten:
Dies ergibt:
Die letzte Gleichung enthält nur eine Unbekannte. Bestimmt man sie, reduziert man die Anzahl der Unbekannten in der vorletzten Gleichung auf eins, so dass dieses Rückwärts-Einsetzverfahren genutzt werden kann, um alle Unbekannten zu bestimmen.
Einzelnachweise
- Conte, S.D., and deBoor, C.: Elementary Numerical Analysis. McGraw-Hill, New York., 1972.