- Règle de résolution
-
La règle de résolution ou principe de résolution de Robinson est une règle d'inférence logique que l'on peut voir comme une généralisation du modus ponens. Cette règle est principalement utilisée dans les systèmes de preuve automatiques, elle est à la base du langage de programmation logique Prolog.
Sommaire
Définition
La règle de résolution s'applique sur deux clauses, c'est-à-dire des formules composées de disjonctions de littéraux, un littéral étant un atome (positif) ou un atome précédé d'une négation (négatif).
Etant donné deux clauses
où les littéraux Li et Mj sont l'un positif et l'autre négatif et qu'ils portent sur le même atome.
Le résolvant de C1 et C2 sur Li et Mj est la clause
Exemples
Soit
La résolution sur b produit
La règle du modus ponens est un cas particulier de résolution avec
Utilisation en logique des prédicats
En logique des prédicats les formules atomiques sont de la forme où P est un symbole de prédicat et les ti sont des termes composés de constantes, de variables et de symboles de fonctions. On peut effectuer la résolution sur deux littéraux s'ils portent sur des formules atomiques identique ou sur des formules unifiables. Deux formules atomiques sont unifiables s'il existe une substitution des variables par des termes qui rend les deux formules identiques.
Par exemple, les formules atomiques
P(x,a,y) et P(c,a,z), où a et c sont des constantes,
sont unifiables par la substitution . Par contre
P(x,a,y) et P(c,b,z)
ne sont pas unifiables car les constantes ne peuvent être remplacées.
Exemple
C2 = Q(a)
C3 = P(b)
La substitution permet d'appliquer la résolution sur Q, entre C1 et C2, ce qui produit
La substitution permet d'appliquer la résolution sur P, entre C3 et CR pour produire
CS = R(b,a)
Résolution et preuves par réfutation
En général on utilise le principe de résolution pour effectuer des preuves par réfutation. Pour prouver que la formule f est une conséquence logique des formules on démontre que l'ensemble est inconsistant.
Pratiquement, il faut commencer par mettre toutes les formules sous forme clausale, pour cela on doit les mettre sous forme prenex (tous les quantificateurs au début) puis les skolemiser.
Pour montrer qu'un ensemble de clause est inconsistant il faut réussir à générer la clause vide en appliquant la règle de résolution autant de fois que nécessaire.
Exemple
On veut montrer que les trois formules
- ,
- ,
ont pour conséquence la formule P(a).
La première formule est équivalente à et produit donc les deux clauses
La seconde formule donne immédiatement la clause
et la troisième
.
La négation de la conséquence cherchée donne
Par résolution sur R de C3 et C4 avec on produit
C6 = S(a)
Par résolution sur S de C1 et C6 on produit
C7 = P(a)
Enfin C5 et C7 donnent la clause vide.
Stratégie d'application de la règle
Le principe de résolution étant complet, si l'ensemble de clause considéré est inconsistant on arrive toujours à générer la clause vide. Par contre, le problème de la consistance (satisfaisabilité) n'étant pas décidable en logique des prédicat, il n'existe pas de méthode pour nous dire quelles résolutions effectuer et dans quel ordre pour arriver à la clause vide.
On peut facilement trouver des exemples où l'on "s'enfonce" dans la génération d'une infinité des clauses sans jamais atteindre la clause vide, alors qu'on l'aurait obtenue en faisant les bons choix.
Différentes stratégies ont été développées pour guider le processus. Le système Prolog se base, par exemple, sur l'ordre d'écriture des clauses et l'ordre des littéraux dans les clauses. D'autres systèmes, comme CyC utilisent une stratégie de coupure (en fonction des ressources consommées) pour éviter de générer des branches infinies.
Références
- (en) Robinson J. A. "A Machine-Oriented Logic Based on the Resolution Principle." J. Assoc. Comput. Mach. 12, 23-41, 1965.
- (en) Kowalski, R. Logic for Problem Solving. North Holland, Elsevier, 1979.
- (fr) Benzaken, C. Systèmes formels : introduction à la logique et à la théorie des langages. Masson, Paris, 1991.
- (en) Bundy, A. The Computer Modelling of Mathematical Reasoning. Academic Press, London, 1983.
- (en) Huth, M., Ryan, M. Logic in Computer Science, Cambridge University Press, 2004.
Wikimedia Foundation. 2010.