Mu-calcul

De testwiki
Version datée du 11 avril 2023 à 21:03 par imported>WikiCleanerBot (v2.05b - Modèles ne fonctionnant pas dans les listes - Correction syntaxique (Modèle dans une liste - Espace insécable))
(diff) ← Version précédente | Version actuelle (diff) | Version suivante → (diff)
Aller à la navigation Aller à la recherche

En logique mathématique et en informatique théorique, le mu-calcul (ou logique du mu-calcul modal) est l'extension de la logique modale classique avec des opérateurs de points fixes. Selon Bradfield et Walukiewicz[1], le mu-calcul est une des logiques les plus importantes pour la vérification de modèles ; elle est expressive tout en ayant de bonnes propriétés algorithmiques.

Le mu-calcul (propositionnel et modal) a d'abord été introduit par Dana Scott et Jaco de Bakker puis a été étendu dans sa version moderne par Dexter Kozen. Cette logique permet de décrire les propriétés des systèmes de transition d'états et de les vérifier. De nombreuses logiques temporelles (telles que CTL* ou ses fragments très usités comme Modèle:Lien ou LTL) sont des fragments du mu-calcul.

Une manière algébrique de voir le mu-calcul est de le considérer comme une algèbre de fonctions monotones sur un treillis complet, les opérateurs étant une composition fonctionnelle plus des points fixes ; de ce point de vue, le mu-calcul agit sur le treillis de l'algèbre des ensembles[2]. La sémantique des jeux du mu-calcul est liée aux jeux à deux joueurs à information parfaite, notamment les jeux de parité[3].

Syntaxe

Soient deux ensembles de symbole P (les propositions) et A (les actions) et V un ensemble énumérable infini de variables. L'ensemble des formules du mu-calcul (propositionnel et modal) est défini inductivement de la façon suivante :

  • chaque proposition est une formule ;
  • chaque variable est une formule ;
  • si ϕ et ψ sont des formules, alors (ϕψ) est une formule ;
  • si ϕ est une formule, alors ¬ϕ est une formule ;
  • si ϕ est une formule et a est une action, alors [a]ϕ est une formule (c'est la formule : « après a, nécessairement ϕ ») ;
  • si ϕ est une formule et Z une variable, alors νZ.ϕ est une formule à supposer que chaque occurrence de Z dans ϕ apparaît positivement, c'est-à-dire qu'elle est niée un nombre pair de fois.

Les notions de variables liées ou libres sont définies comme d'ordinaire avec ν qui est le seul opérateur liant une variable.

Avec les définitions ci-dessus, on peut rajouter comme sucre syntaxique :

  • ϕψ signifiant ¬(¬ϕ¬ψ) ;
  • aϕ signifiant ¬[a]¬ϕ (après a il est possible que ϕ) ;
  • μZ.ϕ signifiant ¬νZ.¬ϕ[Z:=¬Z], où ϕ[Z:=¬Z] signifie qu'on remplace Z par ¬Z pour chaque occurrence libre de Z dans ϕ.

Les deux premières formules sont familières du calcul des propositions et de la logique multimodale K.

La notation μZ.ϕ (et respectivement son dual νZ.ϕ) est inspirée du lambda-calcul ; l'objectif est de noter le plus petit (respectivement le plus grand) point fixe en la variable Z de l'expression ϕ tout comme en lambda-calcul λZ.ϕ est une fonction de la formule ϕ en la variable liée Z[4] ; voir la sémantique dénotationnelle plus bas pour plus de détails.

Sémantique dénotationnelle

Les modèles d'une formule mu-calcul (propositionnelle, modale) sont donnés comme des systèmes de transition d'états (S,R,V) où :

  • S est un ensemble d'états ;
  • R associe à chaque label a une relation binaire sur S ;
  • V:P2S associe à chaque proposition pP l'ensemble des états où la proposition est vraie.

Étant donné un système de transition (S,R,V), une interprétation i associe à toute variable Z un sous-ensemble d'états i(Z). On définit le sous-ensemble d'états [[ϕ_]]i par induction structurelle sur la formule ϕ :

  • [[p]]i=V(p) ;
  • [[Z]]i=i(Z) ;
  • [[ϕψ]]i=[[ϕ]]i[[ψ]]i ;
  • [[¬ϕ]]i=S[[ϕ]]i;
  • [[[a]ϕ]]i={sStS,(s,t)Rat[[ϕ]]i} ;
  • [[νZ.ϕ]]i={TST[[ϕ]]i[Z:=T]}, où i[Z:=T] associe Z à T tout en préservant les associations de i partout ailleurs.

Par dualité, l'interprétation des autres formules basiques est :

  • [[ϕψ]]i=[[ϕ]]i[[ψ]]i ;
  • [[aϕ]]i={sStS,(s,t)Rat[[ϕ]]i} ;
  • [[μZ.ϕ]]i={TS[[ϕ]]i[Z:=T]T}.

De manière informelle, pour un système de transition (S,R,V) :

  • p est vraie pour les états V(p) ;
  • ϕψ est vraie si ϕ et ψ sont vraies ;
  • ¬ϕ est vraie si ϕ n'est pas vraie ;
  • [a]ϕ est vraie dans l'état s si toutes les transitions a sortants de s mènent à un état où ϕ est vraie ;
  • aϕ est vraie dans un état s s'il existe au moins une transition a sortant de s qui mène à un état où ϕ est vraie ;
  • νZ.ϕ est vraie dans n'importe quel état de n'importe quel ensemble T tel que, si la variable Z est remplacée par T, alors ϕ est vraie pour tout T (du théorème de Knaster-Tarski, on déduit que [[νZ.ϕ]]i est le plus grand point fixe de [[ϕ]]i[Z:=T], et [[μZ.ϕ]]i en est le plus petit).

L'interprétation de [a]ϕ et aϕ est l'interprétation « classique » de la logique dynamique. De surcroît, μ peut être vu comme une propriété de vivacité (« quelque chose de bon intervient à un moment ») tandis que ν est vu comme une propriété de sûreté (« quelque chose de mauvais n'arrive jamais ») dans la classification informelle de Leslie Lamport[5].

Exemples

  • νZ.ϕ[a]Z est interprétée comme « ϕ est vraie pour chaque chemin de a »[5].
  • μZ.ϕaZ est interprétée comme l'existence d'un chemin de transitions a vers un état dans lequel ϕ est vraie[6].
  • La propriété d'un système d'être non bloquant, c'est-à-dire que de tout état accessible, il existe une transition sortante, peut être exprimée par la formule νZ.(aAaaA[a]Z) [6].
  • μZ.[a]Z : tout chemin composé de a-transitions est fini[7].
  • νZ.aZ : il existe un chemin infini composé de a-transitions[7].
  • νZ.ϕaZ : il existe un chemin infini composé de a-transitions le long duquel ϕ est vraie tout le temps[7].

Alternation

L'alternation de plus petits et plus grands points fixes s'appelle la profondeur d'alternation. On peut compter le nombre d'alternations mais généralement, on utilise une définition plus sophistiquée introduite par Damian Niwiński[8] qui regarde aussi l'utilisation des variables. La hiérarchie d'alternation est stricte[9].

Problèmes algorithmiques

Le problème de model checking du mu-calcul est dans NP inter co-NP[1] et est P-dur. Un algorithme pour le model checking du mu-calcul est le suivant :

  • Construire un jeu de parité à partir du système de transitions et de la formule du mu-calcul à vérifier ;
  • Résoudre le jeu de parité.

Le problème de satisfiabilité du mu-calcul est EXPTIME-complet[10].

Comme pour la logique temporelle linéaire (LTL)[11], le problème de la vérification de modèles, de la satisfiabilité et de la validité du mu-calcul linéaire est PSPACE-complet[12].

Discussions

La syntaxe originale du mu-calcul était vectorielle. L'avantage de cette notation est qu'elle permet de partager les variables sur plusieurs sous-formules[13]. Il existe une version linéaire (non branchée) du mu-calcul[14]Modèle:,[12].

Bibliographie

Liens externes

Notes et références

Modèle:Références Modèle:Traduction/Référence

Modèle:Portail

  1. 1,0 et 1,1 Modèle:Chapitre
  2. André Arnold et Damian Niwiński, Modèle:Langue, pp. viii-x et chapitre 6.
  3. André Arnold et Damian Niwiński, Modèle:Langue, pp. viii-x et chapitre 4.
  4. André Arnold et Damian Niwiński, Modèle:Langue, p. 14.
  5. 5,0 et 5,1 Julian Bradfield et Colin Stirling, Modèle:Langue, p. 731.
  6. 6,0 et 6,1 Modèle:Ouvrage.
  7. 7,0 7,1 et 7,2 Modèle:Lien web.
  8. Modèle:Article
  9. Modèle:Article
  10. Modèle:Ouvrage.
  11. Modèle:Article.
  12. 12,0 et 12,1 Modèle:Article.
  13. Modèle:Ouvrage
  14. Modèle:Article