Kernighan-Lin-Algorithmus

Der Kernighan-Lin-Algorithmus ist ein 1969 formulierter heuristischer Algorithmus von Brian W. Kernighan und Shen Lin, um das Graphpartitionierungsproblem zu lösen. In der Praxis wird er eingesetzt, um die Komponentenplatzierung auf einem Chip zu optimieren. Dabei soll die Länge der Leitungen zwischen den Komponenten minimal gehalten werden.

Beschreibung

Sei ein kantengewichteter Graph mit Knotenmenge und Kantenmenge . Der Algorithmus soll in zwei disjunkte Untermengen A und B gleicher Größe aufteilen, sodass die Summe der Kantengewichte zwischen A und B minimal wird. Die internen Kosten von A, also die Summe aller Kantengewichte abgehend vom Knoten a in A, wird als bezeichnet. seien die externen Kosten vom Knoten a, also die Summe aller Kosten der Kanten zwischen a und den Knoten in B.

ist die Differenz der externen und internen Kantengewichte. Werden Knoten a und b getauscht, so ist

,

hierbei sind die Kosten der Kante zwischen a und b.

Der Algorithmus versucht nun, die Elemente der Mengen A und B optimal zu tauschen, sodass maximal wird.[1]

Einzelnachweise

  1. B. W. Kernighan, Shen Lin: An efficient heuristic procedure for partitioning graphs. In: Bell Systems Technical Journal. 49, 1970, S. 291–307.