Cuthill-McKee-Algorithmus

aus Wikipedia, der freien Enzyklopädie
Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 8. Februar 2016 um 12:08 Uhr durch 2a02:810d:d00:fdb4:5861:1bf1:99f8:f57f (Diskussion) (→‎Wahl des Startknotens). Sie kann sich erheblich von der aktuellen Version unterscheiden.
Zur Navigation springen Zur Suche springen
Cuthill-McKee-Sortierung derselben Matrix
Umgekehrte Cuthill-McKee-Sortierung derselben Matrix

Der Cuthill-McKee-Algorithmus (benannt nach Elizabeth Cuthill und J. McKee) ist in der numerischen Mathematik ein Algorithmus, der eine symmetrische dünnbesetzte Matrix in eine Bandmatrix mit einer geringeren Bandbreite transformiert.[1] Für Bandmatrizen existieren sehr effiziente Berechnungsalgorithmen, beispielsweise für die Lösung von sehr großen linearen Gleichungssystemen (siehe BLAS).

Der umgekehrte Cuthill-McKee-Algorithmus von Alan George ist derselbe Algorithmus mit umgekehrter Indexreihenfolge. Im Allgemeinen führt der umgekehrte Algorithmus zu einem geringeren Fill-in, wenn eine Gaußelimination durchgeführt wird. Unter „Fill-in“ versteht man das Entstehen von Nichtnull-Elementen an Positionen, die in der ursprünglichen Matrix mit Null besetzt sind.[2]

Der Cuthill-McKee-Algorithmus unterscheidet sich von der Breitensuche für Graphen durch seine Reihenfolge, die durch Nummerierung adjazenter Knoten anhand ihres Grades ermittelt wird.

Algorithmus

Es sei eine Adjazenzmatrix, also eine symmetrische Matrix, die als Einträge nur Nullen und Einsen besitzt. Der Cuthill-McKee-Algorithmus ist eine Umnummerierung der Knoten des durch die Adjazenzmatrix repräsentierten Graphen, um die Bandbreite der Adjazenzmatrix zu reduzieren. Der Algorithmus errechnet ein -Tupel von Knoten, die die neue Reihenfolge darstellen, wie folgt:

  • Man wähle einen Knoten und setze .
  • Für führe, solange ist, folgende Schritte aus:
  • Konstruiere die Menge der adjazenten Knoten von , wobei die -te Komponente von ist, und schließe alle Knoten aus, die schon in enthalten sind:
  • Sortiere nach steigendem Knotengrad.
  • Hänge an das Ergebnis-Tupel an.

Wahl des Startknotens

Aufgrund der kleineren Adjazenzmenge von peripheren Knoten (Knoten deren Exzentrizität gleich dem Durchmesser des Graphen ist), ist es sinnvoll einen solchen als Startknoten zu wählen. Es ist jedoch sehr aufwändig einen peripheren Knoten zu ermitteln (NP-Vollständiges Problem). Man begnügt sich daher mit einem pseudo-peripheren Knoten, der auf folgende Weise ermittelt wird:

  1. Man wähle einen beliebigen Knoten .
  2. Man erzeuge die Schichtung mit der Wurzel .
  3. Man wähle einen beliebigen Knoten minimalen Grades .
  4. Man erzeuge die Schichtung mit der Wurzel . Falls , ersetze man durch und gehe nach 3..
  5. ist ein pseudo-peripherer Knoten.

Als Exzentrizität eines Knotens eines zusammenhängenden Graphen bezeichnet man die Größe

Anwendung

Der Algorithmus wird angewendet, um die Bandbreite von Matrizen zu reduzieren und damit den Aufwand der Gauß-Elimination bei der Lösung linearer Gleichungssysteme zu verringern.

Weblinks

Einzelnachweise

  1. E. Cuthill and J. McKee. Reducing the bandwidth of sparse symmetric matrices In Proc. 24th Nat. Conf. ACM, pages 157–172, 1969.
  2. J. A. George and J. W-H. Liu, Computer Solution of Large Sparse Positive Definite Systems, Prentice-Hall, 1981