Negation as failure

Negation as failure

Négation par l'échec

La négation par l'échec (en anglais NAF pour negation as failure, ou NBF pour negation by failure) est une règle d'inférence non monotone en programmation logique, utilisée pour la dérivation de not~p à partir de l'échec de la dérivation de p. C'est une caractéristique importante de la programmation logique depuis les origines de Planner et de Prolog. En Prolog, la négation par l'échec est habituellement implémentée en utilisant les fonctionnalités non logiques du langage.

En Prolog pur, les littéraux de négation par l'échec (littéraux négatifs) de la forme not~p peuvent apparaître dans le corps des clauses et peuvent être utilisés pour dériver d'autres littéraux négatifs. Par exemple, si l'on considère uniquement les quatre clauses suivantes :

p \leftarrow q \and not~r
q \leftarrow s
q \leftarrow t
t \leftarrow

La négation par l'échec dérive not~s, not~r et p.

Sommaire

Sémantique par complétion

La sémantique de la négation par l'échec est restée un problème ouvert jusqu'à ce que Keith Clark montre en 1978[1] qu'elle était correcte par rapport à la complétion du programme logique où, en gros, « seulement » et \leftarrow sont interprétés comme « si et seulement si », abrégé en « ssi » et noté \equiv.

Par exemple, la complétion des quatre clauses précédentes est :

p \equiv q \and not~r
q \equiv s \or t
t \equiv true
r \equiv false
s \equiv false

La règle d'inférence de la négation par l'échec simule un raisonnement avec une complétion explicite, où la négation est appliquée aux deux côtés de l'équivalence et où la négation de la partie droite est distribuée sur les formules atomiques. Par exemple, pour montrer not~p, la négation par l'échec simule un raisonnement avec les équivalences suivantes :

not~p \equiv not~q \or r
not~q \equiv not~s \and not~t
not~t \equiv false
not~r \equiv true
not~s \equiv true

Dans le cas non propositionnel, il faut étendre la complétion avec des axiomes d'égalité, pour formaliser l'hypothèse que des entités avec des noms différents sont elles-mêmes distinctes. La négation par l'échec simule ceci par l'échec de l'unification. Par exemple, si l'on considère uniquement les deux clauses suivantes :

p(a) \leftarrow
p(b) \leftarrow

On dérive, avec la négation par l'échec, not~p(c).

La complétion du programme est :

p(X) \equiv X=a \or X=b

étendue avec les axiomes d'unicité des noms et de fermeture du domaine.

La sémantique par complétion est étroitement liée à la notion de circonscription et à l'hypothèse du monde fermé.

Sémantique auto-épistémique

La sémantique par complétion justifie l'interprétation du résultat not~p d'une inférence en négation par l'échec comme la négation classique \neg p de p. Cependant, Michael Gelfond a montré en 1987[2] qu'il était également possible d'interpréter not~p de manière littérale comme « p ne peut pas être montré », « p n'est pas connu » ou « p n'est pas cru », comme en logique auto-épistémique. L'interprétation auto-épistémique a été développée en 1988 par Gelfond et Lifschitz[3], et constitue la base de l'answer set programming.

La sémantique auto-épistémique d'un programme Prolog pur P avec la négation par l'échec sur des littéraux est obtenue en « étendant » P avec un ensemble Δ de littéraux négatifs (au sens de la négation par l'échec) exempts de variable libres tel que Δ soit stable au sens où :

Δ = {not~p | P ∪ Δ n'implique pas p}

En d'autres termes, un ensemble d'hypothèses Δ sur ce qui ne peut pas être démontré est stable si et seulement si Δ est l'ensemble de toutes les formules qui ne peuvent véritablement pas être montrées à partir du programme P étendu à l'aide de Δ. Ici, à cause de la syntaxe simple des programmes en Prolog pur, l'implication peut être comprise simplement comme la dérivabilité à l'aide du modus ponens et de la substitution uniforme, à l'exception de tout autre règle.

Un programme peut avoir zéro, une ou plusieurs extensions stables. Par exemple, le programme suivant n'a aucune extension stable :

p \leftarrow  not~p

Celui-ci a exactement une extension stable Δ = {not~q}

p \leftarrow  not~q

Ce troisième programme a deux extensions stables Δ1 = {not~p} et Δ2 = {not~q}.

p \leftarrow  not~q
q \leftarrow  not~p

L'interprétation auto-épistémique de la négation par l'échec peut être combinée avec la négation classique, comme en programmation logique étendue et en answer set programming. En combinant les deux négations, on peut par exemple exprimer l'hypothèse du monde fermé :

\neg p \leftarrow not~p

Ou encore la valeur par défaut d'une proposition :

p \leftarrow not~\neg p

Notes et références de l'article

  1. (en)Keith Clark, "Negation as Failure", Readings in Nonmonotonic Reasoning, Morgan Kaufmann Publishers, 1978, pages 311-325, abstract en ligne.
  2. (en) M. Gelfond, "On Stratified Autoepistemic Theories", AAAI-87 Sixth National Conference on Artificial Intelligence, 1987, pages 207-211, lire en ligne.
  3. (en) M. Gelfond and V. Lifschitz, "The Stable Model Semantics for Logic Programming", 5th International Conference and Symposium on Logic Programming, R. Kowalski et K. Bowen (éditeurs), MIT Press, 1988, pages 1070-1080, lire en ligne.
  • (en) Cet article est partiellement ou en totalité issu d’une traduction de l’article de Wikipédia en anglais intitulé « Negation as failure ».

Voir aussi

Articles connexes

Liens et documents externes

  • Portail de la logique Portail de la logique
Ce document provient de « N%C3%A9gation par l%27%C3%A9chec ».

Wikimedia Foundation. 2010.

Contenu soumis à la licence CC-BY-SA. Source : Article Negation as failure de Wikipédia en français (auteurs)

Игры ⚽ Нужно решить контрольную?

Regardez d'autres dictionnaires:

  • Negation by failure — Négation par l échec La négation par l échec (en anglais NAF pour negation as failure, ou NBF pour negation by failure) est une règle d inférence non monotone en programmation logique, utilisée pour la dérivation de à partir de l échec de la… …   Wikipédia en Français

  • Negation as failure — (NAF, for short) is a non monotonic inference rule in logic programming, used to derive (i.e. that is assumed not to hold) from failure to derive . Note that can be different from the statement of the logical negation of …   Wikipedia

  • Negation par l'echec — Négation par l échec La négation par l échec (en anglais NAF pour negation as failure, ou NBF pour negation by failure) est une règle d inférence non monotone en programmation logique, utilisée pour la dérivation de à partir de l échec de la… …   Wikipédia en Français

  • Négation par l'échec — La négation par l échec (en anglais NAF pour negation as failure, ou NBF pour negation by failure) est une règle d inférence non monotone en programmation logique, utilisée pour la dérivation de à partir de l échec de la dérivation de p. C est… …   Wikipédia en Français

  • Negation — For other uses, see Negation (disambiguation). In logic and mathematics, negation, also called logical complement, is an operation on propositions, truth values, or semantic values more generally. Intuitively, the negation of a proposition is… …   Wikipedia

  • Of Fracture and Failure — Studio album by Ulcerate Released 2007 …   Wikipedia

  • Logic programming — is, in its broadest sense, the use of mathematical logic for computer programming. In this view of logic programming, which can be traced at least as far back as John McCarthy s [1958] advice taker proposal, logic is used as a purely declarative… …   Wikipedia

  • Stable model semantics — The concept of a stable model, or answer set, is used to define a declarative semantics for logic programs with negation as failure. This is one of several standard approaches to the meaning of negation in logic programming, along with program… …   Wikipedia

  • Planner (programming language) — Planner (often seen in publications as PLANNER although it is not an acronym) is a programming language designed by Carl Hewitt at MIT, and first published in 1969. First, subsets such as Micro Planner and Pico Planner were implemented, and then… …   Wikipedia

  • Closed world assumption — The closed world assumption (CWA) is the presumption that what is not currently known to be true, is false. The same name also refers to a logical formalization of this assumption by Raymond Reiter. The opposite of the closed world assumption is… …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”