Matrix-Vektor-Produkt

Aus testwiki
Zur Navigation springen Zur Suche springen
Bei einer Matrix-Vektor-Multiplikation muss die Spaltenzahl der Matrix gleich der Zahl der Komponenten des Vektors sein. Die Komponentenzahl des Ergebnisvektors entspricht dann der Zeilenzahl der Matrix.

Das Matrix-Vektor-Produkt ist in der linearen Algebra das Produkt einer Matrix mit einem Spaltenvektor. Damit eine solche Matrix-Vektor-Multiplikation durchgeführt werden kann, muss die Spaltenzahl der Matrix mit der Zahl der Komponenten des Vektors übereinstimmen. Das Ergebnis ist dann wieder ein Spaltenvektor, dessen Elemente durch komponentenweise Multiplikation und Summation der Einträge der entsprechenden Zeile der Matrix mit den Elementen des Ausgangsvektors ermittelt werden. Das Matrix-Vektor-Produkt kann als Spezialfall einer Matrizenmultiplikation angesehen werden, bei der die zweite Matrix aus nur einer Spalte besteht.

Das Matrix-Vektor-Produkt wird beispielsweise in der Matrixschreibweise linearer Gleichungssysteme sowie bei iterativen Verfahren zu ihrer numerischen Lösung eingesetzt. Weiter kann jede lineare Abbildung zwischen endlichdimensionalen Vektorräumen nach Wahl entsprechender Basen als Matrix-Vektor-Produkt dargestellt werden.

Definition

Zur Berechnung des Matrix-Vektor-Produkts wird jede Zeile der Matrix mit den Einträgen des Vektors kombiniert.

Ist K ein Körper (meist die reellen oder komplexen Zahlen), dann ist die Matrix-Vektor-Multiplikation eine Abbildung

:Km×n×KnKm,(A,x)y=Ax,

die einer Matrix A=(aij) und einem Spaltenvektor x=(xj) einen weiteren Spaltenvektor y=(yi) zuordnet. Die Matrix-Vektor-Multiplikation ist dabei nur für den Fall definiert, dass die Spaltenzahl n der Matrix A mit der Zahl der Komponenten des Vektors x übereinstimmt. Die Komponentenzahl des Ergebnisvektors y entspricht dann der Zeilenzahl m der Matrix A. Jedes Element yi des Ergebnisvektors berechnet sich dabei über

yi=j=1naijxj,

also durch komponentenweise Multiplikation der Einträge der i-ten Zeile von A mit den Elementen von x und durch Summation über diese Produkte. Häufig wird bei der Notation eines Matrix-Vektor-Produkts der Malpunkt weggelassen und man schreibt kurz Ax statt Ax.

Beispiel

Gegeben sei die reelle Matrix und der reelle (Spalten-)Vektor

A=(321102)2×3   und   x=(104)3.

Da die Matrix A ebenso viele Spalten besitzt, wie der Vektor x lang ist, ist das Matrix-Vektor-Produkt Ax definiert, die betreffende Matrix-Vektor-Multiplikation also überhaupt durchführbar. Nachdem A zwei Zeilen hat, wird der Ergebnisvektor y ebenfalls zwei Elemente aufweisen. Um das erste Element des Ergebnisvektors zu berechnen, betrachtet man die erste Zeile von A, multipliziert die jeweils entsprechenden Einträge dieser Zeile mit denen des Ausgangsvektors und summiert die Ergebnisse auf (die Sternchen stehen für noch nicht berechnete Elemente):

(321102)(104)=(31+20+14)=(7)

Für das zweite Element des Ergebnisvektors betrachtet man entsprechend die zweite Zeile von A und berechnet analog:

(321102)(104)=(711+00+24)=(79)

Als Ergebnis erhält man so am Ende das Matrix-Vektor-Produkt y=Ax.

Eigenschaften

Das Matrix-Vektor-Produkt ist assoziativ in dem Sinne, dass für Matrizen AKl×m, BKm×n und Vektoren xKn

A(Bx)=(AB)x

gilt. Das Matrix-Vektor-Produkt ist auch verträglich mit der Multiplikation von Skalaren aK, das heißt

a(Ax)=(aA)x=A(ax).

Betrachtet man die komponentenweise Matrizenaddition A+B zweier Matrizen A,BKm×n sowie die Vektoraddition zweier Vektoren x,yKn, dann sind auch die Distributivgesetze erfüllt, das heißt

(A+B)x=Ax+Bx

und

A(x+y)=Ax+Ay.

Algorithmus

In Pseudocode kann das Matrix-Vektor-Produkt wie folgt implementiert werden:

function matrix-vector-product(A,x,m,n)
  y = zeroes(m)                      // Ergebnisvektor y mit Nullen initialisieren
  for i = 1 to m                     // Schleife über die Zeilen von A
    for j = 1 to n                   // Schleife über die Elemente von x
      y(i) = y(i) + A(i,j) * x(j)    // Bildung der Produktsumme
    end
  end
  return y

Die Reihenfolge der beiden For-Schleifen kann dabei auch vertauscht werden. Da die beiden Schleifen unabhängig voneinander sind, ist die Anzahl der benötigten arithmetischen Operationen von der Ordnung

O(mn).

Die Laufzeit des Algorithmus ist für quadratische Matrizen (m=n) demnach von der Ordnung O(n2). Spezielle Matrizen, wie Bandmatrizen, dünnbesetzte Matrizen oder Toeplitz-Matrizen, können durch Ausnutzen der Struktur auch effizienter mit einem Vektor multipliziert werden.

Geometrische Interpretation

Im bis zu 3-dimensionalen Fall einer Multiplikation von einer Matrix mit einem Vektor kann man schon anhand der Zahlen in der Matrix erkennen, wie die Matrix als lineare Abbildung "aussieht". Sei zum Beispiel eine 2-dimensionale Ebene mit den Basisvektoren

x=(10),y=(01) gegeben. Einen Vektor in dem 2-dimensionalen Vektorraum wird mit Hilfe der Basisvektoren dargestellt. Meistens werden implizit diese beiden Basisvektoren benutzt. Möchte man zum Beispiel den Vektor v=(47) als Linearkombination mit diesen Basisvektoren darstellen, so setzt sich der Vektor v durch v=4x+7y=4(10)+7(01) zusammen. Setzt man die Basisvektoren x und y als Matrix zusammen, erhält man (1001). Das ist die Einheitsmatrix E2. Möchte man zum Beispiel mit einer Matrix eine lineare Abbildung beschreiben, die eine 90° Drehung gegen den Uhrzeigersinn beschreibt, so kann man sich vorstellen, der x Basisvektor sich dreht und dann zu (01)wird. Dreht man den y Basisvektor um 90° gegen den Uhrzeigersinn, ergibt sich intuitiv (10). Die Matrix, die nun die 90° Rotation gegen den Uhrzeigersinn beschreibt, ist damit (0110). Aus dieser Betrachtungsweise kann man die Zahlen in einer Matrix geometrisch interpretieren.

Verwendung

Das Matrix-Vektor-Produkt wird in der linearen Algebra häufig verwendet. So ist die Matrixschreibweise eines linearen Gleichungssystems

Ax=b

nichts anderes als eine Vektorgleichung, auf deren linken Seite ein Matrix-Vektor-Produkt steht. Viele iterative Verfahren zur numerischen Lösung linearer Gleichungssysteme, wie das Verfahren der konjugierten Gradienten oder allgemeine Krylow-Unterraum-Verfahren, basieren auf wiederholten Matrix-Vektor-Multiplikationen. Auch die Potenzmethode zur Ermittlung des betragsgrößten Eigenwerts einer Matrix basiert auf der wiederholten Berechnung von Matrix-Vektor-Produkten.

Sind allgemein V und W zwei endlichdimensionale Vektorräume über dem gleichen Körper, dann kann jede lineare Abbildung f:VW nach Wahl je einer Basis in beiden Vektorräumen über ihre Abbildungsmatrix Mf dargestellt werden. Das Bild y eines Vektors x unter der Abbildung f in den jeweiligen Basen kann dann über das Matrix-Vektor-Produkt

y=Mfx

ermittelt werden. In der Geometrie lässt sich beispielsweise auf diese Weise jede Drehung um den Ursprung und jede Spiegelung an einer Ursprungsebene durch ein solches Matrix-Vektor-Produkt ausführen. Auch diskrete Faltungen, beispielsweise die diskrete Fourier-Transformation, können als Matrix-Vektor-Produkt realisiert werden.

In den Wirtschaftswissenschaften wird das Matrix-Vektor-Produkt bei der Input-Output-Analyse benutzt.

Literatur