Isomorphie von Graphen
Die Isomorphie von Graphen (oder Graphenisomorphie) ist in der Graphentheorie die Eigenschaft zweier Graphen, strukturell gleich zu sein.
Bei der Untersuchung graphentheoretischer Probleme kommt es meist nur auf die Struktur der Graphen, nicht aber auf die Bezeichnung ihrer Knoten an. In den allermeisten Fällen sind die untersuchten Grapheneigenschaften dann invariant bzgl. Isomorphie (gr. ἴσος ísos „gleich" und μορφή morphé „Form", „Gestalt"), die im Folgenden genauer definiert wird.
Definitionen
[Bearbeiten | Quelltext bearbeiten ]Seien {\displaystyle G_{1}=\left(V_{1},E_{1}\right)} und {\displaystyle G_{2}=\left(V_{2},E_{2}\right)} Graphen desselben Typs. Eine bijektive Abbildung {\displaystyle p\colon V_{1}\to V_{2}} heißt Isomorphismus zwischen {\displaystyle G_{1}} und {\displaystyle G_{2}}, falls gilt:
- {\displaystyle \left\{v,w\right\}} ist Kante von {\displaystyle G_{1}} genau dann, wenn {\displaystyle \left\{p(v),p(w)\right\}} Kante von {\displaystyle G_{2}} ist in ungerichteten Graphen ohne Mehrfachkanten.
- {\displaystyle \left(v,w\right)} ist Kante von {\displaystyle G_{1}} genau dann, wenn {\displaystyle \left(p\left(v\right),p\left(w\right)\right)} Kante von {\displaystyle G_{2}} ist in gerichteten Graphen ohne Mehrfachkanten.
- {\displaystyle E_{1}\left(\left\{v,w\right\}\right)=E_{2}\left(\left\{p\left(v\right),p\left(w\right)\right\}\right)} in ungerichteten Graphen mit Mehrfachkanten, d. h., je zwei Ecken sind mit ebenso vielen Kanten verbunden wie ihre Bildecken.
- {\displaystyle E_{1}\left(\left(v,w\right)\right)=E_{2}\left(\left(p\left(v\right),p\left(w\right)\right)\right)} in gerichteten Graphen mit Mehrfachkanten.
- {\displaystyle \left\{v_{1},\dotsc ,v_{k}\right\}} ist Kante von {\displaystyle G_{1}} genau dann, wenn {\displaystyle \left\{p\left(v_{1}\right),\dotsc ,p\left(v_{k}\right)\right\}} Kante von {\displaystyle G_{2}} ist in Hypergraphen.
Zwei Graphen heißen zueinander isomorph, falls es einen Isomorphismus zwischen ihnen gibt. Die Abbildung {\displaystyle p} heißt Automorphismus von {\displaystyle G_{1}} bzw. {\displaystyle G_{2}}, falls zusätzlich {\displaystyle G_{1}=G_{2}} gilt.
Prüfung auf Isomorphie und Graphen-Isomorphismus-Problem
[Bearbeiten | Quelltext bearbeiten ]Zur Prüfung der Isomorphie zweier gegebener Graphen ist kein effizienter (polynomialzeitlicher) Algorithmus bekannt. Mehr noch, die Komplexität des bestmöglichen Algorithmus ist bis heute noch nicht bestimmt. Insbesondere ist die Isomorphie von Graphen eines der wenigen bekannten Probleme in NP, für die weder bekannt ist, ob sie in P enthalten, noch ob sie NP-vollständig sind. Die Frage, ob das Graphen-Isomorphismus-Problem in P ist (oder ob es NP-vollständig ist) ist eines der großen offenen Probleme der Informatik. Es ist das letzte der 12 Probleme in dem Buch Computers and Intractability (1979) von Michael Garey und David S. Johnson, von denen nicht bekannt ist, in welche der Komplexitätsklassen NP-vollständig oder P sie gehören (oder nicht gehören). Deshalb wurde es auch schon als eigene Komplexitätsklasse GI definiert und es wurde untersucht, ob andere Probleme GI-schwer oder GI-vollständig sind, wobei die Definitionen in analoger Weise wie bei NP-schwer und NP-vollständig erfolgen.
László Babai gab im Dezember 2015 an, einen Algorithmus gefunden zu haben, der das Problem in der Zeit {\displaystyle e^{{(\log {n})}^{O(1)}}} löst (mit der Anzahl {\displaystyle n} der Knoten des Graphen).[1] [2] [3] [4] [5] Dieses Verhalten wird als quasipolynomial bezeichnet, da die Laufzeit schneller als polynomial wächst, aber einem polynomialen Verhalten nahe kommt. Die vorher beste Abschätzung stammte von Babai und Eugene Luks 1983,[6] die die Schranke {\displaystyle e^{O({\sqrt {(n\cdot \log {n})}})}} angab.
Beispiel
[Bearbeiten | Quelltext bearbeiten ]Diese beiden Graphen sind isomorph, obwohl ihre Darstellungen sich erheblich unterscheiden.
Software
[Bearbeiten | Quelltext bearbeiten ]- nauty. Ein Programm zur Berechnung der Automorphismengruppen und der kanonischen Labelings von Graphen. Zwei Graphen sind genau dann isomorph, wenn ihre kanonischen Labelings übereinstimmen.
- NetworkX. Eine freie Python-Bibliothek [7]
Siehe auch
[Bearbeiten | Quelltext bearbeiten ]Einzelnachweise
[Bearbeiten | Quelltext bearbeiten ]- ↑ Babai: Graph Isomorphism in Quasipolynomial Time. Arxiv 2015. Auf seiner Homepage gab er im Januar 2017 an, dass ein von Harald Helfgott gefundener Fehler korrigiert werden konnte.
- ↑ Babai, Graph isomorphism in quasipolynomial time [extended abstract, STOC '16: Proceedings of the forty-eighth annual ACM symposium on Theory of Computing, Juni 2016, S. 684–697]
- ↑ Erica Klarreich, Graph isomorphism vanquished - again, Quanta Magazine, Januar 2017
- ↑ Harald Helfgott, Isomorphismes de graphes en temps quasi-polynomial (d'après Babai et Luks, Weisfeiler-Leman...), Seminaire Bourbaki, Nr. 1125, Januar 2017, Arxiv
- ↑ László Babai: Groups, Graphs, Algorithms: The Graph Isomorphism Problem. Proc. ICM 2018, Rio de Janeiro, Online
- ↑ Babai, Luks: Canonical labeling of graphs. Proceedings of the Fifteenth Annual ACM Symposium on Theory of Computing (STOC ’83), 1983, S. 171–183.
- ↑ Algorithms - Isomorphism. In: NetworkX 2.2 documentation. Abgerufen am 25. Oktober 2018 (englisch).