Maximální řez - Maximum cut

Příklad maximálního řezu

Pro graf, a maximální řez je střih jehož velikost je alespoň velikostí jakéhokoli jiného střihu. To znamená, že se jedná o rozdělení vrcholů grafu do dvou doplňkových sad S a T, takže počet hran mezi sadou S a sada T je co největší. Problém nalezení maximálního řezu v grafu je známý jako Problém Max-Cut.

Problém lze uvést jednoduše následovně. Jeden chce podmnožinu S vrcholu nastavena tak, aby počet hran mezi S a doplňková podmnožina je co největší. Ekvivalentně, jeden chce bipartitní podgraf grafu s co největším počtem hran.

Existuje obecnější verze problému s názvem vážený Max-Cut, kde každá hrana je spojena se skutečným číslem, je hmotnosta cílem je maximalizovat celkovou hmotnost hran mezi nimi S a jeho doplněk, spíše než počet okrajů. Vážený problém Max-Cut umožňující pozitivní i negativní váhy lze triviálně transformovat na vážený minimální řez překlopením cedule ve všech vahách.

Výpočetní složitost

Následující rozhodovací problém týkající se maximálních škrtů bylo široce studováno v teoretická informatika:

Daný graf G a celé číslo k, určete, zda existuje alespoň velikost k v G.

O tomto problému je známo NP-kompletní. Je snadno vidět, že problém je v NP: a Ano odpověď lze snadno dokázat předložením dostatečně velkého řezu. NP-úplnost problému lze ukázat například snížením z maximální uspokojivost 2 (omezení problém maximální uspokojivosti ).[1] Vážená verze rozhodovacího problému byla jedna z Karpových 21 NP-úplných problémů;[2] Karp ukázal NP-úplnost snížením od problém s oddílem.

Kanonický varianta optimalizace výše uvedeného rozhodovacího problému je obvykle známý jako Problém maximálního řezu nebo Max. Řez a je definována jako:

Daný graf G, najděte maximální řez.

O variantě optimalizace je známo, že je NP-Hard. Opačný problém, a to hledání minimální řez je známo, že je účinně řešitelný prostřednictvím Algoritmus Ford-Fulkerson.

Algoritmy

Algoritmy polynomiálního času

Jak je problém Max-Cut NP-tvrdé, nejsou známy žádné algoritmy polynomiálního času pro Max-Cut v obecných grafech.

Rovinné grafy

Nicméně v rovinné grafy, Problém s maximálním řezem je dvojí problém kontroly trasy (problém najít nejkratší prohlídku, která alespoň jednou navštíví každou hranu grafu), v tom smyslu, že hrany, které nepatří do maximální sestavy grafu G jsou duály hran, které jsou zdvojnásobeny při optimální inspekční prohlídce duální graf z G. Optimální inspekční prohlídka tvoří křižovatku, která se protíná, a rozděluje rovinu na dvě podmnožiny, podmnožinu bodů, pro které číslo vinutí křivky je sudá a podmnožina, pro kterou je číslo vinutí liché; tyto dvě podmnožiny tvoří střih, který zahrnuje všechny hrany, jejichž duály se v prohlídce objevují lichě. Problém kontroly trasy může být vyřešen v polynomiálním čase a tato dualita umožňuje také řešení problému maximálního řezu v polynomiálním čase pro rovinné grafy.[3] Je známo, že problém Maximum-Bisection je NP-těžký.[4]

Aproximační algoritmy

Problém Max-Cut je APX-tvrdé,[5] což znamená, že neexistuje žádné polynomiálně-časové aproximační schéma (PTAS), libovolně blízké optimálnímu řešení, pokud P = NP. Každý známý algoritmus aproximace v polynomiálním čase tedy dosahuje přibližný poměr přísně méně než jeden.

Existuje jednoduchý náhodně 0.5-aproximační algoritmus: pro každý vrchol otočte mincí, abyste se rozhodli, které polovině oddílu ji přiřadíte.[6][7] V očekávání jsou poloviny okrajů řezané hrany. Tento algoritmus může být derandomizováno s metoda podmíněných pravděpodobností; proto existuje také jednoduchý deterministický algoritmus polynomiálního času s 0,5 aproximací.[8][9] Jeden takový algoritmus začíná libovolným rozdělením vrcholů daného grafu a opakovaně přesouvá jeden vrchol najednou z jedné strany přepážky na druhou a vylepšuje řešení v každém kroku, dokud již nelze provést další vylepšení tohoto typu. Počet iterací je maximálně protože algoritmus zlepšuje řez o alespoň jednu hranu v každém kroku. Když se algoritmus ukončí, alespoň polovina okrajů dopadajících na každý vrchol patří řezu, protože jinak by pohyb vrcholem vylepšil řez. Proto řez zahrnuje alespoň hrany.

Algoritmus aproximace polynomiálního času pro Max-Cut s nejznámějším aproximačním poměrem je metoda Goemansa a Williamsona používající semidefinitní programování a náhodné zaokrouhlování který dosahuje přibližného poměru kde

[10][11]

Pokud domněnky o jedinečných hrách je pravda, toto je nejlepší možný poměr přiblížení pro maximální řez.[12] Bez těchto neprokázaných předpokladů se ukázalo, že je těžké NP odhadnout hodnotu maximálního řezu s přibližným poměrem lepším než .[13][14]

v [15] k tomuto problému existuje rozšířená analýza 10 heuristik, včetně implementace open-source.

Aplikace

Teoretická fyzika

v statistická fyzika a neuspořádané systémy, problém Max Cut je ekvivalentní minimalizaci Hamiltonian a točit sklo model, nejjednodušší model Isingův model.[16] Pro Isingův model na grafu G a pouze interakce nejbližšího souseda je Hamiltonian

Tady každý vrchol i grafu je místo rotace, které může nabrat hodnotu rotace Oddíly konfigurace rotace do dvou sad, ti se točí a ti, kteří mají spánek Označujeme s sada hran, které spojují dvě sady. Potom můžeme přepsat Hamiltonian jako

Minimalizace této energie je ekvivalentní problému min-cut nebo nastavením vah grafu jako problém maximálního řezu.[16]

Návrh obvodu

Problém s maximálním řezem má aplikace v VLSI design.[16]

Viz také

Poznámky

  1. ^ Garey & Johnson (1979).
  2. ^ Karp (1972).
  3. ^ Hadlock (1975).
  4. ^ Jansen a kol. (2005).
  5. ^ Papadimitriou & Yannakakis (1991) dokázat MaxSNP -úplnost.
  6. ^ Mitzenmacher & Upfal (2005), Oddíl. 6.2.
  7. ^ Motwani & Raghavan (1995), Oddíl. 5.1.
  8. ^ Mitzenmacher & Upfal (2005), Oddíl. 6.3.
  9. ^ Khuller, Raghavachari & Young (2007).
  10. ^ Gaur & Krishnamurti (2007).
  11. ^ Ausiello a kol. (2003)
  12. ^ Khot a kol. (2007).
  13. ^ Håstad (2001)
  14. ^ Trevisan a kol. (2000)
  15. ^ Dunning, Gupta & Silberholz (2018)
  16. ^ A b C Barahona, Francisco; Grötschel, Martin; Jünger, Michael; Reinelt, Gerhard (1988). "Aplikace kombinatorické optimalizace na statistickou fyziku a návrh rozvržení obvodu". Operační výzkum. 36 (3): 493–513. doi:10,1287 / opre.36.3.493. ISSN  0030-364X. JSTOR  170992.

Reference

  • Ausiello, Giorgio; Crescenzi, Pierluigi; Gambosi, Giorgio; Kann, Viggo; Marchetti-Spaccamela, Alberto; Protasi, Marco (2003), Složitost a aproximace: Problémy kombinatorické optimalizace a vlastnosti jejich přibližnostiSpringer.
Maximální řez (optimalizační verze) je problém ND14 v příloze B (strana 399).
Maximum cut (decision version) is the problem ND16 in Annex A2.2.
Maximální bipartitní podgraf (rozhodovací verze) je problém GT25 v dodatku A1.2.

externí odkazy