Algoritmus DPLL - DPLL algorithm
v logika a počítačová věda, Davis – Putnam – Logemann – Loveland (DPLL) algoritmus je kompletní, ustoupit -na základě vyhledávací algoritmus pro rozhodování o uspokojivosti z výrokové logické vzorce v konjunktivní normální forma, tj. pro řešení CNF-SAT problém.
To bylo představeno v roce 1961 Martin Davis, George Logemann a Donald W. Loveland a je vylepšení předchozího Algoritmus Davis – Putnam, což je rozlišení - postup založený na Davisovi a Hilary Putnam v roce 1960. Zejména ve starších publikacích je algoritmus Davis – Logemann – Loveland často označován jako „Davis – Putnamova metoda“ nebo „algoritmus DP“. Jiné běžné názvy, které udržují rozdíl, jsou DLL a DPLL.
Po více než 50 letech je postup DPLL stále základem pro nejúčinnější úplné SAT řešení. Nedávno byla prodloužena pro automatizované dokazování věty pro fragmenty logika prvního řádu prostřednictvím DPLL (T) algoritmus.[1]
Třída | Booleovský problém uspokojivosti |
---|---|
Nejhorší případ výkon | |
Nejhorší případ složitost prostoru | (základní algoritmus) |
Implementace a aplikace
The SAT problém je důležité jak z teoretického, tak z praktického hlediska. v teorie složitosti byl to první problém, který se ukázal být NP-kompletní, a mohou se objevit v široké škále aplikací, jako je kontrola modelu, automatické plánování a plánování, a diagnostika v umělé inteligenci.
Jako takový je již mnoho let horkým tématem výzkumu a soutěží mezi nimi SAT řešitelé pravidelně konat.[2] Moderní implementace DPLL jako Plevy a zChaff,[3][4] UCHOPIT nebo Minisat[5] jsou v posledních letech na prvních místech soutěží.[když? ]
Další aplikace, která často zahrnuje DPLL, je automatizované dokazování věty nebo teorie uspokojivosti modulo (SMT), což je SAT problém, ve kterém výrokové proměnné jsou nahrazeny vzorci jiného matematická teorie.
Algoritmus
Základní algoritmus zpětného sledování běží výběrem literálu, přiřazením a pravdivostní hodnota zjednodušení vzorce a rekurzivní kontrola, zda je zjednodušený vzorec uspokojivý; v takovém případě je původní vzorec uspokojivý; jinak se provede stejná rekurzivní kontrola za předpokladu opačné hodnoty pravdy. Toto je známé jako pravidlo rozdělení, protože rozděluje problém na dva jednodušší dílčí problémy. Krok zjednodušení v podstatě odstraní všechny klauze, které se stanou pravdivými pod přiřazením ze vzorce, a všechny literály, které se stanou nepravdivými ze zbývajících klauzulí.
Algoritmus DPLL se oproti algoritmu zpětného sledování vylepšuje dychtivým použitím následujících pravidel v každém kroku:
- Šíření jednotek
- Pokud je klauzule a jednotková klauze, tj. obsahuje pouze jeden nepřiřazený literál, lze tuto klauzuli splnit pouze přiřazením hodnoty nezbytné k tomu, aby byl tento literál pravdivý. Není tedy nutná žádná volba. V praxi to často vede k deterministickým kaskádám jednotek, čímž se vyhneme velké části prostoru naivního hledání.
- Čistá doslovná eliminace
- Pokud výroková proměnná vyskytuje se pouze s jednou polaritou ve vzorci, nazývá se čistý. Čisté literály lze vždy přiřadit tak, aby byly všechny klauze, které je obsahují, pravdivé. Tyto klauzule tedy již neomezují hledání a mohou být odstraněny.
Neuspokojitelnost daného částečného přiřazení je detekována, pokud se jedna klauzule vyprázdní, tj. Pokud byly všechny její proměnné přiřazeny způsobem, který způsobí, že odpovídající literály budou nepravdivé. Splnitelnost vzorce je detekována buď při přiřazení všech proměnných bez generování prázdné klauzule, nebo v moderních implementacích, pokud jsou splněny všechny klauzule. Neuspokojivost celého vzorce lze zjistit až po vyčerpávajícím hledání.
Algoritmus DPLL lze shrnout do následujícího pseudokódu, kde Φ je CNF vzorec:
Algoritmus Vstup DPLL: Sada klauzulí Φ. Výstup: Pravdivá hodnota.
funkce DPLL (Φ) -li Φ je konzistentní sada literálů pak vrátit se skutečný; -li Φ obsahuje prázdnou klauzuli pak vrátit se Nepravdivé; pro každého jednotková klauze {l} v Φ dělat Φ ← propagace jednotky(l, Φ); pro každého doslovný l k tomu dochází čistě v Φ dělat Φ ← pure-literal-assign(l, Φ); l ← zvolit doslovně(Φ); vrátit se DPLL(Φ ∧ {l}) nebo DPLL(Φ ∧ {ne (l)});
- „←“ označuje úkol. Například, "největší ← položka"znamená, že hodnota největší změny hodnoty položka.
- "vrátit se"ukončí algoritmus a odešle následující hodnotu.
V tomto pseudokódu unit-propagate (l, Φ)
a pure-literal-assign (l, Φ)
jsou funkce, které na literál vracejí výsledek použití šíření jednotky a čistého literálního pravidla l
a vzorec Φ
. Jinými slovy, nahrazují každý výskyt l
s "true" a každý výskyt ne l
s "false" ve vzorci Φ
a výsledný vzorec zjednodušte. The nebo
v vrátit se
prohlášení je a zkratový operátor. Φ ∧ {l}
označuje zjednodušený výsledek nahrazení „true“ za l
v Φ
.
Algoritmus končí v jednom ze dvou případů. Bylo zjištěno, že buď vzorec CNF Φ obsahuje a konzistentní sada literálů- to znamená, že neexistuje l
a ¬l
pro jakýkoli doslovný l
ve vzorci. V takovém případě lze proměnné triviálně uspokojit jejich nastavením na příslušnou polaritu obklopujícího literálu v ocenění. V opačném případě, když vzorec obsahuje prázdnou klauzuli, je klauzule vakuově nepravdivá, protože disjunkce vyžaduje, aby byl pravdivý celkový soubor alespoň jednoho člena, který je pravdivý. V tomto případě z existence takové klauze vyplývá, že vzorec (vyhodnocen jako a spojení všech klauzulí) nelze vyhodnotit jako pravdivé a musí být neuspokojivé.
Funkce DPLL pseudokódu vrátí pouze to, zda konečné přiřazení splňuje vzorec nebo ne. Ve skutečné implementaci se částečné uspokojivé přiřazení obvykle také vrátí po úspěchu; to lze odvodit z konzistentní sady literálů prvního -li
prohlášení o funkci.
Algoritmus Davis – Logemann – Loveland závisí na výběru větvení doslovný, což je doslovný údaj uvažovaný v kroku zpětného sledování. Ve výsledku to není přesně algoritmus, ale spíše rodina algoritmů, jeden pro každý možný způsob výběru větvicího literálu. Účinnost je silně ovlivněna volbou větvícího se literálu: existují instance, u nichž je doba chodu konstantní nebo exponenciální v závislosti na volbě větvených literálů. Takovým volbám se také říká heuristické funkce nebo větvení heuristiky.[6]
Vizualizace
Tento algoritmus vyvinuli Davis, Logemann, Loveland (1961). Některé vlastnosti tohoto původního algoritmu jsou:
- Je založen na vyhledávání.
- Je základem pro téměř všechny moderní SAT řešení.
- To ne používat učení nebo nechronologické zpětné sledování (zavedeno v roce 1996).
Příklad s vizualizací algoritmu DPLL s chronologickým zpětným sledováním:
Všechny klauzule tvořící vzorec CNF
Vyberte proměnnou
Rozhodněte se, proměnná a = False (0), zelené klauze se tak stanou True
Po několika rozhodnutích jsme našli implikační graf který vede ke konfliktu.
Nyní se vraťte zpět na okamžitou úroveň a silou přiřaďte této proměnné opačnou hodnotu
Ale vynucené rozhodnutí stále vede k dalšímu konfliktu
Vraťte se na předchozí úroveň a proveďte vynucené rozhodnutí
Udělejte nové rozhodnutí, ale vede to ke konfliktu
Udělejte vynucené rozhodnutí, ale opět to vede ke konfliktu
Zpět na předchozí úroveň
Pokračujte tímto způsobem a konečný implikační graf
Současná práce
V letech 2010s byly práce na vylepšení algoritmu provedeny třemi směry:
- Definování různých zásad pro výběr větvených literálů.
- Definování nových datových struktur, aby byl algoritmus rychlejší, zejména jeho část jednotkové šíření
- Definování variant základního algoritmu zpětného sledování. Druhý směr zahrnuje nechronologické zpětné sledování (aka zpětný skok ) a doložka učení. Tato upřesnění popisují metodu zpětného sledování po dosažení klauzule o konfliktu, která „učí“ hlavní příčiny (přiřazení proměnných) konfliktu, aby se zabránilo opětovnému dosažení stejného konfliktu. Výsledný Konfliktem řízené učení klauzule Řešitelé SAT jsou nejmodernější v roce 2014.[Citace je zapotřebí ]
Novější algoritmus z roku 1990 je Stålmarckova metoda. Také od roku 1986 (objednané omezené) binární rozhodovací diagramy byly také použity pro SAT řešení.
Vztah k jiným pojmům
Spuštění algoritmů založených na DPLL na neuspokojivých instancích odpovídá stromu rozlišení důkazy o vyvrácení.[7]
Viz také
Reference
Všeobecné
- Davis, Martin; Putnam, Hilary (1960). „Postup výpočtu pro teorii kvantifikace“. Deník ACM. 7 (3): 201–215. doi:10.1145/321033.321034.
- Davis, Martin; Logemann, George; Loveland, Donald (1961). „Strojový program pro dokazování věty“. Komunikace ACM. 5 (7): 394–397. doi:10.1145/368273.368557. hdl:2027 / mdp. 39015095248095.
- Ouyang, Ming (1998). "Jak dobrá jsou pravidla větvení v DPLL?". Diskrétní aplikovaná matematika. 89 (1–3): 281–286. doi:10.1016 / S0166-218X (98) 00045-6.
- John Harrison (2009). Příručka praktické logiky a automatizovaného uvažování. Cambridge University Press. str. 79–90. ISBN 978-0-521-89957-4.
Charakteristický
- ^ Nieuwenhuis, Robert; Oliveras, Albert; Tinelli, Cesar (2004), "Abstraktní DPLL a abstraktní DPLL modulové teorie" (PDF), Proceedings Int. Konf. na Logika pro programování, umělou inteligenci a uvažování, LPAR 2004, str. 36–50
- ^ Mezinárodní webová stránka soutěží SAT, sat! žít
- ^ Webové stránky zChaff
- ^ Web plev
- ^ „Web Minisat“.
- ^ Marques-Silva, João P. (1999). „Dopad větvení heuristiky v algoritmech výrokové uspokojivosti“. V Barahoně, Pedro; Alferes, José J. (eds.). Pokrok v oblasti umělé inteligence: 9. portugalská konference o umělé inteligenci, EPIA '99 Évora, Portugalsko, 21. – 24. Září 1999 Sborník. LNCS. 1695. 62–63. doi:10.1007/3-540-48159-1_5. ISBN 978-3-540-66548-9.
- ^ Van Beek, Peter (2006). Msgstr "Zpětné vyhledávání vyhledávacích algoritmů". V Rossi, Francesca; Van Beek, Peter; Walsh, Toby (eds.). Příručka programování omezení. Elsevier. p. 122. ISBN 978-0-444-52726-4.
Další čtení
- Malajština Ganai; Aarti Gupta; Dr. Aarti Gupta (2007). Škálovatelné řešení formálního ověření založené na SAT. Springer. 23–32. ISBN 978-0-387-69166-4.
- Gomes, Carla P .; Kautz, Henry; Sabharwal, Ashish; Selman, Bart (2008). „Řešitelé uspokojivosti“. In Van Harmelen, Frank; Lifschitz, Vladimir; Porter, Bruce (eds.). Příručka reprezentace znalostí. Základy umělé inteligence. 3. Elsevier. str. 89–134. doi:10.1016 / S1574-6526 (07) 03002-7. ISBN 978-0-444-52211-5.