Skutečně kvantifikovaný booleovský vzorec - True quantified Boolean formula
v teorie výpočetní složitosti, jazyk TQBF je formální jazyk skládající se z skutečně kvantifikované booleovské vzorce. (Plně) kvantifikovaný booleovský vzorec je vzorec v vyčísleno výroková logika kde je každá proměnná kvantifikována (nebo vázaný ) pomocí obou existenciální nebo univerzální kvantifikátory, na začátku věty. Takový vzorec je ekvivalentní buď true, nebo false (protože neexistují žádné volný, uvolnit proměnné). Pokud je takový vzorec vyhodnocen jako true, pak je tento vzorec v jazyce TQBF. Je také známý jako QSAT (Kvantifikováno SAT ).
Přehled
V teorii výpočetní složitosti je kvantifikovaný problém s booleovským vzorcem (QBF) je zobecněním Booleovský problém uspokojivosti ve kterém oba existenční kvantifikátory a univerzální kvantifikátory lze použít na každou proměnnou. Jinými slovy, zeptá se, zda je kvantifikovaný sentenciální formulář přes sadu booleovských proměnných pravdivý nebo nepravdivý. Například následující je instance QBF:
QBF je kanonický úplný problém pro PSPACE, třída problémů řešitelná deterministickým nebo nedeterministickým způsobem Turingův stroj v polynomiálním prostoru a neomezeném čase.[1] Vzhledem k tomu, vzorec ve formě abstraktní syntaxový strom lze problém snadno vyřešit pomocí sady vzájemně rekurzivních postupů, které hodnotí vzorec. Takový algoritmus využívá prostor úměrný výšce stromu, který je v nejhorším případě lineární, ale v čase kvantifikátorů používá časovou exponenciálnost.
Pokud MA ⊊ PSPACE, o kterém se všeobecně věří, že QBF nelze vyřešit, ani nelze dané řešení ani ověřit, ať už deterministicky, nebo pravděpodobnostní polynomiální čas (ve skutečnosti, na rozdíl od problému uspokojivosti, neexistuje žádný známý způsob, jak stručně určit řešení). To lze vyřešit pomocí střídavý Turingův stroj od lineárního času AP = PSPACE, kde AP je třída problémů, které mohou střídavé stroje vyřešit v polynomiálním čase.[2]
Když je klíčový výsledek IP = PSPACE byl zobrazen (viz interaktivní kontrolní systém ), bylo provedeno vystavením interaktivního důkazního systému, který by mohl vyřešit QBF řešením konkrétní aritmetizace problému.[3]
Vzorce QBF mají řadu užitečných kanonických forem. Lze například ukázat, že existuje a polynomial-time many-one reduction který přesune všechny kvantifikátory na přední část vzorce a umožní jim střídat univerzální a existenční kvantifikátory. Existuje další redukce, která se osvědčila v důkazu IP = PSPACE, kde mezi použití každé proměnné a kvantifikátor vázající tuto proměnnou není umístěn více než jeden univerzální kvantifikátor. To bylo rozhodující pro omezení počtu produktů v určitých podvýrazech aritmetizace.
Prenex normální forma
Lze předpokládat, že plně kvantifikovaný booleovský vzorec má velmi konkrétní formu, tzv normální forma prenex. Má dvě základní části: část obsahující pouze kvantifikátory a část obsahující nevyčíslený booleovský vzorec obvykle označovaný jako . Pokud existují Booleovské proměnné, celý vzorec lze zapsat jako
kde každá proměnná spadá do rozsah nějakého kvantifikátoru. Zavedením fiktivních proměnných lze libovolný vzorec v normální formě prenex převést na větu, kde se střídají existenční a univerzální kvantifikátory. Použití fiktivní proměnné ,
Druhá věta má totéž pravdivostní hodnota ale dodržuje omezenou syntaxi. Častým rysem důkazů je předpokládat, že plně kvantifikované booleovské vzorce budou v prenexové normální formě.
Řešení
Existuje jednoduchý rekurzivní algoritmus pro určení, zda je QBF v TQBF (tj. Je pravda). Vzhledem k určitému QBF
Pokud vzorec neobsahuje žádné kvantifikátory, můžeme vzorec jednoduše vrátit. Jinak sundáme první kvantifikátor a zkontrolujeme obě možné hodnoty pro první proměnnou:
Li , pak se vraťte . Li , pak se vraťte .
Jak rychle tento algoritmus běží? U každého kvantifikátoru v počátečním QBF provede algoritmus dvě rekurzivní volání pouze na lineárně menším dílčím problému. To dává algoritmu exponenciální runtime O (2n).
Kolik místa tento algoritmus používá? V rámci každého vyvolání algoritmu musí ukládat průběžné výsledky výpočtu A a B. Každé rekurzivní volání sundá jeden kvantifikátor, takže celková rekurzivní hloubka je v počtu kvantifikátorů lineární. Vzorce, které postrádají kvantifikátory, lze vyhodnotit v prostoru logaritmicky v počtu proměnných. Počáteční QBF byl plně kvantifikován, takže existuje alespoň tolik kvantifikátorů jako proměnných. Tento algoritmus tedy používá Ó(n + log n) = Ó(n) prostor. Díky tomu je jazyk TQBF součástí PSPACE třída složitosti.
PSPACE - úplnost
Jazyk TQBF slouží v teorie složitosti jako kanonický PSPACE - kompletní problém. Být úplným PSPACE znamená, že jazyk je v PSPACE a že jazyk také existuje PSPACE-tvrdé. Výše uvedený algoritmus ukazuje, že TQBF je v PSPACE. Ukázání, že TQBF je PSPACE, vyžaduje ukázat, že jakýkoli jazyk ve třídě složitosti PSPACE lze v polynomiálním čase snížit na TQBF. Tj.,
To znamená, že pro jazyk PSPACE L, ať už jde o vstup X je v L lze rozhodnout kontrolou, zda je v TQBF, pro nějakou funkci F který je vyžadován pro běh v polynomiálním čase (vzhledem k délce vstupu). Symbolicky,
Dokázat, že TQBF je tvrdý na PSPACE, vyžaduje specifikaci F.
Předpokládejme tedy, že L je jazyk PSPACE. To znamená, že o L může rozhodnout deterministický polynomiální prostor Turingův stroj (DTM). To je velmi důležité pro redukci L na TQBF, protože konfigurace jakéhokoli takového Turingova stroje mohou být reprezentovány jako booleovské vzorce, přičemž booleovské proměnné představují stav stroje i obsah každé buňky na pásku Turingova stroje, s polohou hlavy Turingova stroje zakódovanou ve vzorci podle pořadí vzorce. Naše redukce bude využívat zejména proměnné a , které představují dvě možné konfigurace DTM pro L a přirozené číslo t při konstrukci QBF což je pravda, právě když DTM pro L může přejít z konfigurace zakódované v do konfigurace zakódované v v ne více než t krocích. Funkce F, potom vytvoří z DTM pro L a QBF , kde je počáteční konfigurace DTM, je přijímající konfigurace DTM a T je maximální počet kroků, které může DTM potřebovat k přechodu z jedné konfigurace do druhé. Víme, že T = Ó(exp (n)), kde n je délka vstupu, protože tím je omezen celkový počet možných konfigurací příslušné DTM. Samozřejmě nemůže DTM podniknout více kroků, než je možné dosáhnout konfigurací pokud nevstoupí do smyčky, v takovém případě se nikdy nedostane tak jako tak.
V této fázi důkazu jsme již omezili otázku, zda vstupní vzorec w (kódováno, samozřejmě v ) je v L na otázku, zda QBF , tj., , je v TQBF. Zbytek tohoto důkazu to dokazuje F lze vypočítat v polynomiálním čase.
Pro , výpočet je přímočarý - buď se jedna z konfigurací v jednom kroku změní na druhou, nebo ne. Protože Turingův stroj, který náš vzorec představuje, je deterministický, nepředstavuje to žádný problém.
Pro , výpočet zahrnuje rekurzivní vyhodnocení hledající takzvaný „střední bod“ . V tomto případě přepíšeme vzorec následovně:
Tím se převádí otázka, zda může dosáhnout v t krocích k otázce, zda dosáhne středního bodu v kroky, které sám dosáhne v kroky. Odpověď na druhou otázku samozřejmě dává odpověď na první.
Nyní je t omezeno pouze T, které je exponenciální (a tedy ne polynomické) v délce vstupu. Každá rekurzivní vrstva navíc zdvojnásobuje délku vzorce. (Proměnná je pouze jeden střed - pro větší t je na cestě takřka více zastávek.) Čas potřebný k rekurzivnímu vyhodnocení tímto způsobem může být také exponenciální, jednoduše proto, že vzorec se může stát exponenciálně velkým. Tento problém je vyřešen univerzální kvantifikací pomocí proměnných a přes konfigurační páry (např. ), který zabrání zvětšení délky vzorce kvůli rekurzivním vrstvám. Tím se získá následující interpretace :
Tuto verzi vzorce lze skutečně vypočítat v polynomiálním čase, protože kteroukoli jeho instanci lze vypočítat v polynomiálním čase. Univerzálně kvantifikovaný uspořádaný pár nám jednoduše říká, že z kterékoli volby je vyrobeno, .
Tím pádem, , takže TQBF je tvrdý pro PSPACE. Spolu s výše uvedeným výsledkem, že TQBF je v PSPACE, to završuje důkaz, že TQBF je jazyk pro PSPACE.
(Tento důkaz navazuje na Sipser 2006 str. 310–313 ve všech podstatných náležitostech. Papadimitriou 1994 také obsahuje důkaz.)
Rozmanitost
- Jedním důležitým dílčím problémem v TQBF je Booleovský problém uspokojivosti. V tomto problému chcete vědět, zda daný booleovský vzorec může být provedeno s určitým přiřazením proměnných. To je ekvivalentní TQBF používající pouze existenční kvantifikátory:
- Toto je také příklad většího výsledku NP PSPACE, který přímo vyplývá z pozorování, že polynomiální ověřovač času pro důkaz jazyka akceptovaného NTM (Nedeterministický Turingův stroj ) vyžaduje polynomiální prostor pro uložení důkazu.
- Libovolná třída v polynomiální hierarchie (PH ) má TQBF jako těžký problém. Jinými slovy, pro třídu zahrnující všechny jazyky L, pro kterou existuje vícenásobný TM V, ověřovatel, který pro všechny vstupy x a některé konstanty i,
- který má specifickou formulaci QBF, která je uvedena jako
- takhle
- Kde jsou vektory booleovských proměnných.
- Je důležité si uvědomit, že zatímco jazyk TQBF je definován jako soubor skutečných kvantifikovaných booleovských vzorců, zkratka TQBF se často používá (dokonce i v tomto článku) jako zkratka pro zcela kvantifikovaný booleovský vzorec, často jednoduše nazývaný QBF (kvantifikovaný booleovský vzorec, chápaný jako „zcela“ nebo „zcela“ kvantifikovaný). Je důležité kontextově rozlišovat mezi dvěma způsoby použití zkratky TQBF při čtení literatury.
- TQBF lze považovat za hru hranou mezi dvěma hráči se střídavými tahy. Existenciálně kvantifikované proměnné jsou ekvivalentní představě, že tah je k dispozici hráči na tahu. Všeobecně kvantifikované proměnné znamenají, že výsledek hry nezávisí na tom, jaký pohyb hráč v daném tahu provede. Také TQBF, jehož první kvantifikátor je existenční, odpovídá a formule hra ve kterém má první hráč vítěznou strategii.
- TQBF, ve kterém je kvantifikovaný vzorec 2-CNF může být vyřešen v lineární čas algoritmem zahrnujícím silná analýza konektivity jeho implikační graf. The 2 - uspokojivost problémem je speciální případ TQBF pro tyto vzorce, ve kterém je každý kvantifikátor existenční.[4][5]
- Existuje systematické zacházení s omezenými verzemi kvantifikovaných booleovských vzorců (poskytujících klasifikace typu Schaefer), které poskytuje výkladový článek Hubie Chen.[6]
- Planární TQBF, zobecňující Planární SAT, byl prokázán PSPACE-kompletní D. Lichtenstein.[7]
Poznámky a odkazy
- ^ M. Garey a D. Johnson (1979). Počítače a neodolatelnost: Průvodce po teorii NP-úplnosti. W. H. Freeman, San Francisco, Kalifornie. ISBN 0-7167-1045-5.
- ^ A. Chandra, D. Kozen a L. Stockmeyer (1981). "Střídání". Deník ACM. 28 (1): 114–133. doi:10.1145/322234.322243.CS1 maint: více jmen: seznam autorů (odkaz)
- ^ Adi Shamir (1992). „Ip = Pspace“. Deník ACM. 39 (4): 869–877. doi:10.1145/146585.146609.
- ^ Krom, Melven R. (1967). „Problém rozhodování pro třídu vzorců prvního řádu, ve které jsou všechny disjunkce binární“. Zeitschrift für Mathematische Logik und Grundlagen der Mathematik. 13 (1–2): 15–20. doi:10,1002 / malq.1970130104..
- ^ Aspvall, Bengt; Plass, Michael F .; Tarjan, Robert E. (1979). „Algoritmus lineárního času pro testování pravdivosti určitých kvantifikovaných booleovských vzorců“ (PDF). Dopisy o zpracování informací. 8 (3): 121–123. doi:10.1016/0020-0190(79)90002-4..
- ^ Chen, Hubie (prosinec 2009). „Setkání logiky, složitosti a algebry“. ACM Computing Surveys. ACM. 42 (1): 1–32. arXiv:cs / 0611018. doi:10.1145/1592451.1592453.
- ^ Lichtenstein, David (01.05.1982). „Rovinné vzorce a jejich použití“. SIAM Journal on Computing. 11 (2): 329–343. doi:10.1137/0211025. ISSN 0097-5397.
- Fortnow & Homer (2003) poskytuje historická pozadí pro PSPACE a TQBF.
- Zhang (2003) poskytuje některé historické pozadí booleovských vzorců.
- Arora, Sanjeev. (2001). COS 522: Výpočetní složitost. Poznámky k přednášce, Princetonská univerzita. Citováno 10. října 2005.
- Fortnow, Lance a Steve Homer. (2003, červen). Krátká historie výpočetní složitosti. Sloupec výpočetní složitosti, 80. Citováno 9. října 2005.
- Papadimitriou, C. H. (1994). Výpočetní složitost. Čtení: Addison-Wesley.
- Sipser, Michael. (2006). Úvod do teorie výpočtu. Boston: Thomson Course Technology.
- Zhang, Lintao. (2003). Hledání pravdy: Techniky pro uspokojivost booleovských vzorců. Citováno 10. října 2005.
Viz také
- Cook – Levinova věta s tím, že SAT je NP-kompletní
- Zobecněná geografie
externí odkazy
- Kvantifikovaná booleovská knihovna vzorců (QBFLIB)
- Mezinárodní workshop o kvantifikovaných booleovských vzorcích
- DepQBF - řešič kvantifikovaných booleovských vzorců založený na vyhledávání
- CAQE - řešič CEGAR pro kvantifikované booleovské vzorce; vítěz nedávných vydání každoroční soutěže řešitelů QBF QBFEVAL.
- KADET - řešitel kvantifikovaných booleovských vzorců omezený na jednu alternaci kvantifikátoru se schopností počítat Funkce Skolem