est une formule de MSO et elle se lit « il existe un ensemble Z tel qu'il existe un élément u qui appartient à Z et pour tout x, si x est dans Z, alors il existe y tel que y est fils de x et y est dans Z ». Ce n'est pas une formule de la logique du premier ordre car il y a une quantification du second ordre sur Z ;
Toutes les formules de la logique du premier ordre sont des formules de MSO ;
La formule n'est pas une formule de MSO car il y a une quantification sur un prédicat binaire R.
Le problème de satisfiabilité de la logique du premier ordre étant indécidable, comme MSO est une extension conservatrice de la logique du premier ordre, le problème de satisfiabilité de MSO est aussi indécidable. Mais selon Yuri Gurevich[2], MSO est une source de théories logiques à la fois expressives et décidables.
Exemples de formules
La formule qui définit la récurrence, et qui se lit « pour tout ensemble X, si 0 appartient à X, et si pour tout y, y appartient à X implique y+1 appartient à X alors pour tout z, z appartient à X » est une formule de MSO. Les quantifications « pour tout y » et « pour tout z » sont des quantifications du premier ordre. La quantification « pour tout X » est une quantification du second ordre.
Toutes les formules de la logique du premier ordre sont des formules de MSO.
MSO et graphes
MSO a été défini sur des classes de graphes (par exemple, non orientés). Par exemple, on peut exprimer en MSO qu'un graphe n'est pas connexe[3] : qui se lit « il existe un ensemble de sommets Z tel qu'il existe un sommet x contenu dans Z et un sommet y en dehors de Z et tel que si deux sommets u et v sont reliés par une arête, alors u est dans Z si et seulement si v est dans Z » (voir figure à droite). La connexité n'est pas définissable en logique du premier ordre (c'est une conséquence du théorème de compacité de la logique du premier ordre[4]). Ainsi MSO est strictement plus expressive que la logique du premier ordre sur les graphes.
Sur une classe finie, MSO et la logique du premier ordre ont une expressivité équivalente. Il existe des classes infinies où MSO et la logique du premier ordre ont une expressivité équivalente[5],[6].
Le théorème de Courcelle est un résultat algorithmique sur MSO et les graphes : toute propriété de MSO est décidable en temps linéaire dans la classe des graphes avec une largeur arborescente bornée[3]. Par exemple, d'après le théorème de Courcelle, savoir si un graphe est coloriable avec 3 couleurs est décidable en temps linéaire sur la classe des graphes avec un treewidth borné. En effet, on peut exprimer en MSO qu'un graphe est coloriable avec trois couleurs avec la formule suivante : . La formule se lit « il existe des ensembles de sommets C1, C2, C3 qui forment une partition du graphe et tels que deux sommets adjacents ne soient pas dans un même Ci ». Par contre, le problème de décision qui consiste à savoir si n'importe quel graphe est coloriable avec 3 couleurs est un problème NP-complet.
Büchi a démontré qu'un langage de mots finis est régulier si et seulement s'il est décrit par une formule de MSO sur les mots. MSO est strictement plus expressive que la logique du premier ordre sur les mots finis : la classe des langages de mots finis définis par la logique du premier ordre est la classe des langages sans étoile[7],[8].
Mots infinis
Büchi a aussi démontré qu'un langage est régulier si et seulement s'il est décrit par une formule de MSO sur les mots.
S1S (pour second-order with 1 successor) est une variante de MSO interprétée sur le domaine des entiers, avec un prédicat pour le successeur et un pour l'ordre[2]. Büchi a démontré en 1962 que S1S est décidable en établissant une correspondance entre la satisfiabilité d'une formule de S1S et la vacuité d'un automate de Büchi[9]. Elgot et Rabin ont démontré que l'on peut ajouter à S1S le prédicat unaire « être un nombre factoriel » ou « être une puissance de k » tout en restant décidable[10]. Par contre, si on ajoute la fonction « fois 2 » au langage, on obtient toute l'arithmétique sur les entiers avec addition et multiplication et on obtient une logique indécidable.
Arbres binaires
On appelle S2S (pour second-order with 2 successors) la variante de MSO pour parler de propriétés sur le modèle de l'arbre binaire infini. Rabin a montré que l'on peut plonger les MSO sur les arbres d'arité 3, 4 et même les arbres d'arité infinie dénombrable dans S2S[11]. Rabin a démontré la décidabilité de S2S par réduction à la vacuité d'un automate d'arbre infini. Par contre, la logique monadique du second ordre sur l'arbre binaire infini avec en plus la relation « même niveau » est indécidable[12].
Version faible
Une variante de MSO, dite faible (et notée WMSO pour weak MSO), a été considérée où la quantification du second ordre porte sur des sous-ensembles finis.
WS1S
WS1S (pour weak second-order with 1 successor) est une variante de S1S où la quantification du second ordre porte uniquement sur les sous-ensembles finis. La décidabilité de WS1S a été démontré avant celle de S1S, par Büchi en 1960[13] et Algot en 1961[14]. La preuve de décidabilité de WS1S s'obtient directement de celle de S1S puisque WS1S peut être vu comme un fragment syntaxique de S1S (on peut exprimer la finitude d'un ensemble dans S1S). On peut démontrer que l'arithmétique de Presburger est décidable en transformant une formule de l'arithmétique de Presburger en une formule de WS1S.
Büchi[15] a montré qu'il y a équivalence, pour tout langage de mots infinis L, entre :
Les équivalences sont effectives : on transforme une formule S1S en un automate de Büchi. Ainsi, la logique S1S (et WS1S) est décidable. La logique S1S est de complexité non élementaire[16].
WS2S
WS2S (pour weak second-order with 2 successors) est une variante de S2S où la quantification du second ordre est uniquement sur les sous-ensembles finis. WS2S est décidable. WS2S est strictement plus faible que S2S. L'inclusion WS2S ⊆ S2S est stricte, en effet : pour tout langage L d'arbres binaires infinis, on a équivalence entre[17],[18] :
L et son complémentaire sont reconnaissables par un automate d'arbres avec condition de Büchi ;
L est définissable dans WS2S.
Plus précisément, le langage défini par « il y a un chemin contenant une infinité de b » est reconnaissable par un automate de Büchi alors que son complémentaire ne l'est pas[19]. Ainsi, ce langage est définissable dans S2S, mais pas dans WS2S.
Théorie des groupes
MSO sur les groupes abéliens ordonnés où la quantification du second ordre est restreinte aux sous-groupes convexes est décidable[20].
Invariance par bisimulation
À l'instar du théorème de Van Benthem qui dit que toute formule du première ordre invariante par bisimulation est équivalente à (la traduction standard d') une formule de la logique modale, Janin et Walukiewicz ont démontré que toute formule de MSO invariante par bisimulation est équivalente à une formule du mu-calcul[21].
Il est folklore (voir[22]) d'avoir la variante du théorème de Van Benthem suivante pour WMSO sur les arbres à arité fixée : toute formule de WMSO sur les arbres d'arité k invariante par bisimulation est équivalente à une formule du fragment mu-calcul sans alternance (Arnold et Niwinski ont donné la preuve complète dans le cas des arbres binaires, c'est-à-dire pour WS2S[23]).
Le résultat est plus compliqué pour les arbres d'arités quelconques non fixées. D'une part, il existe une autre variante de MSO qui correspond au fragment sans alternance du mu-calcul[24]. D'autre part, il existe un fragment du fragment du mu-calcul sans alternance qui correspond WMSO invariant par bisimulation[22].
Selon la structure sur laquelle MSO est interprétée, le nombre d'alternances entre quantificateurs existentiels et universels du second ordre nécessaires pour obtenir l'expressivité maximale de la logique varie. Dans l'interprétation de MSO sur les arbres infinis, toute formule MSO est équivalente à une formule utilisant deux alternances de quantificateurs monadiques[26]. Dans l'interprétation sur des modèles finis à deux dimensions et coloriés (pictures model), une seule alternance suffit[27]. Dans le cas des structures finies, il n'est par contre pas possible de restreindre le nombre d'alternances[28].
↑ a et b(en) Y. Gurevich, « Monadic Second-Order Theories », dans J. Barwise, S. Feferman, Model-Theoretic Logics, New York, Springer-Verlag, , 479-506 p. (lire en ligne).
↑A. Dawar et L. Hella, « The Expressive Power of Finitely Many Generalized Quantifiers », Information and Computation, vol. 123, , p. 172–184 (DOI10.1006/inco.1995.1166, lire en ligne, consulté le ).
↑Michael Elberfeld, Martin Grohe et Till Tantau, « Where First-Order and Monadic Second-Order Logic Coincide », Proceedings of the 2012 27th Annual IEEE/ACM Symposium on Logic in Computer Science, IEEE Computer Society, lICS '12, , p. 265–274 (ISBN9780769547695, DOI10.1109/LICS.2012.37, lire en ligne, consulté le ).
↑M. P. Schützenberger, « On finite monoids having only trivial subgroups », Information and Control, vol. 8, , p. 190–194 (DOI10.1016/S0019-9958(65)90108-7, lire en ligne, consulté le ).
↑(en) J. Richard Büchi, « On a decision method in restricted second order arithmetic », dans S. Mac Lane, D. Siefkes, The Collected Works of J. Richard Büchi, New York, Springer, (ISBN978-1-4613-8930-9).
↑(en) Calvin C. Elgot et Michael O. Rabin, « Decidability and Undecidability of Extensions of Second (First) Order Theory of (Generalized) Successor », Journal of Symbolic Logic, vol. 31, , p. 169–181 (ISSN0022-4812 et 1943-5886, lire en ligne, consulté le ).
↑(en) Rabin M. O., « Decidability of second order theories and automata on infinite trees », Transactions of the American Mathematical Society, vol. 141, , p. 1-35.
↑Wolfgang Thomas, « Automata on infinite objects », dans Handbook of theoretical computer science (volume B), MIT Press, , 133–191 p. (ISBN0444880747, lire en ligne)
↑(en) Michael O. Rabin, « Weakly Definable Relations and Special Automata », Mathematical Logic and Fondations of Set Theory, North-Holland, vol. 59, , p. 1–23 (ISSN0049-237X, DOI10.1016/S0049-237X(08)71929-3, lire en ligne, consulté le )
↑(en) David Janin et Igor Walukiewicz « On the Expressive Completeness of the Propositional Mu-Calculus With Respect to Monadic Second Order Logic » () (lire en ligne, consulté le ) —CONCUR '96: Concurrency Theory — « (ibid.) », dans Lecture Notes in Computer Science, vol. 1119, Springer.
↑ a et bFacundo Carreiro, Alessandro Facchini, Yde Venema et Fabio Zanasi, « Weak MSO: Automata and Expressiveness Modulo Bisimilarity », Proceedings of the Joint Meeting of the Twenty-Third EACSL Annual Conference on Computer Science Logic (CSL) and the Twenty-Ninth Annual ACM/IEEE Symposium on Logic in Computer Science (LICS), ACM, cSL-LICS '14, , p. 27:1–27:27 (ISBN9781450328869, DOI10.1145/2603088.2603101, lire en ligne, consulté le ).
↑A. Facchini, Y. Venema et F. Zanasi, « A Characterization Theorem for the Alternation-Free Fragment of the Modal #x00B5;-Calculus », 2013 28th Annual IEEE/ACM Symposium on Logic in Computer Science (LICS), , p. 478–487 (DOI10.1109/LICS.2013.54, lire en ligne, consulté le ).
↑C. Riba, « A Model Theoretic Proof of Completeness of an Axiomatization of Monadic Second-Order Logic on Infinite Words », FIP International Federation for Information Processing, Springer Berlin Heidelberg, , p. 310-324 (DOI10.1007/978-3-642-33475-7_22, lire en ligne, consulté le ).
↑(en) Wolfgang Thomas, Handbook of Formal Languages : Volume 3 Beyond Words (Languages, automata, and logic), Grzegorz Rozenberg, Arto Salomaa.
↑(en) O. Matz, « One quantifier will do in existential monadic second-order logic over pictures », Mathematical Foundations of Computer Science 1998, august 24–28, 1998, p. 751-759 (ISSN0302-9743, lire en ligne).
↑(en) M. Otto, « A note on the number of monadic quantifiers in monadic ∑^1_1 », Information Processing Letters, , p. 337-339 (lire en ligne).