Certifikát K-připojení - K-connectivity certificate

Graf vpravo je a k- certifikát připojení pro graf G vlevo pro k = 1,2.

v teorie grafů, pro k-připojeno graf G = (V, E), podmnožina hran je považován za certifikát pro k-konektivita grafu G právě tehdy, je-li podgraf G '= (V, E') k-připojeno.[1]

Řídké certifikáty

Pro k-spojený graf s n vrcholy, vždy existuje a k-konektivita certifikát s maximálně k (n-1) hranami. Certifikáty K-připojení jsou považovány za řídké, pokud obsahují Ó(kn) hrany.[2] Na tomto obrázku je graf vpravo také řídkým certifikátem pro graf G nalevo.

Vyhledávání první skenování

Scan-First je algoritmus pro paralelní konstrukci k-konektivita certifikáty pro grafy. To bylo představeno v novinách Scan-First Search and Sparse Certificates: an Improved Parallel Algorithm for Konektivita K-Vertex Joseph Cheriyan, Ming-Yang Kao a Ramakrishna Thurimella.[2] Algoritmus prohledávání prvního skenování zlepšuje dobu chodu vytváření řídkého certifikátu k-konektivita pomocí paralelního výpočetního modelu.

Můžeme najít řídký certifikát pro k-konektivitu iterativním spuštěním prohledávání nejprve prohledáváním krát v dílčích grafech našeho vstupního grafu. Náš vstup je graf G = (V, E) a kořenový vrchol r. Pro každou iteraci vyhledávání na prvním skenování nejprve spočítáme spanning tree T našeho vstupního grafu G a přiřadíme číslování předobjednávek všem vrcholům, které použijeme jako naše pořadí skenování. Z našeho kořene r nejprve prohledáme r, což zahrnuje označení všech sousedních vrcholů.

Vzhledem k připojenému neorientovanému grafu a zadanému vrcholu je vyhledávání v grafu, které začíná nejprve od zadaného vrcholu, systematickým způsobem označení vrcholů. Je vyvolán hlavní krok značení skenovat: skenovat označený vrchol znamená označit všechny dříve neoznačené sousedy tohoto vrcholu. Na začátku hledání je označen pouze zadaný počáteční vrchol. Poté hledání iterativně skenuje označený a neskenovaný vrchol, dokud nebudou naskenovány všechny vrcholy.

Vyhledávání na prvním skenování v připojeném neorientovaném grafu vytvoří spanning tree definovaný následujícím způsobem. Na začátku hledání je strom prázdný. Potom pro každý vrchol x v grafu, když je skenováno x, jsou všechny hrany mezi x a jeho dříve neoznačenými sousedy přidány do stromu; hrany mezi x a jeho dříve označenými sousedy nejsou do stromu přidány.

Příklad ukazující dvě iterace vyhledávání nejprve skenováním v grafu G. U grafu k-Připojeno provedeme k iterace vyhledávání První skenování. První a druhá iterace vyhledávání první skenování jsou zobrazeny výše.

Všechny dříve neoznačené vrcholy tvoří koncový bod hrany z aktuálně naskenovaného vrcholu, takže pokud začneme od nějakého vrcholu v a má sousedy w a x, pak pokud jsou neoznačeny jak w, tak x, vytvoříme hrany (v , w) a (v, x) a přidejte je do našeho výstupního stromu T '. Pokud bylo dříve označeno buď w nebo x, nepřidáme hranu zahrnující tento vrchol k T '. S těmito novými hranami v T 'se přesuneme na další vrchol s nejnižším číslem předobjednávky, který se má skenovat, což zahrnuje kontinuální označování dříve neoznačených vrcholů a přidání hran z aktuálního vrcholu k těmto vrcholům do našeho výstupního stromu.

Pro generování certifikátů pro k-connectivity používáme prohledávání nejprve spuštěním pro k iterace. Důležitou poznámkou vpřed je, že pro každou hranu přidanou do nějakého výstupního stromu T 'v každé iteraci odstraníme hrany z původního grafu G, aby nemuseli být zahrnuty v nějakém překlenovacím lese pro další iteraci. Můžeme však zobrazit značky na vrcholech jako reset, takže při příští iteraci nejsou označeny žádné vrcholy.

Jakmile jsme vyčerpali všechny vrcholy, máme hranu nastavenou pro první iteraci, E.1. Poté odstraníme E.1 z G = G0a udělejte to G1, a přejděte na druhou iteraci pomocí grafu G1. Na konci každé iterace máme:

    • Ei : Sada hran, se kterými jsme se setkali během našeho prvního skenování
    • Fi : Prohledávací les pro první skenování, seskupení okrajů do samostatných stromů v každém kroku.
    • Gi : Výsledný graf odebrání Ei z grafu Gi-1 že jsme začali tuto iteraci.
    • Hi : Sjednocení hran od každé iterace až do současnosti, E1 ∪ E2 ∪ ... ∪ Ei.

Říkáme to Hk je řídký certifikát pro graf G.

Hlavní věta certifikátu

Vzhledem k neusměrnění graf G = (PROTI, E) s n vrcholy, nechť k být nějaké kladné celé číslo. Pro všechny i = 1, 2, . . . , k, nechť Ei být množina hran generovaných i-tá iterace vyhledávání prvního skenování, odpovídající grafu Gi−1 = (PROTI, E − (E1 ∪ . . . ∪ Ei−1)). Takže pro každou iteraci vyhledávání první skenování, jak je uvedeno výše, odstraníme okraje z grafu G vytvořit nový graf Gi která je výsledkem na konci ith iterace. Pro každou iteraci ije náš vyhledávací les pro skenování první sestaven z grafu Gi−1, kde G = G0. Tvrzení hlavní věty certifikátu je, že unie E1 ∪ . . . ∪ Ek je certifikát pro k-vrcholová konektivita G a že to má nanejvýš k(n − 1) hrany.[2]

Výpočetní složitost

Nejdůležitějším časem běhu je algoritmus běžící paralelně, v tomto případě s použitím modelu CRCW PRAM. Náš první klenutý strom T najdete v Ó(log n) čas pomocí C(n,m) procesory. Naše čísla předobjednávky a sousedé lze také vypočítat v O (log n) čase, protože paralelní techniky[3] s Ó((n + m) / log n) procesory, naše C(n,m) hodnota. Z tohoto důvodu můžeme vygenerovat jeden T & prime odpovídá jedné iteraci v Ó(log n) čas.

Pomocí distribuovaného přístupu k vyhledávání na šířku najdeme náš rozlehlý les v Ó(d log3 n) čas na grafu s průměrem d použitím Ó(m + n log3 n) zprávy. Sekvenční přístup je jednoduše doba běhu vyhledávání na šířku, Ó(m + n).

Viz také

Reference

  1. ^ Dokonce i S. (01.09.1975). „Algoritmus pro určení, zda je konektivita grafu nejméně k“ (PDF). SIAM Journal on Computing. 4 (3): 393–396. doi:10.1137/0204034. hdl:1813/6027. ISSN  0097-5397.
  2. ^ A b C Cheriyan, J .; Kao, M .; Thurimella, R. (01.02.1993). „Vyhledávací a řídké certifikáty: Vylepšený paralelní algoritmus pro připojení k-Vertex“ (PDF). SIAM Journal on Computing. 22 (1): 157–174. doi:10.1137/0222013. hdl:1813/8878. ISSN  0097-5397.
  3. ^ Karp, Richard M .; Ramachandran, Vijaya (01.01.1990). van Leeuwen, Jan (ed.). Příručka teoretické informatiky (svazek A). Cambridge, MA, USA: MIT Press. str. 869–941. ISBN  978-0-444-88071-0.