Grundsätzliche Matrix-Operationen

Hinweise
Eine einmal belegte Variable kann von nachfolgendem Code nicht überschrieben/geändert werden - eine Variable ändern heißt erzeuge eine neue Instanz/neue Variable. [br]Ein Matrix-Element kann nicht per Indizes geändert/geschrieben werden sondern man muss eine Zeile Element für Element durchlaufen und eine neue Zeile/Matrix mit der Änderung erzeugen oder Änderungen an (unvollständige) Zeilen anhängen. [br][br]A := {{11,12,13,14},{21,22,23,24},{31,32,33,34},{41,42,43,44}}[br][br][math]\large \cancel{\text{Element(A,2,3)=5}}\\ [br]\to\text{Sequence(Sequence(If(i==2 \;\&\&\; j==3,5, Element(A, i,j)),j,1,4),i,1,4)}\\ [br]\to\text{Join(Take(A,1, 1), \{Join(Take(Element(A, 2),1,1),{5},Take(Element(A, 2),3))\},Take(A,3))} \\[br]\to \left(\begin{array}{rrrr}11&12&13&14\\21&22&5&24\\31&32&33&34\\41&42&43&44\\\end{array}\right)[/math]
[size=150]L[/size][size=150]ineare Gleichungssysteme A [math]\vec{x}[/math] = [/size][size=150][math]\vec{b}[/math][/size]
[size=100]Im CAS lege ich eine Matrix A an und verwende Einträge an denen sich leicht die Zeilen und Spalten-Positionen ablesen lassen.[br]Ich verwende Zahleneinträge, damit sich die Matrixelemente einfach abgreifen lassen: [br]A(n) steht dann für die Matrixzeile n und A(z,s) steht für das Element in Zeile z, Spalte s![/size]
[size=100]Tauschmatrix zum Vertauschen von Zeilen oder Spalten. Sie entstehen aus der Einheitsmatrix in dem die entsprechenden Zeilen vertauscht wurden: T12, T13, T14, T23, T24, T34 wäre ein kompletter Satz an Matrizen um alle möglichen Zeilen- oder Spalten-Vertauschungen einer 4x4 Matrix zu beschreiben.[/size]
[size=100]Anwenden der Tauschmatrix T12 zum Zeilentausch[/size]
[size=100]Anwenden der Tauschmatrix T12 zum Spaltentausch[/size]
[size=100]Inverse: Wende ich eine Tauschmatrix auf sich selber an, dann tausche ich einen Satz vertauschter Zeilen wieder zurück und ich erhalte die Einheitsmatrix.[/size][br][br][size=150]Umformen von linearen Gleichungssystemen[/size]
[size=100]A x = b[br]Eine Matrix-Gleichung kann einfach von Links mit einer Zeilentauschmatrix multipliziert werden um eine Zeilenoperation in der Matrix A durchzuführen.[br]T12 A x = T12 b[br]Um an der Matrix A eine Spaltenoperation durchzuführen kann die Matrix-Gleichung nicht einfach von rechts multipliziert werden, da die Tauschmatrix dann bei x einen Spaltentausch durchführem will wo keine Spalten sind. [br]A x T12 = b T12[br]Bringen wir zwischen A x die Einheitsmatrix in Form von zwei Tauschmatrizen T12 T12 = E ein, so tauschen wir in A die Spalten und in x die Zeilen, was dann das GLS erhält - wir haben ja nur mit der Einheitsmatrix E multipliziert. [math]\searrow[/math][/size]
A x = b
[size=100]Das GeoGebra-Ergebnis A x = b etwas schöner aufgeschrieben:[/size][br][math]\begin{matrix}11r+12s+13u+14v\\21r+22s+23u+24v\\31r+32s+33u+34v\\41r+42s+43u+44v\end{matrix}=\begin{matrix}a\\b\\c\\d\end{matrix}[/math]
Zeilentausch: T12 A x = T12 b
[size=100]Das GeoGebra-Ergebnis T12 A x = T12 b etwas schöner aufgeschrieben:[/size][br][math]\begin{matrix}[br]21r+22s+23u+24v\\11r+12s+13u+14v[br]\\31r+32s+33u+34v[br]\\41r+42s+43u+44v\end{matrix}=\begin{matrix}b\\a\\c\\d\end{matrix}[/math]
Zeilen- & Spaltentausch: T12 A T12 T12 x = T12 b
Teilbetrachtung Zeilentausch und Spaltentausch[br] T12 A T12                T12 [math]\vec{x}[/math][br][math]\left(\begin{array}{rrrr}22&21&23&24\\12&11&13&14\\32&31&33&34\\42&41&43&44\\\end{array}\right)[/math] [math]\left( \begin{matrix}s\\r\\u\\v\end{matrix} \right) [/math][br][br]
Zeilenumformung zur Lösung eines linearen GLS
Beim Lösen eines GLS mittels Gauss-Algorithmus oder bei der Erzeugung der LR-Zerlegung werden die Zeilen der Matrix A durch Zeilenumformungen auf die Einheitsmatrix oder die Dreiecksmatrizen L R zurückgeführt.[br]Das Standardverfahren addiert ein Faktor q-faches der ersten Zeile zur allen folgenden Zeilen, so dass in der ersten Spalte Nullen entstehen: [br]Die Zeilenumformungsmatrix T2plus1 soll ein q faches der ersten Zeile zur zweiten und ein p-faches der zweiten Zeile zur dritten addieren.[br]
[size=100]Allgemein werden in Zeilentransformationsmatrizen die Faktoren für die erste Zeile unterhalb der Diagonalen in der ersten Spalte und die Faktoren für die zweite Zeile in der zweiten Spalte hinterlegt. Weitere Zeilenfaktoren analog eintragen ...[/size]
[size=100]Im Ergebnis erhalten wir Zeile2=q*Zeile1+Zeile2 und Zeile3=p*Zeile2+Zeile3[br]Die Zeilenumformung Zeile1+Zeile2 soll im Lösungsschritt Gauss/LR-Zerlegung in der ersten Spalte 0 ergeben:[br]11q + 21 = 0[br]q = -21/11 oder allgemein q = -A(2,1)/A(1,1)[/size][br]Je nach Versionszustand muss die Matrixindizierung auch via Befehl ELEMENT erfolgen: A(2,1) = ELEMENT(A,2,1)![br]
[br]
[br]
Inverse
[size=100]Den Vorzeichenwechsel der Matrix-Elemente unter der Diagonalen lässt sich rechnerisch darstellen: die Einheitsmatrix mit 2 multiplizieren und dann die Matrix L1 abziehen: [br]L1^-1 = 2 E - L1 [br][/size]
Gauß-Algorithmus R4x4
Aus einer Matrix[br] [math]A=\left(\begin{array}{rrrr}a_{11}&a_{12}&a_{13}&a_{14}\\a_{21}&a_{22}&a_{23}&a_{24}\\a_{31}&a_{32}&a_{33}&a_{34}\\a_{41}&a_{42}&a_{43}&a_{44}\\\end{array}\right)[/math] [br]generiere ich die Gaußelimationsfaktoren für L[sub]1[/sub] aus der 1. Spalte[br] [math]\frac{1}{a_{11}} \; \left(\begin{array}{r}a_{11}\\a_{21}\\a_{31}\\a_{41}\\\end{array}\right)[/math] [br]dividiere durch a[sub]11[/sub], alle Faktoren mal (-1) (alles unter a[sub]11[/sub]) und fülle zur Einheitsmatix auf.[br]In der 1. Spalte stehen die Faktoren mit denen die 1.Zeile multipliziert wird. Um dann per Matrixprodukt zur Faktorzeile addiert zu werden. Alle Zeilen 2,3,4..n werden geändert mit Nullen in der ersten Spalte. [br] [math]L_1= \, \left(\begin{array}{rrrr}1&0&0&0\\\frac{-a_{21}}{a_{11}}&1&0&0\\\frac{-a_{31}}{a_{11}}&0&1&0\\\frac{-a_{41}}{a_{11}}&0&0&1\\\end{array}\right)[/math][math]\Longrightarrow L_1\cdot A=[/math][math] \, \left(\begin{array}{rrrr}a_{11}&a_{12}&a_{13}&a_{14}\\0&c_{22}&c_{23}&c_{24}\\0&c_{32}&c_{33}&c_{34}\\0&c_{42}&c_{43}&c_{44}\\\end{array}\right)[/math] [br]Wiederhole Algorithmus auf der Matrix (c[sub]ij[/sub]) [br] [math]L_2=\left(\begin{array}{rrrr}1&0&0&0\\0&1&0&0\\0&\frac{-c_{32}}{c_{22}}&1&0\\0&\frac{-c_{42}}{c_{22}}&0&1\\\end{array}\right) \Longrightarrow L_2\cdot L_1\cdot A=\left(\begin{array}{rrrr}a_{11}&a_{12}&a_{13}&a_{14}\\0&c_{22}&c_{23}&c_{24}\\0&0&u_{33}&u_{34}\\0&0&u_{43}&u_{44}\\\end{array}\right)[/math] [br]Wiederhole Algorithmus auf Matric (u[sub]ij[/sub])[br][math]L_{3}=\left(\begin{array}{rrrr}1&0&0&0\\0&1&0&0\\0&0&1&0\\0&0&\frac{-u_{43}}{u_{33}}&1\\\end{array}\right) \Longrightarrow L_3 \cdot L_2\cdot L_1\cdot A=\left(\begin{array}{rrrr}a_{11}&a_{12}&a_{13}&a_{14}\\0&c_{22}&c_{23}&c_{24}\\0&0&u_{33}&u_{34}\\0&0&0&-u_{34} \cdot \frac{u_{43}}{u_{33}} + u_{44}\\\end{array}\right)[/math] [br]
Zusammenfassung
In den diskutierten Beispielen habe ich einige Matrix-Operationen und Eigenschaften der verwendeten Matrizen zusammen gestellt, die auf dem Weg zur Lösung von linearen GLS zur Anwendung kommen.[br]Matrizentechnisch ist ggb schwach aufgestellt. Viele Funktionalitäten fehlen![br][br]Zeilenzugriffe[br]{Take(A,2,2),Element(A,2)}[br][math] \left\{ \left(\begin{array}{rrrr}a_{21}&a_{22}&a_{23}&a_{24}\\\end{array}\right), \left\{ a_{21}, a_{22}, a_{23}, a_{24} \right\} \right\} [/math] [br]Take => Zeilenvektor, Element => Liste[br][br]Spaltenzugriffe (transponieren um Spalten als Zeilen abzugreifen und Rücktransponieren zu Spalten)[br]{Transpose(Take(Transpose(A),2,2)),Transpose(Element(Transpose(A),2))}[br][math] \left\{ \left(\begin{array}{r}a_{12}\\a_{22}\\a_{32}\\a_{42}\\\end{array}\right), \left(\begin{array}{r}a_{12}\\a_{22}\\a_{32}\\a_{42}\\\end{array}\right) \right\} [/math][br]Uneinheitliches Ergebnis, durchs Transponeren wird die (Element) Liste zum Spaltenvektor? [br][br][color=#ff0000]Achtung[/color]: Beim Übergang zu LGS n>3 erfolgt auch ein Paradigmenwechsel von Vektor zu Liste/Matrix. [br]Grundsätzlich ist die bisher praktizierte Praxis einen Vektor als Liste {1,2,3,4} darzustellen u.U. ein Problem. Besser ist es einen Vektor als 1-spaltige Matrix zu schreiben {{1},{2},{3},{4}} oder als 1-zeilige Matrix {{1,2,3,4}} die transponiert Transpose({{1,2,3,4}}) wieder eine 1-spaltige Matrix darstellt - macht halt mehr Scheibarbeit.[br]Nach meiner Erfahrung ist das Matrix*Vektor-Produkt (ggb-Vektoren) auch immer für Überraschungen gut - unterscheide Punkt/Vektor![br][br][img][/img][br][br]Ich beginne eine neues Arbeitsblatt um ein konkretes GLS mittels Gauss-Algorithmus bzw. mittels LR-Zerlegung zu lösen.[br][br]Siehe [url=https://ggbm.at/U7VHfY5J]KonvertGLS2Matrix.ggb[/url], um aus einem in x1,x2,x3... gegebenen GLS die Matrixgleichung A x = b heraus zu ziehen.
Anwendung CAS-User-Functions Lineare Gleichungsysteme
Rang, Kern in-,sur-,bijektiv
Rang der Matrix = Anzahl der Spalten ⇔ Abbildungs-Matrix ist injektiv.[br]Rang der Matrix = Anzahl der Zeilen ⇔ Abbildungs-Matrix ist surjektiv.[br]Kern der Matrix = 0 ⇔ Abbildungs-Matrix ist injektiv.[br][br]Bei quadratischen Abbildungs-Matrizen folgt aus der Surjketivität die Injektivitiät und umgekehrt aus der Injektivität die Surjektivität.[br]Wenn die Determinante einer quadratischen Matrix ≠0 ist, kann man die Matrix invertieren, also gibt es eine Umkehrabbildung. Die Abbildungs-Matrix ist dann bijektiv. Das gilt auch umgekehrt. 

Information: Grundsätzliche Matrix-Operationen