Gadget (počítačová věda) - Gadget (computer science)
v teorie výpočetní složitosti, a přístroj je podmnožina problémové instance, která simuluje chování jedné ze základních jednotek jiného výpočetního problému. Gadgety se obvykle používají ke konstrukci redukce z jednoho výpočetního problému do druhého, jako součást důkazů o NP-úplnost nebo jiné typy výpočetní tvrdosti. The konstrukční prvek Technika je metoda konstrukce redukcí pomocí gadgetů.[1]
Szabó (2009) sleduje použití gadgetů na papír z roku 1954 ve formátu teorie grafů podle W. T. Tutte, ve kterém Tutte poskytl gadgety pro snížení problému hledání a podgraf s daným stupeň omezení a perfektní shoda problém. Terminologie „gadgetu“ má však pozdější původ a neobjevuje se v Tutteho práci.[2][3]
Příklad
Mnoho důkazů úplnosti NP je založeno na mnoho-jedna redukce z 3 - uspokojivost, problém najít uspokojivé přiřazení k Booleovskému vzorci, který je spojkou (Boolean a) klauzulí, přičemž každá klauzule je disjunkcí (Boolean nebo) tří výrazů a každý výraz je Booleova proměnná nebo její negace. Redukce z tohoto problému na těžký problém neorientované grafy, tak jako Hamiltonovský cyklus problém nebo zbarvení grafu, by obvykle byly založeny na gadgetech ve formě podgrafů, které simulují chování proměnných a klauzulí dané instance 3 uspokojivosti. Tyto gadgety by pak byly slepeny dohromady a vytvořily jeden graf, což je tvrdá instance uvažovaného problému s grafem.[4]
Například problém testování 3barevnosti grafů může být prokázán jako NP-úplný snížením 3-uspokojivosti tohoto typu. Redukce používá dva speciální vrcholy grafu, označené jako „Ground“ a „False“, které nejsou součástí žádného gadgetu. Jak je znázorněno na obrázku, gadget pro proměnnou X sestává ze dvou vrcholů spojených v trojúhelníku se zemním vrcholem; jeden ze dvou vrcholů gadgetu je označen X a druhý je označen negací X. Gadget pro klauzuli (t0 ∨ t1 ∨ t2) se skládá ze šesti vrcholů, které jsou vzájemně propojeny, s vrcholy představujícími členy t0, t1, a t2, a k zemi a falešným vrcholům podle zobrazených hran. Žádný 3-CNF vzorec lze převést do grafu vytvořením samostatného gadgetu pro každou z jeho proměnných a klauzulí a jejich spojením, jak je znázorněno.[5]
V jakémkoli 3-vybarvení výsledného grafu lze označit tři barvy jako true, false nebo ground, kde false a ground jsou barvy dané falešným a pozemním vrcholům (nutně odlišné, protože tyto vrcholy jsou vytvořeny v sousedství konstrukce) a true je zbývající barva, kterou nepoužívá žádný z těchto vrcholů. V rámci gadgetu s proměnnými jsou možné pouze dvě barvy: vrchol označený proměnnou musí být obarvený buď true nebo false, a vrchol označený negací proměnné musí být odpovídajícím způsobem vybarven buď false nebo true. Tímto způsobem platná přiřazení barev k proměnným gadgetům odpovídají jedna za druhou s přiřazením pravdy k proměnným: chování gadgetu vzhledem k vybarvení simuluje chování proměnné s ohledem na přiřazení pravdy. platné 3 zbarvení, pokud je alespoň jeden z jeho sousedních vrcholů termínu zbarvený na true, a nemůže být 3-barevný, pokud jsou všechny jeho vrcholy na sousedních termínech barevně nepravdivé. Tímto způsobem lze gadget klauzule obarvit právě tehdy, pokud odpovídající přiřazení pravdy klauzuli splňuje, takže chování gadgetu opět simuluje chování klauzule.
Omezené redukce
Agrawal a kol. (1997) uvažovali o tom, čemu říkali „radikálně jednoduchá forma redukce gadgetů“, ve které každý bit popisující část gadgetu může záviset pouze na omezeném počtu bitů vstupu, a pomocí těchto redukcí prokázal analogii Berman – Hartmanisova domněnka o tom, že všechny NP-úplné sady jsou polynomiálně-časové izomorfní.[6]
Standardní definice NP-úplnosti zahrnuje polynomiální čas mnoho-jedna redukce: problém v NP je podle definice NP-úplný, pokud každý jiný problém v NP má redukci tohoto typu na něj a standardním způsobem, jak dokázat, že problém v NP je NP-úplný, je najít polynomiální čas mnoho-jeden redukce ze známého NP-úplného problému na něj. Ale (v tom, co Agrawal a kol. Nazývali „zvědavý, často pozorovaný fakt“), všechny soubory známé v té době jako NP-úplné mohly být prokázány jako úplné pomocí silnějšího pojmu AC0 mnoho-jedna redukce: to znamená redukce, které lze vypočítat pomocí obvodů s polynomiální velikostí, konstantní hloubkou a neomezeným vstupem. Agrawal a kol. dokázal, že každá sada, která je NP pod AC kompletní0 redukce je dokončena pod ještě omezenějším typem redukce, NC0 mnoho-jedna redukce, s využitím obvodů polynomiální velikosti, konstantní hloubky a omezeného fan-inu. V NC0 redukce, každý výstupní bit redukce může záviset pouze na konstantním počtu vstupních bitů,
Berman – Hartmanisova domněnka je nevyřešeným problémem v teorii výpočetní složitosti, který uvádí, že všechny třídy NP-úplných úloh jsou polynomiálně-časově izomorfní. To je, pokud A a B jsou dvě NP-úplné třídy problémů, existuje polynomiální časově individuální redukce z A na B jehož inverzní je také vypočítatelný v polynomiálním čase. Agrawal a kol. použili jejich ekvivalenci mezi AC0 redukce a NC0 redukce, které ukazují, že všechny sady jsou dokončeny pro NP pod AC0 redukce jsou AC0-izomorfní.
Optimalizace gadgetů
Jednou z aplikací gadgetů je prokazování tvrdost aproximace výsledky snížením problému, o kterém je známo, že je obtížné jej přiblížit jinému problému, jehož tvrdost je třeba prokázat. V této aplikaci má jeden typickou rodinu instancí prvního problému, ve kterých je mezera v hodnotách objektivních funkcí a ve kterých je těžké určit, zda má daná instance objektivní funkci, která je na spodní straně nebo na vysoké straně mezery. Redukce použité v těchto důkazech a gadgety použité při redukcích musí zachovat existenci této mezery a síla výsledku nepřibližnosti odvozená z redukce bude záviset na tom, jak dobře bude mezera zachována.
Trevisan a kol. (2000) formalizovat problém hledání gadgetů pro zachování mezer pro rodiny s dětmi problémy s uspokojením omezení ve kterém je cílem maximalizovat počet uspokojených omezení.[7] Jako příklad uvádějí snížení z 3 - uspokojivost na 2 - uspokojivost podle Garey, Johnson & Stockmeyer (1976), ve kterém se gadget představující klauzuli 3-SAT skládá z deseti klauzulí 2-SAT a ve kterém přiřazení pravdy, které splňuje klauzuli 3-SAT, také splňuje alespoň sedm klauzulí v gadgetu, zatímco přiřazení pravdy, které nesplňuje Klauzule 3-SAT také nedokáže uspokojit více než šest klauzulí gadgetu.[8] Použití tohoto gadgetu a skutečnost, že (pokud P = NP ) tady není žádný schéma aproximace v polynomiálním čase pro maximalizaci počtu klauzulí 3-SAT, které přiřazení pravdy splňuje, lze ukázat, že podobně neexistuje žádné schéma aproximace pro MAX 2-SAT.
Trevisan a kol. ukazují, že v mnoha případech problémů s uspokojením omezení, které studují, mohou být gadgety vedoucí k nejsilnějším možným výsledkům nepřístupnosti vytvořeny automaticky jako řešení lineární programování problém. Stejné redukce založené na gadgetech lze použít také v opačném směru, k přenosu aproximačních algoritmů z jednodušších problémů na těžší problémy. Například Trevisan a kol. poskytují optimální gadget pro redukci 3-SAT na váženou variantu 2-SAT (skládající se ze sedmi vážených 2-SAT klauzulí), která je silnější než ta Garey, Johnson & Stockmeyer (1976); jeho použití, společně se známými semidefinitní programování aproximační algoritmy pro MAX 2-SAT, poskytují aproximační algoritmus pro MAX 3-SAT s přibližným poměrem 0,801, lepší než dříve známé algoritmy.
Reference
- ^ Garey, M. R.; Johnson, D. S. (1979), "3.2.3 Design součásti", Počítače a neodolatelnost: Průvodce po teorii NP-úplnosti, San Francisco, Kalifornie: W. H. Freeman, str.72–74, ISBN 0-7167-1045-5, PAN 0519066.
- ^ Szabó, Jácint (2009), „Dobrá charakteristika pro určité omezené podgrafy“, Journal of Combinatorial Theory, Řada B, 99 (2): 436–446, doi:10.1016 / j.jctb.2008.08.009, PAN 2482961.
- ^ Tutte, W. T. (1954), „Krátký důkaz faktorové věty pro konečné grafy“, Kanadský žurnál matematiky, 6: 347–352, doi:10.4153 / CJM-1954-033-3, hdl:10338.dmlcz / 101241, PAN 0063008.
- ^ Sipser, Michael (1997), Úvod do teorie výpočtu, PWS Publishing Co., s. 260.
- ^ Tato redukce je popsána v Goldreich, Oded (2008), Výpočetní složitost: koncepční perspektiva, Cambridge University Press, Proposition 2.27, s. 81.
- ^ Agrawal, Manindra; Allender, Eric; Impagliazzo, Russell; Pitassi, Toniann; Rudich, Steven (1997), „Snižování složitosti redukcí“, Proceedings of the 29. ACM Symposium on Theory of Computing (STOC '97), str. 730–738, doi:10.1145/258533.258671. Agrawal, Manindra; Allender, Eric; Rudich, Steven (1998), „Redukce složitosti obvodů: věta o izomorfismu a věta o mezeře“, Journal of Computer and System Sciences, 57 (2): 127–143, doi:10.1006 / jcss.1998.1583.
- ^ Trevisan, Luca; Sorkin, Gregory B .; Súdán, Madhu; Williamson, David P. (2000), „Gadgety, aproximace a lineární programování“, SIAM Journal on Computing, 29 (6): 2074–2097, doi:10.1137 / S0097539797328847, PAN 1756405.
- ^ Garey, Michael R.; Johnson, David S.; Stockmeyer, Larry (1976), „Some simplified NP-complete graph problems“, Teoretická informatika: 237–267, doi:10.1016/0304-3975(76)90059-1.