Spis treści |
Rezolucja to metoda automatycznego dowodzenia twierdzeń oparta na generowaniu nowych klauzul, aż dojdzie się do sprzeczności. W ten sposób można udowodnić, że dane twierdzenie nie jest spełnialne, lub też, co jest równoważne, że jego zaprzeczenie jest tautologią.
Rezolucja jest podstawą wielu praktycznych systemów dowodzenia twierdzeń rachunku predykatów pierwszego rzędu.
Zasady generowania nowych klauzul to:
Gdzie α, β to formuły, Γ, Δ – zbiory formuł.
W rachunku zdań reguła rezolucji upraszcza się do:
Jeśli potrafimy dojść do klauzuli pustej rezolucja jest zakończona, i twierdzenie jest sprzeczne (a więc jego zaprzeczenie jest tautologią).
Udowodnimy że p → (p ∨ q):
Sprowadźmy najpierw ¬ (p → (p ∨ q)) do postaci z negacjami na liściach (nie jest to konieczne, ale potrzebne by były wtedy reguły usuwania każdego ze spójników oraz podwójnej negacji):
Rezolucja w działaniu:
Istnieje wiele wersji pochodnych rezolucji, polegających na ograniczeniu możliwości stosowania reguły rezolucji w prowadzaniu dodatkowych reguł (takich jak faktoryzacja czy kondensacja), co daje lepsze praktyczne rezultaty.
Jeśli dany skończony zbiór klauzul jest spełnialny, nie uda nam się udowodnić jego fałszywości przez rezolucję. Zasady pozbywania się spójników ∧ i ∨ są trywialne, zajmijmy się więc tylko zasadą rezolucji.
Jeśli istnieje podstawienie, które jest spełnialne zarówno przez [ α, Γ ] jak i przez [ ¬ α, Δ ], i dokonujemy na tych klauzulach rezolucji, są dwie możliwości:
Czyli rezolucja dwóch klauzul spełnialnych nie może dać klauzuli niespełnialnej.
W rachunku predykatów pierwszego rzędu, niech jeśli [Γ] jest spełnialne, to spełnialne jest też dowolne podstawienie [Γ]σ. W szczególności jeśli rezolwujemy [ α, Γ ] z [ ¬ β, Δ ], a σ jest unifikatorem α i β, to [ ασ, Γσ ] oraz [ ¬ βσ, Δσ ] (ασβσ) są spełnialne. Dalej prowadzi to do przypadku analogicznego do rachunku zdań:
Udowodnijmy, że jeśli dany zbiór klauzul (po zastosowaniu wszystkich reguł dla eliminacji spójników) jest sprzeczny, dojdziemy za pomocą rezolucji do klauzuli pustej.
Weźmy dowolną zmienną
. Są trzy grupy klauzul: zawierające
, zawierające
, oraz nie zawierające ani jednego ani drugiego. Klauzule zawierające zarówno
jak i
są oczywiście spełnialne i nie będziemy się nimi zajmować:
![\; [p,\Gamma_i],\; [\neg p,\Delta_j],\; [\Psi_k]](http://upload.wikimedia.org/wikipedia/pl/math/d/f/b/dfbb563c014caa102e99776f3d693e69.png)
Dla każdego wartościowania sprzeczne jest albo któreś
, albo któreś
, albo też któreś
. Utwórzmy wszystkie klauzule przez rezolucje względem
:
.
Teraz udowodnijmy że sprzeczny jest zbiór
. Jeśli w wartościowaniu któreś
nie było spełnione, to nowy zbiór – ponieważ też zawiera tę klauzulę – też nie spełnia tego wartościowania.
Rozpatrzmy więc przypadek kiedy tak nie jest. Ponieważ żadne wartościowanie nie spełnia tego zbioru, to nie spełnia go też żadne wartościowanie z pozytywnym
, a jako że wszystkie
są w takich wartościowaniach spełnione, a
, to jest przynajmniej jedno niespełnione
.
Weźmy też identyczne wartościowanie tyle że z negatywnym
. Wszystkie
są w tym wartościowaniu spełnione, a
. Tak więc jest przynajmniej jedno niespełnione
.
Ponieważ istnieją niespełnione
i
, a wszystkie pary utworzyliśmy przez rezolucje, to istnieje przynajmniej jedna para
która nie jest spełniona.
Tak więc z każdego zbioru klauzul sprzecznych o
zmiennych możemy stworzyć zbiór klauzul sprzecznych o
zmiennych, dochodząc w ten sposób w końcu do klauzuli pustej (przy okazji zwiększając liczbę klauzul wykładniczo).
Przypadek bez zmiennych jest trywialny – każdemu termowi przyporządkowujemy pewną zmienną zdaniową i dowód postępuje identycznie jak dla rachunku zdań.
Skończony, skolemizowany zbiór klauzul rachunku predykatów pierwszego rzędu odpowiada nieskończonemu zbiorowi wynikłemu z wszystkich możliwych podstawień zmiennych. "Dowolne" modele są jednak zbyt trudne – mogą one np. być nieprzeliczalne. Na szczęście zachodzi twierdzenie:
Modele Herbranda są przeliczalne i składają się z termów. Tak więc nieskończony zbiór klauzul będzie przeliczalnym zbiorem klauzul rachunku zdań.
Dodajmy do rezolucji dodatkową zasadę – zasadę substytucji – mówiącą, że możemy podstawić dowolne wyrażenie za daną zmienną – i będziemy podstawiać w taki sposób że kiedyś podstawimy wszystko co podstawić można w każde możliwe miejsce (czyli nałożymy na podstawienia jakiś porządek i będziemy podstawiać w końcu do każdej klauzuli którą mamy). Zgodnie z twierdzeniem o zwartości każdy sprzeczny zbiór formuł rachunku zdań ma sprzeczny podzbiór skończony. Tak więc odpowiednio podstawiając w końcu uzyskamy taki podzbiór, a że dla rachunku zdań rezolucja jest zupełna, razem z taką regułą dostajemy system zupełny.
Teraz wystarczy dowód korzystający z zasady substytucji przekształcić na dowód nie korzystający z tej zasady. Dowód składa się z kroków substytucji i rezolucji oraz klauzul powstałych w ich wyniku. Jeśli pewna klauzula została uzyskana w drodze substytucji, i wykorzystaliśmy ją również jedynie do substytucji, możeby zastąpić tę parę jedną substytucją.
Ponieważ w końcu uzyskujemy klauzulę pustą ostatnim krokiem dowodu musi być rezolucja – substytucja nie może prowadzić do zmniejszenia liczby elementów klauzuli.
Teraz wyeliminujmy pozostałe substytucje – jedyne substytucje jakie mamy w dowodzie to substytucje klauzul które potem będą wykorzystywane do rezolucji – ponieważ w przeciwnym wypadku ich wykluczenie nie psuje dowodu. Tak więc weźmy dowolny fragment dowodu postaci (nie muszą być one jedno po drugim w liniowej reprezentacji dowodu):
Ponieważ mamy przynajmniej jedną rezolucję, przynajmniej jedną substytucję (w przeciwnym wypadku dowód jest skończony), a każda substytucja jest użyta w rezolucji, zawsze będzie taki fragment. Rozpisując te wyrażenia będzie to:
![A = [\alpha,\Delta]](http://upload.wikimedia.org/wikipedia/pl/math/5/a/3/5a3827a430a273254e5130a3498a9a56.png)
,
– użyta substytucja![C = [\neg\beta,\Gamma]](http://upload.wikimedia.org/wikipedia/pl/math/2/4/9/249581b36fe7d0d5ac261ba83ee5d8f0.png)
–
– najmniejszy unifikator
i 
Lub też negacja będzie w A zamiast w C, co nie zmienia dowodu. Ponieważ
i
mają z definicji rozłączne zmienne
. Tak więc
i
można zunifikować w D za pomocą
. Każdy unifikator można rozbić na najmniejszy wspólny unifikator i jakieś podstawienie – niech
będzie najmniejszym wspólnym unifikatorem, a
takim podstawieniem, że
,
.
Tak więc możemy zmienić ten dowód na:
Teraz (pamiętając o składaniu substytucji) dojdziemy w końcu do sytuacji gdzie przenosimy substytucję (która mogła już osiągnąć gigantyczne rozmiary) przez ostatnią rezolucje. Ponieważ jednak podstawienie to zachodzi dla klauzuli pustej – w rzeczywistości możemy je zupełnie odrzucić.
Tak więc rezolucja bez dodatkowych zasad jest zupełna.