Kanonizace grafů - Graph canonization
v teorie grafů, obor matematiky, kanonizace grafů je problém najít kanonická forma daného grafu G. Kanonická forma je a označený graf Kánon(G) to je izomorfní na G, takže každý graf, který je izomorfní G má stejnou kanonickou podobu jako G. Od řešení problému s kanonizací grafů by tedy bylo možné vyřešit také problém izomorfismus grafu: otestovat, zda dva grafy G a H jsou izomorfní, počítají jejich kanonické formy Canon (G) a Canon (H) a otestujte, zda jsou tyto dvě kanonické formy totožné.
Kanonická forma grafu je příkladem a kompletní graf neměnný: každé dva izomorfní grafy mají stejnou kanonickou formu a každé dva neizomorfní grafy mají různé kanonické formy.[1][2] Naopak, každý úplný invariant grafů lze použít ke konstrukci kanonické formy.[3] Vrcholová množina an n-vertexový graf lze identifikovat pomocí celá čísla od 1 do na pomocí takové identifikace lze kanonickou formu grafu také popsat jako a permutace jeho vrcholů. Kanonické formy grafu se také nazývají kanonické štítky,[4] a kanonizace grafů je také někdy známá jako kanonizace grafů.
Výpočetní složitost
Je zřejmé, že problém s kanonizací grafů je přinejmenším stejný výpočetně těžké jako problém grafového izomorfismu. Ve skutečnosti je izomorfismus grafů sudý AC0 -redukovatelný ke kanonizaci grafů. Stále však zůstává otevřenou otázkou, zda tyto dva problémy jsou polynomiální časový ekvivalent.[2]
Zatímco existence (deterministických) polynomiálních algoritmů pro izomorfismus grafů je stále otevřeným problémem teorie výpočetní složitosti, v roce 1977 László Babai uvádí, že s pravděpodobností alespoň 1 - exp (−O (n)), jednoduchý algoritmus klasifikace vrcholů vytváří kanonické značení grafu zvoleného náhodně rovnoměrně ze sady všech n-vertexové grafy po pouhých dvou krocích upřesnění. Malé úpravy a přidané hloubkové vyhledávání krok produkuje kanonické značení takto rovnoměrně vybraných náhodných grafů v lineárním očekávaném čase. Tento výsledek vrhá světlo na skutečnost, proč se mnoho hlášených algoritmů izomorfismu grafů chová v praxi dobře.[5][6] To byl důležitý průlom v pravděpodobnostní teorie složitosti který se stal široce známým ve své rukopisné podobě a který byl ještě dlouho poté, co byl ohlášen na sympoziu, citován jako „nepublikovaný rukopis“.
Běžně známá kanonická forma je lexikograficky nejmenší graf v rámci třída izomorfismu, což je graf třídy s lexikograficky nejmenší matice sousedství je považován za lineární řetězec. Výpočet lexikograficky nejmenšího grafu je však NP-tvrdé.[1]
U stromů je prezentován stručný algoritmus polynomiální kanonizace vyžadující O (n) prostor Číst (1972).[7] Začněte tím, že každý vrchol označíte řetězcem 01. Iterativně pro každý nelist x odstraňte úvodní 0 a koncovou 1 ze štítku x; potom seřaďte štítek x spolu se štítky všech sousedních listů v lexikografickém pořadí. Zřetězte tyto seřazené štítky, přidejte zpět úvodní 0 a koncovou 1, udělejte z tohoto nový štítek x a odstraňte sousední listy. Pokud zbývají dva vrcholy, zřetězte jejich popisky v lexikografickém pořadí.
Aplikace
Kanonizace grafů je podstatou mnoha algoritmů izomorfismu grafů. Jedním z předních nástrojů je Nauty.[8]
Běžná aplikace kanonizace grafů je v grafice dolování dat, zejména v chemická databáze aplikace.[9]
Počet identifikátory pro chemické substance, jako ÚSMĚVY a InChI při jejich výpočtu použít kroky kanonikalizace, což je v podstatě kanonizace grafu, který představuje molekulu.[10][11][12]Tyto identifikátory jsou navrženy tak, aby poskytovaly standardní (a někdy i čitelný pro člověka) způsob kódování molekulárních informací a usnadnily hledání těchto informací v databázích a na webu.
Reference
- ^ A b Arvind, Vikraman; Das, Bireswar; Köbler, Johannes (2008), „Algoritmus logického prostoru pro částečnou kanonizaci dvou stromů“, Computer Science - Theory and Applications: Third International Computer Science Symposium in Russia, CSR 2008 Moscow, Russia, 7-7 June, 2008, Proceedings, Poznámky k přednášce ve Výpočtu. Sci., 5010, Springer, Berlín, str. 40–51, doi:10.1007/978-3-540-79709-8_8, PAN 2475148.
- ^ A b Arvind, V .; Das, Bireswar; Köbler, Johannes (2007), „Vesmírná složitost vesmíru k-strom izomorfismu ", Algoritmy a výpočet: 18. mezinárodní sympozium, ISAAC 2007, Sendai, Japonsko, 17. – 19. Prosince 2007, sborník, Poznámky k přednášce ve Výpočtu. Sci., 4835, Springer, Berlín, str. 822–833, doi:10.1007/978-3-540-77120-3_71, PAN 2472661.
- ^ Gurevič, Jurij (1997), „Od invarianty ke kanonizaci“ (PDF), Bulletin Evropské asociace pro teoretickou informatiku (63): 115–119, PAN 1621595.
- ^ Babai, László; Luke, Eugene (1983), „Kanonické označování grafů“, Proc. 15. ACM Symposium on Theory of Computing, str. 171–183, doi:10.1145/800061.808746.
- ^ Babai, László (1977), O problému izomorfismu, nepublikovaný rukopis.
- ^ Babai, László; Kučera, L. (1979), „Kanonické značení grafů v lineárním průměrném čase“, Proc. 20. výroční sympozium IEEE o základech informatiky, str. 39–46, doi:10.1109 / SFCS.1979.8.
- ^ Přečtěte si, Ronald C. (1972), „Kódování různých druhů neoznačených stromů“, Teorie grafů a výpočty, Academic Press, New York, s. 153–182, PAN 0344150.
- ^ McKay, Brendan D .; Piperno, Adolfo (2014), „Journal of Symbolic Computation“, Praktický izomorfismus grafů, II, str. 94–112, ISSN 0747-7171.
- ^ Cook, Diane J .; Holder, Lawrence B. (2007), "6.2.1. Canonical Labeling", Data grafu těžby, str. 120–122, ISBN 0-470-07303-9.
- ^ Weininger, David; Weininger, Arthur; Weininger, Joseph L. (květen 1989). "SMILES. 2. Algoritmus pro generování jedinečné notace SMILES". Journal of Chemical Information and Modeling. 29 (2): 97–101. doi:10.1021 / ci00062a008.
- ^ Kelley, Brian (květen 2003). „Kanonizace grafů“. Dr. Dobb's Journal.
- ^ Scheider, Nadine; Sayle, Roger A .; Landrum, Gregory A. (říjen 2015). „Uspořádejte své atomy - open-source implementace nového a robustního algoritmu molekulární kanonizace“. Journal of Chemical Information and Modeling. 55 (10): 2111–2120. doi:10.1021 / acs.jcim.5b00543. PMID 26441310.