« Théorème de Rice » : différence entre les versions

Un article de Wikipédia, l'encyclopédie libre.
Contenu supprimé Contenu ajouté
Fschwarzentruber (discuter | contributions)
Ydadloupi (discuter | contributions)
Ligne 78 : Ligne 78 :


=== Théorème de Rice pour les ensembles ===
=== Théorème de Rice pour les ensembles ===
Le théorème de Rice pour les fonctions calculables peut également être exprimé{{Référence nécessaire|date=30 novembre 2017}} du
Le théorème de Rice pour les fonctions calculables peut également être exprimé<ref name=":8">{{Ouvrage|langue=|auteur1=|prénom1=Kozen, Dexter,|nom1=1951-|titre=Automata and computability|passage=Lecture 34|lieu=|éditeur=|date=|pages totales=|isbn=9783642857065|oclc=883383306|lire en ligne=https://www.worldcat.org/oclc/883383306}}</ref> du
point de vue des ensembles [[récursivement énumérable|récursivement énumérables]].
point de vue des ensembles [[récursivement énumérable|récursivement énumérables]].
Notons ''RE'' la classe de tous les sous-ensembles de <math>\mathbb{N}</math> [[récursivement énumérable|récursivement énumérables]]. Soit ''E'' <math> \subseteq</math> ''RE''. Notons ''P'' l'ensemble des programmes ''p'' qui décident un ensemble ''A'' <math> \in</math> ''E'' (i.e. ''y'' <math> \in</math> ''A'' ssi l'exécution de ''p'' se termine sur l'entrée ''y'').
Notons ''RE'' la classe de tous les sous-ensembles de <math>\mathbb{N}</math> [[récursivement énumérable|récursivement énumérables]]. Soit ''E'' <math> \subseteq</math> ''RE''. Notons ''P'' l'ensemble des programmes ''p'' qui décident un ensemble ''A'' <math> \in</math> ''E'' (i.e. ''y'' <math> \in</math> ''A'' ssi l'exécution de ''p'' se termine sur l'entrée ''y'').
Ligne 87 : Ligne 87 :
Soit ''Prop'' une propriété sur les ensembles récursivement énumérables et ''E<sub>Prop</sub>'' <math> \subseteq</math> ''RE'' la classe des ensembles récursivement énumérables qui satisfont ''Prop''.
Soit ''Prop'' une propriété sur les ensembles récursivement énumérables et ''E<sub>Prop</sub>'' <math> \subseteq</math> ''RE'' la classe des ensembles récursivement énumérables qui satisfont ''Prop''.
Notons ''P<sub>A</sub>'' l'ensemble des programmes ''p'' qui décident un ensemble ''A'' <math> \in</math> ''E'' (i.e. ''y'' <math> \in</math> ''A'' ssi l'exécution de ''p'' se termine sur l'entrée ''y'').
Notons ''P<sub>A</sub>'' l'ensemble des programmes ''p'' qui décident un ensemble ''A'' <math> \in</math> ''E'' (i.e. ''y'' <math> \in</math> ''A'' ssi l'exécution de ''p'' se termine sur l'entrée ''y'').
Cette variante du théorème de Rice<ref name=":5" /><ref name=":4" /> dit que si ''P<sub>E<sub>Prop</sub></sub>'' est [[récursivement énumérable]], alors ''Prop'' est monotone.
Cette variante du théorème de Rice<ref name=":5" /><ref name=":4" /><ref name=":8" /> dit que si ''P<sub>E<sub>Prop</sub></sub>'' est [[récursivement énumérable]], alors ''Prop'' est monotone.


== Démonstration du théorème de Rice ==
== Démonstration du théorème de Rice ==

Version du 30 novembre 2017 à 23:29

En informatique théorique, plus précisément en théorie de la calculabilité, le théorème de Rice énonce que toute propriété sémantique non triviale d'un programme est indécidable[1],[2],[3]. Le théorème de Rice généralise l'indécidabilité du problème de l'arrêt. Le théorème est classique[4],[5],[6],[7],[8],[9] et fait l'objet d'exercices dans certains ouvrages de théorie de la calculabilité[10].

Explication de l'énoncé

L'animation montre une machine impossible : d'après le théorème de Rice, il n'existe pas de machine qui lit des codes sources de fonctions et qui prédit si la fonction ne retourne jamais un entier non nul.

Les propriétés sémantiques concernent le comportement d'un programme et s'opposent aux propriétés syntaxiques sur le code source du programme. Une propriété est non triviale si elle n'est ni vraie pour toute fonction calculable, ni fausse pour toute fonction calculable. La table suivante donne des exemples de propriétés non triviales syntaxiques et des propriétés non triviales sémantiques. Le théorème de Rice ne s'applique qu'aux propriétés sémantiques.

Propriétés syntaxiques (attention, le théorème de Rice ne s'applique pas) Propriétés sémantiques (et donc indécidables par le théorème de Rice)
  • « le programme ne rend jamais de valeurs nulles[3] »
  • « le programme ne termine jamais par une erreur d'exécution »
  • « le programme calcule le même résultat qu'un programme donné », autrement dit « le programme calcule une fonction calculable donnée ».
  • « le programme calcule un résultat correct par rapport à sa spécification » autrement dit « la fonction calculée par le programme est bien celle définie par la spécification ». C'est une variante du précédent.
  • « le programme contient un virus »
  • « le programme accède à un site Web »

Impact en vérification de programmes

Pour vérifier qu'un programme est correct, on peut recourir au test, y compris à des batteries de tests avec couverture de code. Mais comme l'a souligné Edsger Dijkstra « Le test de programmes peut être une façon très efficace de montrer la présence de bugs, mais est désespérément inadéquat pour prouver leur absence »[11].

La formulation pragmatique du théorème de Rice est qu'aucune méthode automatique d'analyse statique de programmes ne permet de décider, à partir du code source d'un programme, si la fonction qui associe les entrées à la sortie de ce programme satisfait ou non une propriété intéressante (non triviale) donnée.

En pratique, on adopte des stratégies pour contourner les limitations du théorème de Rice[12],[13] :

  1. Vérification de programmes avec seulement un nombre fini d'états.
  2. Méthode de vérification partiellement automatisée.
  3. Méthodes à base d'approximations.
  4. Méthodes restreignant l'ensemble des programmes sur lesquell on veut démontrer la propriété.
  5. Restrictions raisonnables de l'ensemble des fonctions calculables[14].

Ces stratégies ont donné lieu à différentes approches pour vérifier des programmes : l'interprétation abstraite, la vérification de modèles (model checking[15]) et la preuve semi-automatisée de programmes par assistant de preuve. Aucune de ces méthodes n'a une portée universelle. Des recherches en cours visent à étendre les domaines d'application des vérificateurs, donc à diminuer les restrictions citées ci-dessus, mais le théorème de Rice dit que le vérificateur absolu n'existe pas ou comme disait Frederick Brooks « il n'y a pas de balle en argent »[16].

Un cas particulier introductif : la fonction réalisée par un programme

Comme introduction au théorème de Rice, considérons le cas spécifique où la propriété du programme soumise à décision est le fait que le programme calcule une fonction donnée que nous appelons  ; on dit aussi que le programme « réalise » la fonction . Par rapport à ce que nous avons dit dans l'introduction et le premier paragraphe, la propriété à décider sur la fonction associée au programme est l'égalité à . Autrement dit, on veut savoir si la fonction calculée par le programme est la fonction ou non. Nous allons considérer trois cas de généralité croissante.

La fonction est la fonction nulle part définie

Si la fonction calculée par le programme est celle qui n'est pas définie, cela signifie que le programme ne se termine jamais, quelle que soit la valeur en entrée. Décider cette propriété n'est pas possible en application du théorème de l'Indécidabilité de l'arrêt qui peut se formuler en disant qu'il n'y a pas d'algorithme pour décider si un programme réalise la fonction nulle part définie.

La fonction est la fonction carré

Supposons que nous souhaitions décider si un programme réalise la fonction carré, autrement dit, réalise la fonction . Il faut que nous puissions décider si le programme

programmeCarré_p (x) =
(x);
x * x

est un programme quelconque, calcule effectivement la fonction pour une valeur , sans être non défini sur . Pour décider si le programme programmeCarré_p calcule la fonction carré, il faut décider si se termine sur . Il faut donc décider l'arrêt de sur . C'est ni plus ni moins le problème de l'arrêt, qui, comme l'on sait, est indécidable. Donc décider si un programme calcule le carré de la valeur qu'on lui donne en entrée est indécidable.

La fonction est une fonction quelconque

On peut dans ce cas aussi ramener la décision de la fonction calculée par un programme pour une fonction quelconque au problème de l'arrêt, il suffit de remplacer x * x par (x), à savoir décider si le programme

truc_p (x) =
(x);
(x)

calcule la fonction . On en conclut donc qu'étant donnée une fonction , décider si un programme calcule la fonction est indécidable.

Différentes présentations

Dans cette section, nous exposons différentes versions du théorème de Rice dans la littérature.

Version avec des machines de Turing

Dans les ouvrages de théorie de la calculabilité, le théorème de Rice est souvent énoncé avec l'appui des machines de Turing[6],[17]. Wolper, dans son livre Introduction à la Calculabilité[2], énonce que toute propriété non triviale sur les langages récursivement énumérables est indécidable. On rappelle qu'un langage est récursivement énumérable s'il est accepté par une machine de Turing. Wolper insiste bien qu'il s'agit d'une propriété sur les langages acceptés par les machines de Turing et non pas sur les machines de Turing, c'est-à-dire une propriété sémantique et non pas syntaxique.

Version avec des programmes

Olivier Ridoux et Gilles Lesventes[18] proposent une propriété dite « extensionnelle » (i.e., sémantique) et non triviale sur des programmes.

Théorème de Rice pour les fonctions

Le théorème de Rice peut être exprimé du point de vue des fonctions calculées par les programmes[4],[3],[19]. On suppose que l'on travaille avec un langage de programmation Turing-complet. Soit la fonction calculée par le programme p. est donc le résultat de l'évaluation du programme p sur l'entrée . Si le programme p ne se termine pas sur l'entrée , n'est pas défini. Comme il existe des programme qui ne se terminent pas, la fonction est partielle. Notons FC l'ensemble de toutes les fonctions calculables partielles de dans . Soit F FC. Notons PF l'ensemble {p | F}, c'est-à-dire l'ensemble des programmes p tels que la fonction soit dans F. Le théorème de Rice dit que PF est récursif si et seulement si F=∅ ou F=FC.

Théorème de Rice pour les ensembles

Le théorème de Rice pour les fonctions calculables peut également être exprimé[20] du point de vue des ensembles récursivement énumérables. Notons RE la classe de tous les sous-ensembles de récursivement énumérables. Soit E RE. Notons P l'ensemble des programmes p qui décident un ensemble A E (i.e. y A ssi l'exécution de p se termine sur l'entrée y). Le théorème de Rice dit que P est récursif si et seulement si E = ∅ ou E=RE.

Le théorème de Rice ci-dessus exprime l'indécidabilité de propriétés portant sur les ensembles récursivement énumérables. Il est cependant possible de caractériser parmi de telles propriétés celles qui sont semi-décidables. Une propriété Prop sur les ensembles récursivement énumérables est dite monotone si, pour tous ensembles récursivement énumérables A et B tels que A B, on a Prop(A) Prop(B). Par exemple, « A est un ensemble fini » n'est pas monotone, alors que « A contient l'élément x » l'est. Soit Prop une propriété sur les ensembles récursivement énumérables et EProp RE la classe des ensembles récursivement énumérables qui satisfont Prop. Notons PA l'ensemble des programmes p qui décident un ensemble A E (i.e. y A ssi l'exécution de p se termine sur l'entrée y). Cette variante du théorème de Rice[19][7][20] dit que si PEProp est récursivement énumérable, alors Prop est monotone.

Démonstration du théorème de Rice

Démonstration pour les ensembles

On[réf. nécessaire] montre que la décision du problème de l'arrêt peut se réduire à la décision de toute propriété non triviale sur un ensemble récursivement énumérable. On représente tout ensemble récursivement énumérable par une machine de Turing qui l'accepte. Soit P une propriété décidable et non triviale sur les ensembles récursivement énumérables. Soit P(∅)= « Faux » (si ce n'est pas le cas, on raisonne pareillement avec la négation de P). Donc, il existe un ensemble récursivement énumérable A qui satisfait P. Soit K une machine de Turing qui accepte A. P étant décidable, il existe donc une machine de Turing MP qui, pour toute représentation d'une machine de Turing, décide si l'ensemble récursivement énumérable accepté par cette machine satisfait P ou non.

Dès lors, on construit une machine de Turing H prenant en entrée la représentation d'une machine de Turing M suivie d'une entrée x. L'algorithme de H est le suivant :

1. Construire la représentation d'une machine de Turing T qui, sur une entrée d :
  • Simule l'exécution de M sur x
  • Simule l'exécution de K sur d et renvoie le résultat.
2. Simuler l'exécution de MP sur la représentation de T et renvoyer le résultat.

Si M s'arrête sur x, l'ensemble accepté par T est A. Cet ensemble satisfaisant P, la seconde phase de l'algorithme renverra « Vrai ». Si M ne s'arrête pas sur x, l'ensemble accepté par T est ∅. Cet ensemble ne satisfaisant pas P, la seconde phase de l'algorithme renverra « Faux ».

La machine H calcule donc de manière totale le problème de l'arrêt. Celui-ci étant indécidable, par contradiction, P est donc indécidable.

Une démonstration similaire peut être réalisée pour démontrer le théorème de Rice pour les fonctions.

Démonstration pour les fonctions (par le théorème du point fixe de Kleene)

Le théorème de Rice pour les fonctions peut se démontrer[5],[9] par le théorème du point fixe de Kleene. Le théorème du point fixe de Kleene dit que pour tout transformateur de programme T qui est une fonction totale, il existe un programme p tel que les programmes p et T(p) calculent la même fonction ().

Soit une propriété non triviale ( et FC). Supposons par l'absurde que P = {p | F} est récursif.

Comme F est non triviale, il existe f et g . Les fonctions f et g étant calculables, il existe deux programmes p et q avec = f et = g. Définissons le transformateur de programmes T :

T(x) = q si x P

T(x) = p si x P

Comme P est récursif, T est une fonction totale calculable. Par le théorème du point fixe de Kleene, il existe un programme n tel que . Procédons maintenant par étude de cas sur la valeur de T(n) :

  • Si T(n)=p, par définition de T, on a n P. Comme , T(n) P. Or T(n)=p P. Contradiction.
  • Si T(n)=q, alors n P. Comme , T(n) P. Or T(n)=q P. Contradiction.

Démonstration pour les ensembles (variante du théorème)

De manière analogue à la démonstration du théorème de Rice pour les ensembles, on montre[19],[7] que la semi décision de la négation du problème de l'arrêt peut se réduire à la semi-décision de toute propriété non-monotone sur les ensembles récursivement énumérables.

Soit P une propriété non-monotone et semi-décidable. Il existe donc deux ensembles récursivement énumérables A et B, calculés respectivement par des machines de Turing MA et MB tels que :

  • A est inclus dans B
  • A satisfait P
  • B ne satisfait pas P.

De plus, il existe une machine de Turing MP qui, pour toute représentation d'une machine de Turing, s'arrête et accepte si l'ensemble récursivement énumérable accepté par cette machine satisfait P.

Dès lors, on peut construire une machine de Turing H prenant en entrée la représentation d'une machine de Turing M suivie d'une entrée x dont l'algorithme est le suivant :

1 Construire la représentation d'une machine de Turing T qui, sur une entrée y :
1 Exécute en parallèle
  • MA sur y
  • MB sur y
  • M sur x
2 Accepte y si
  • MA accepte y ou bien
  • MB accepte y ET M s'arrête sur x
2 Exécuter MP sur la représentation de T et renvoyer le résultat.

Par « exécuter en parallèle », on entend que la machine T exécute un pas MA sur y, puis un pas de MB sur y, puis un pas de M sur x, puis un second pas de MA sur y, et ainsi de suite. Autrement dit, on «entrelace» les pas de calcul d'une machine avec ceux de l'autre machine.

Si M s'arrête sur x, T accepte y si, et seulement si MA ou MB accepte y, et comme A est inclus dans B, cela revient à dire si et seulement si y appartient à B. Donc, T accepte exactement l'ensemble B, qui, par hypothèse, ne vérifie pas P. Par conséquent, MP n'accepte pas T. (P étant supposé semi-décidable, MP peut même ne pas s'arrêter du tout) Si M ne s'arrête pas sur x, T accepte y si et seulement si y appartient à A. T accepte donc exactement l'ensemble A qui, par hypothèse, satisfait P. Par conséquent, MP accepte T (et finit donc par s'arrêter, par définition de la semi-décidabilité). La machine H calcule donc la négation du problème de l'arrêt. Celui-ci n'étant pas semi-décidable, par contradiction, P ne peut donc pas être semi-décidable.

Notes et références

Notes

  1. Ce théorème est la reformulation « intuitive » du corollaire B de la publication originale de Henry Gordon Rice (1953).
  2. a et b Pierre Wolper, Introduction à la calculabilité, Dunod, , p. 150, Théorème 7.3
  3. a b et c Olivier Ridoux et Gilles Lesventes, Calculateurs, Calculs et Calculabilité, p. 53
  4. a et b Rogers, Hartley, Jr., 1926-2015., Theory of recursive functions and effective computability, MIT Press, (ISBN 0262680521, OCLC 15108070, lire en ligne), p. 34
  5. a et b Mandrioli, Dino., Theoretical foundations of computer science, Wiley, (ISBN 0471838349, OCLC 15162953, lire en ligne), p.174-175
  6. a et b Hopcroft, John E., 1939- et Ullman, Jeffrey D., 1942-, Introduction to automata theory, languages, and computation, Pearson/Addison Wesley, (ISBN 0321462254, OCLC 69013079, lire en ligne), p.307
  7. a b et c Machtey, Michael., An introduction to the general theory of algorithms, North-Holland, (ISBN 044400226X, OCLC 3168554, lire en ligne), p.102 et 106
  8. Pippenger, Nicholas., Theories of computability, Cambridge University Press, (ISBN 0521553806, OCLC 35593710, lire en ligne), p. 148
  9. a et b Davis, Martin, 1928- et Weyuker, Elaine J., Computability, complexity, and languages : fundamentals of theoretical computer science, Academic Press, Harcourt, Brace, (ISBN 9780122063824, OCLC 28506245, lire en ligne), p. 102-103
  10. (en) Sipser, Introduction to the Theory of Computation, p. 210 Ex. 5.22
  11. (en) Edsger Dijkstra, « The Humble Programmer », Communications of the ACM, vol. 15, no 10,‎ , p. 859-866
  12. (en) Traub, Formal Verification of Concurrent Embedded Software, p. 16
  13. (en) « Cours sur les méthodes formelles par John Rushby », sur p. 129
  14. Par exemple les fonctions normalisantes en calcul des constructions inductif, ne sont pas toutes fonctions calculables, mais couvrent toutes les fonctions utiles en mathématiques.
  15. « Cours sur le model checking par Gerard Berry au Collège de France »
  16. (en) « No Silver Bullet », IEEE Computer Magazine,‎
  17. Papadimitriou, Christos H., Computational complexity, Addison-Wesley, (ISBN 0201530821, OCLC 28421912, lire en ligne), p. 62
  18. Olivier Ridoux et Gilles Lesventes, Calculateurs, Calculs et Calculabilité, Dunod, coll. « Sciences Sup », , 204 p., p. 54
  19. a b et c Bridges, D. S. (Douglas S.), 1945-, Computability : a mathematical sketchbook, Springer-Verlag, (ISBN 0387941746, OCLC 28891770, lire en ligne), p. 78 et 85
  20. a et b Kozen, Dexter, 1951-, Automata and computability (ISBN 9783642857065, OCLC 883383306, lire en ligne), Lecture 34

Références

  • Olivier Ridoux et Gilles Lesventes, Calculateurs, calculs, calculabilité, Dunod, coll. « Sciences sup », , 204 p. (ISBN 978-2-10-051588-2), Chapitre 4
  • (en) D. Mandrioli, C. Ghezzi, Theoretical Foundations of Computer Science, John Wiley & Sons, 1987; (ISBN 0-471-83834-9), pages 174-175
  • (en) D.S. Bridges, Computability, A Mathematical Sketchbook, Springer, (ISBN 0387941746), 1994, pages 78 et 85.
  • (en) M. Machtey, P. Young Introduction to the General Theory of Algorithms, North Holland, 1978, pages 102 et 106
  • (en) Martin Davis, Ron Sigal Elaine Weyuker, Computability, Complexity, and Languages (2nd ed), Morgan Kaufmann, (ISBN 9780122063824), 1994, p. 609, page 103
  • (en) Nicholas Pippenger, Theories of computability, Cambridge University Press, (ISBN 0-521-55380-6), 1997, page 148
  • (en) John E. Hopcroft, Rajeev Motwani, Jeffrey D. Ullman , Introduction to Automata Theory, Languages, and Computation (3rd Edition), Addison-Wesley, (ISBN 0321462254), 2006, page 307