SPQR strom - SPQR tree
v teorie grafů, obor matematiky, tři propojené komponenty a biconnected graph jsou systém menších grafů, které popisují všechny 2-vertexové řezy v grafu. An SPQR strom je stromová datová struktura použito v počítačová věda a konkrétněji grafové algoritmy, reprezentovat triconnected komponenty grafu. Strom SPQR grafu může být sestaven v lineární čas[1] a má několik aplikací ve Windows algoritmy dynamického grafu a kreslení grafu.
Základní struktury, které jsou základem stromu SPQR, triconnected komponenty grafu a spojení mezi tímto rozkladem a rovinnými vložkami a rovinný graf, byly nejprve vyšetřovány Saunders Mac Lane (1937 ); tyto struktury byly použity v efektivních algoritmech několika dalšími výzkumníky[2] před jejich formalizací Di Battista a Tamassia jako stromu SPQR (1989, 1990, 1996 ).
Struktura
Strom SPQR má podobu nezakořeněný strom ve kterém pro každý uzel X je přidružen neorientovaný graf nebo multigraf GX. Uzel a k němu přidružený graf může mít jeden ze čtyř typů, vzhledem k iniciálám SPQR:
- V uzlu S je přidružený graf a graf cyklu se třemi nebo více vrcholy a hranami. Tento případ je analogický se sériovým složením v sériově paralelní grafy; S znamená „série“.[3]
- V uzlu P je přidružený graf a dipólový graf, multigraf se dvěma vrcholy a třemi nebo více hranami, planární duální do grafu cyklu. Tento případ je analogický s paralelním složením v sériově paralelní grafy; P znamená „paralelní“.[3]
- V uzlu Q má přidružený graf jednu skutečnou hranu. Tento triviální případ je nezbytný pro zpracování grafu, který má pouze jednu hranu. V některých pracích na stromech SPQR se tento typ uzlu neobjevuje ve stromech SPQR grafů s více než jednou hranou; v jiných pracích musí být všechny nevirtuální hrany reprezentovány Q uzly s jednou skutečnou a jednou virtuální hranou a hrany v ostatních typech uzlů musí být všechny virtuální.
- V uzlu R je přidružený graf 3-připojený graf, který není cyklem nebo dipólem. R znamená „rigidní“: v aplikaci stromů SPQR při vkládání rovinných grafů má přidružený graf uzlu R jedinečné rovinné vkládání.[3]
Každá hrana xy mezi dvěma uzly stromu SPQR je spojen se dvěma směrovanými virtuální hrany, z nichž jeden je hrana v GX a druhá z nich je hrana v Gy. Každá hrana v grafu GX může být virtuální hranou pro maximálně jednu hranu stromu SPQR.
Strom SPQR T představuje 2 propojený graf GT, vytvořený následovně. Kdykoli hrana stromu SPQR xy přidruží virtuální hranu ab z GX s virtuální hranou CD z Gy, vytvoří jeden větší graf sloučením A a C do jednoho supervertexu, sloučení b a d do jiného jediného supervertexu a odstranění dvou virtuálních hran. To znamená, že větší graf je Součet 2 klik z GX a Gy. Provedení tohoto kroku lepení na každém okraji stromu SPQR vytvoří graf GT; pořadí provedení kroků lepení nemá vliv na výsledek. Každý vrchol v jednom z grafů GX mohou být spojeny tímto způsobem s jedinečným vrcholem v GT, supervertex, do kterého byl sloučen.
Typicky není ve stromu SPQR povoleno, aby sousedily dva S uzly, ani aby sousedily dva P uzly, protože pokud by k takové sousednosti došlo, mohly by být dva uzly sloučeny do jediného většího uzlu. S tímto předpokladem je strom SPQR jednoznačně určen z jeho grafu. Když graf G je reprezentován stromem SPQR bez sousedních P uzlů a bez sousedních S uzlů, poté grafy GX spojené s uzly stromu SPQR jsou známé jako triconnected komponenty G.
Konstrukce
Strom SPQR daného grafu připojeného ke 2 vrcholům lze postavit v lineární čas.[1]
Problém konstrukce tří propojených složek grafu byl poprvé vyřešen v lineárním čase pomocí Hopcroft & Tarjan (1973). Na základě tohoto algoritmu Di Battista & Tamassia (1996) navrhl, že úplná stromová struktura SPQR, nejen seznam komponent, by měla být konstruovatelná v lineárním čase. Poté, co byla jako součást knihovny GDToolkit poskytnuta implementace pomalejšího algoritmu pro stromy SPQR, Gutwenger & Mutzel (2001) za předpokladu první implementace v lineárním čase. V rámci tohoto procesu implementace tohoto algoritmu opravili také některé chyby v dřívější práci Hopcroft & Tarjan (1973).
Algoritmus Gutwenger & Mutzel (2001) zahrnuje následující celkové kroky.
- Seřaďte okraje grafu podle dvojic číselných indexů jejich koncových bodů pomocí varianty radix sort což dělá dva průchody kbelík třídění, jeden pro každý koncový bod. Po tomto kroku třídění budou rovnoběžné hrany mezi stejnými dvěma vrcholy vedle sebe v seřazeném seznamu a lze je rozdělit na P-uzel případného stromu SPQR, takže zbývající graf zůstane jednoduchý.
- Rozdělte graf na rozdělené komponenty; jedná se o grafy, které lze vytvořit vyhledáním dvojice oddělovacích vrcholů, rozdělením grafu na těchto dvou vrcholech na dva menší grafy (s propojenou dvojicí virtuálních hran s oddělovacími vrcholy jako koncovými body) a opakováním tohoto dělícího procesu, dokud již nebudou existují oddělující páry. Takto nalezený oddíl není jednoznačně definován, protože části grafu, které by se měly stát S-uzly stromu SPQR, budou rozděleny do několika trojúhelníků.
- Označte každou rozdělenou komponentu P (rozdělená složka se dvěma vrcholy s více hranami), S (rozdělená složka ve formě trojúhelníku) nebo R (jakákoli jiná rozdělená složka). I když existují dvě rozdělené komponenty, které sdílejí propojenou dvojici virtuálních hran, a obě komponenty mají typ S nebo obě mají typ P, sloučte je do jedné větší komponenty stejného typu.
Chcete-li najít rozdělené komponenty, Gutwenger & Mutzel (2001) použití hloubkové vyhledávání najít strukturu, kterou nazývají palma; toto je hloubkový první vyhledávací strom s jeho hranami orientované od kořene stromu pro hrany patřící ke stromu a směrem ke kořenu pro všechny ostatní hrany. Poté najdou speciální předobjednávka číslování uzlů ve stromu a pomocí určitých vzorů v tomto číslování identifikujte dvojice vrcholů, které mohou rozdělit graf na menší komponenty. Pokud je komponenta nalezena tímto způsobem, a struktura dat zásobníku se používá k identifikaci hran, které by měly být součástí nové komponenty.
Používání
Nalezení 2-vrcholných řezů
Se stromem SPQR grafu G (bez uzlů Q) je snadné najít každý pár vrcholů u a proti v G takové, že odstranění u a proti z G ponechá odpojený graf a připojené komponenty zbývajících grafů:
- Dva vrcholy u a proti mohou být dva koncové body virtuální hrany v grafu přidružené k R uzlu, přičemž v tomto případě jsou tyto dvě komponenty reprezentovány dvěma podstromy stromu SPQR vytvořenými odstraněním odpovídajícího okraje stromu SPQR.
- Dva vrcholy u a proti mohou být dva vrcholy v grafu přidružené k uzlu P, který má dva nebo více virtuálních okrajů. V tomto případě součásti vytvořené odstraněním u a proti jsou zastoupeny podstromy stromu SPQR, jedním pro každou virtuální hranu v uzlu.
- Dva vrcholy u a proti mohou být dva vrcholy v grafu spojené s uzlem S tak, že buď u a proti nejsou sousedící nebo hrany uv je virtuální. Pokud je hrana virtuální, pak dvojice (u,proti) také patří do uzlu typu P a R a komponenty jsou popsány výše. Pokud tyto dva vrcholy nesousedí, pak jsou tyto dvě složky reprezentovány dvěma cestami grafu cyklu spojenými s uzlem S as uzly stromu SPQR připojenými k těmto dvěma cestám.
Představující všechny vložení rovinných grafů
Pokud je rovinný graf spojen se 3 spoji, má jedinečné rovinné zakotvení až do výběru, která plocha je vnější plocha a orientace vložení: plochy vložení jsou přesně neoddělitelné cykly grafu. Avšak u rovinného grafu (se značenými vrcholy a hranami), který je spojen 2, ale ne 3, může existovat větší volnost při hledání rovinného vložení. Konkrétně, kdykoli jsou dva uzly ve stromu SPQR grafu spojeny dvojicí virtuálních hran, je možné otočit orientaci jednoho z uzlů (nahradit jej zrcadlovým obrazem) vzhledem k druhému. Navíc v P uzlu stromu SPQR mohou být různé části grafu připojené k virtuálním okrajům P uzlu libovolně permutovaný. Tímto způsobem lze popsat všechny rovinné reprezentace.[4]
Viz také
- Blokovaný strom, podobná stromová struktura pro komponenty připojené ke 2 vrcholům
- Gomory – Hu strom, odlišná stromová struktura, která charakterizuje konektivitu okraje grafu
- Rozklad stromů, zobecnění (již není jedinečné) pro větší řezy
Poznámky
- ^ A b Hopcroft & Tarjan (1973); Gutwenger & Mutzel (2001).
- ^ Např., Hopcroft & Tarjan (1973) a Bienstock & Monma (1988), z nichž oba jsou uvedeny jako precedenty Di Battista a Tamassia.
- ^ A b C Di Battista & Tamassia (1989).
- ^ Mac Lane (1937).
Reference
- Bienstock, Daniel; Monma, Clyde L. (1988), „O složitosti pokrytí vrcholů plochami v rovinném grafu“, SIAM Journal on Computing, 17 (1): 53–76, CiteSeerX 10.1.1.542.2314, doi:10.1137/0217004.
- Di Battista, Giuseppe; Tamassia, Roberto (1989), „Inkrementální testování rovinnosti“, Proc. 30. výroční sympozium o základech informatiky, str. 436–441, doi:10.1109 / SFCS.1989.63515.
- Di Battista, Giuseppe; Tamassia, Roberto (1990), „On-line graph algorithms with SPQR-trees“, Proc. 17. mezinárodní kolokvium o automatech, jazycích a programování, Přednášky z informatiky, 443, Springer-Verlag, str. 598–611, doi:10.1007 / BFb0032061.
- Di Battista, Giuseppe; Tamassia, Roberto (1996), „On-line testování rovinnosti“ (PDF), SIAM Journal on Computing, 25 (5): 956–997, doi:10.1137 / S0097539794280736.
- Gutwenger, Carsten; Mutzel, Petra (2001), „Lineární časová implementace stromů SPQR“, Proc. 8. mezinárodní sympozium o kreslení grafů (GD 2000), Přednášky v informatice, 1984, Springer-Verlag, str. 77–90, doi:10.1007/3-540-44541-2_8.
- Hopcroft, Johne; Tarjan, Robert (1973), „Rozdělení grafu na tři propojené komponenty“, SIAM Journal on Computing, 2 (3): 135–158, doi:10.1137/0202012, hdl:1813/6037.
- Mac Lane, Saunders (1937), „Strukturální charakterizace rovinných kombinatorických grafů“, Duke Mathematical Journal, 3 (3): 460–472, doi:10.1215 / S0012-7094-37-00336-3.
externí odkazy
- Implementace SPQR stromu v Open Graph Drawing Framework.
- Strom implementace Java se třemi propojenými komponentami v knihovně jBPT (viz třída TCTree).