Nastavit problém s krytem - Set cover problem
The nastavit problém s krytem je klasická otázka v kombinatorika, počítačová věda, operační výzkum, a teorie složitosti. Je to jeden z Karpových 21 NP-úplných problémů prokázáno, že je NP-kompletní v roce 1972.
Jedná se o problém, "jehož studium vedlo k vývoji základních technik pro celý obor" aproximační algoritmy.[1]
Vzhledem k sadě prvků (volal vesmír ) a sbírka z sady, jejichž svaz rovná se vesmíru, problém s krytem sady je identifikovat nejmenší dílčí kolekci jehož unie se rovná vesmíru. Zvažte například vesmír a kolekce sad . Je zřejmé, že spojení je . Můžeme však pokrýt všechny prvky s následujícím menším počtem sad: .
Více formálně, vzhledem k vesmíru a rodinu podskupin ,A Pokrýt je podčeleď množin, jejichž sjednocení je . V krycí sadě rozhodovací problém, vstup je pár a celé číslo ; otázkou je, zda existuje množinová pokrývka velikosti nebo méně. V krycí sadě optimalizační problém, vstup je pár , a úkolem je najít sadu pokrývající, která používá nejméně sad.
Rozhodovací verze krytiny sady je NP-kompletní a optimalizační / vyhledávací verze krytu sady je NP-tvrdé.[2]
Pokud je každé sadě přiřazena cena, stane se vážený nastavit problém s krytem.
Celé číslo lineární formulace programu
Problém minimální sady krytu lze formulovat následovně celočíselný lineární program (ILP).[3]
minimalizovat | (minimalizovat počet sad) | ||
podléhá | pro všechny | (pokrýt každý prvek vesmíru) | |
pro všechny . | (každá sada je buď v krytu sady, nebo ne) |
Tento ILP patří do obecnější třídy ILP pro pokrývající problémy.v mezera v integritě tohoto ILP je maximálně , Takže to je relaxace dává faktor aproximační algoritmus pro problém s minimálním nastavením krytu (kde je velikost vesmíru).[4]
Ve váženém krytu sady jsou sadám přiřazeny váhy. Označte hmotnost soupravy podle . Pak je celočíselný lineární program popisující kryt váženého souboru identický s výše uvedeným, kromě toho, že objektivní funkce k minimalizaci je .
Bití formulace sady
Souprava krytiny je ekvivalentní s bít set problém. To je patrné z pozorování, že instanci zakrytí množiny lze považovat za libovolnou bipartitní graf, se sadami představovanými vrcholy vlevo, vesmírem představovaným vrcholy na pravé straně a hranami představujícími zahrnutí prvků do množin. Úkolem je pak najít minimální podmnožinu mohutnosti levých vrcholů, která pokrývá všechny pravé vrcholy. V problému Úderová sada je cílem pokrýt levé vrcholy pomocí minimální podmnožiny pravých vrcholů. Převodu z jednoho problému na druhý se tedy dosáhne záměnou dvou sad vrcholů.
Chamtivý algoritmus
Tady je chamtivý algoritmus pro polynomiální časovou aproximaci pokrytí sady, která vybírá sady podle jednoho pravidla: v každé fázi vyberte sadu, která obsahuje největší počet nekrytých prvků. Může se to ukázat[5] že tento algoritmus dosahuje přibližného poměru , kde je velikost sady, která má být pokryta. Jinými slovy, najde krytinu, která může být krát tak velký jako minimální, kde je -th harmonické číslo:
Tento chamtivý algoritmus ve skutečnosti dosahuje přibližného poměru kde je maximální sada mohutnosti . Pro husté instance však existuje a - přibližovací algoritmus pro každého .[6]
Existuje standardní příklad, kdy chamtivý algoritmus dosahuje přibližného poměru Vesmír se skládá z elementy. Nastavený systém se skládá z párové disjunktní sady s velikostmi respektive dvě další disjunktní sady , z nichž každý obsahuje polovinu prvků z každého . Na tomto vstupu chamtivý algoritmus vezme sady, v tomto pořadí, zatímco optimální řešení sestává pouze z a Příklad takového vstupu pro je zobrazen vpravo.
Výsledky nepřibližnosti ukazují, že chamtivý algoritmus je v podstatě nejlepším možným algoritmem aproximace polynomiálního času pro zakrytí množiny až po termíny nižšího řádu (viz Výsledky nepřibližnosti níže), za pravděpodobných předpokladů složitosti. Těsnější analýza chamtivého algoritmu ukazuje, že poměr přiblížení je přesně .[7]
Nízkofrekvenční systémy
Pokud se každý prvek vyskytuje nanejvýš F množiny, pak lze najít řešení v polynomiálním čase, které přibližuje optimum k faktoru F použitím LP relaxace.
Pokud omezení je nahrazen pro všechny S v v zobrazeném celočíselném lineárním programu výše, pak se stane (necelým) lineárním programem L. Algoritmus lze popsat takto:
- Najděte optimální řešení Ó pro program L pomocí nějaké metody polynomiálního času řešení lineárních programů.
- Vyberte všechny sady S pro které odpovídá proměnná XS má hodnotu alespoň 1 /F v řešení Ó.[8]
Výsledky nepřibližnosti
Když odkazuje na velikost vesmíru, Lund a Yannakakis (1994) ukázaly, že pokrytí množiny nelze v polynomiálním čase aproximovat v rámci faktoru , pokud NP má kvazi-polynomiální čas algoritmy. Feige (1998) tuto dolní hranici zlepšili za stejných předpokladů, které v zásadě odpovídají aproximačnímu poměru dosaženému chamtivým algoritmem. Raz & Safra (1997) stanovil dolní mez , kde je určitá konstanta, za slabšího předpokladu PNPPodobný výsledek s vyšší hodnotou bylo nedávno prokázáno Alon, Moshkovitz & Safra (2006). Dinur & Steurer (2013) ukázal optimální nepřibližnost prokázáním, že jej nelze přiblížit ledaže PNP.
Vážený kryt sady
Tato sekce potřebuje expanzi. Můžete pomoci přidávat k tomu. (Listopad 2017) |
Relaxační je uveden celočíselný lineární program pro vážený kryt sady výše, jeden může použít náhodné zaokrouhlování získat -faktorová aproximace. Odpovídající analýza pro nevážený kryt sady je uvedena v Náhodné zaokrouhlování # Algoritmus náhodného zaokrouhlování pro kryt setu a lze jej přizpůsobit váženému případu.[9]
Související problémy
- Bít do setu je ekvivalentní přeformulování Set Cover.
- Vrcholový kryt je speciální případ zasažení sady.
- Kryt hrany je speciální případ Set Cover.
- Geometrická sada krytu je speciální případ Set Cover, když je vesmír souborem bodů dovnitř a množiny jsou indukovány průnikem vesmíru a geometrických tvarů (např. disky, obdélníky).
- Nastavit balení
- Problém s maximálním pokrytím je vybrat maximálně k sad k pokrytí co nejvíce prvků.
- Dominující sada je problém výběru sady vrcholů (dominující množina) v grafu tak, že všechny ostatní vrcholy sousedí s alespoň jedním vrcholem v dominující množině. Ukázalo se, že problém Dominující sady je NP úplný díky redukci z krytu sady.
- Přesný problém s krytem je vybrat sadu krytu bez prvku zahrnutého do více než jedné sady krytu.
Poznámky
- ^ Vazirani (2001, str. 15)
- ^ Korte & Vygen 2012, str. 414.
- ^ Vazirani (2001, str. 108)
- ^ Vazirani (2001, str. 110–112)
- ^ Chvatal, V. Chamtivá heuristika pro problém zakrytí soupravy. Matematika operačního výzkumuVol. 4, č. 3 (srpen 1979), str. 233-235
- ^ Karpinski & Zelikovsky 1998
- ^ Slavík Petr Pečlivá analýza chamtivého algoritmu pro kryt setu. STOC'96, strany 435-441, doi:10.1145/237814.237991
- ^ Vazirani (2001, s. 118–119)
- ^ Vazirani (2001, Kapitola 14)
Reference
- Alon, Noga; Moshkovitz, Dana; Safra, Shmuel (2006), „Algoritmická konstrukce množin pro k-omezení“, ACM Trans. Algoritmy, 2 (2): 153–177, CiteSeerX 10.1.1.138.8682, doi:10.1145/1150334.1150336, ISSN 1549-6325, S2CID 11922650.
- Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2001), Úvod do algoritmů, Cambridge, Massachusetts: MIT Press a McGraw-Hill, str. 1033–1038, ISBN 978-0-262-03293-3
- Feige, Uriel (1998), „Prahová hodnota ln n pro přibližné stanovení krytí“, Deník ACM, 45 (4): 634–652, CiteSeerX 10.1.1.70.5014, doi:10.1145/285055.285059, ISSN 0004-5411, S2CID 52827488.
- Karpinski, Marek; Zelikovsky, Alexander (1998), Přibližování hustých případů problémů s krytím, 40, s. 169–178, ISBN 9780821870846
- Lund, Carsten; Yannakakis, Mihalis (1994), „O tvrdosti aproximace problémů minimalizace“, Deník ACM, 41 (5): 960–981, doi:10.1145/185675.306789, ISSN 0004-5411, S2CID 9021065.
- Raz, Ran; Safra, Shmuel (1997), „Test nízkého stupně pravděpodobnosti subkonstantní chyby a charakterizace PCP subkonstantní chyby pravděpodobnosti PCP“, STOC '97: Sborník z dvacátého devátého ročníku ACM symposia o teorii práce s počítačem, ACM, str. 475–484, ISBN 978-0-89791-888-6.
- Dinur, Irit; Steurer, David (2013), „Analytický přístup k paralelnímu opakování“, STOC '14: Sborník ze čtyřicátého šestého ročníku ACM symposia o teorii práce s počítačem, ACM, str. 624–633.
- Vazirani, Vijay V. (2001), Aproximační algoritmy (PDF), Springer-Verlag, ISBN 978-3-540-65367-7CS1 maint: ref = harv (odkaz)
- Korte, Bernhard; Vygen, Jens (2012), Kombinatorická optimalizace: Teorie a algoritmy (5. vyd.), Springer, ISBN 978-3-642-24487-2CS1 maint: ref = harv (odkaz)
- Cardoso, Nuno; Abreu, Rui (2014), Efektivní distribuovaný algoritmus pro výpočet sad minimálních zásahů (PDF), Graz, Rakousko, doi:10,5281 / zenodo.10037CS1 maint: ref = harv (odkaz)