Castor affairéUn castor affairé est, en théorie de la calculabilité, une machine de Turing qui maximise son « activité opérationnelle » (comme le nombre de pas effectués ou le nombre de symboles écrits avant son arrêt) parmi toutes les machines de Turing d'une certaine classe. Celles-ci doivent satisfaire certaines spécifications et doivent s'arrêter après être lancées sur un ruban vierge. Une fonction du castor affairé, ou fonction du nombre maximal de pas, quantifie cette activité maximale pour une machine de Turing à n états ; ce type de fonction n'est pas calculable. De plus, à partir d'un certain point, cette fonction croît plus rapidement que n'importe quelle fonction calculable. Déterminer le castor affairé parmi un ensemble de machines de Turing à n états donnés est un problème insoluble algorithmiquement ; en pratique, on ne peut même pas espérer exhiber un castor affairé pour un nombre n au-delà de 10. Le concept, introduit en 1962 par le mathématicien hongrois Tibor Radó, est l'un des premiers exemples connus de fonction non calculable. NomLe terme « castor affairé » est la traduction littérale de l'expression anglaise « busy beaver », désignant familièrement une personne industrieuse et travailleuse. Le terme (et le concept) est introduit en 1962 par Tibor Radó sous le nom « busy beaver game » (« jeu du castor affairé ») dans son article de 1962 « On Non-Computable Functions » (« Sur des fonctions non calculables »)[1]. DéfinitionsMachines de Turing considéréesLe jeu du castor affairé à n états, introduit par Tibor Radó, utilise une classe de machines de Turing dont chaque membre répond aux spécifications suivantes :
La machine démarre sur une cellule quelconque d'un ruban complètement vierge (c'est-à-dire ne comportant que des 0) ; elle procède ensuite par itération de sa fonction de transition jusqu'à atteindre éventuellement l'état d'arrêt. Si la machine s'arrête, le nombre de 1 alors présents sur le ruban est appelé le score de la machine. Le jeu du castor affairé consiste à trouver, pour un nombre n donné, une machine de Turing possédant le score maximal. Celle-ci est un castor affairé à n états. Fonction du castor affairé ΣLa fonction du castor affairé Σ : N → N est définie telle que Σ(n) est le score maximal parmi toutes les machines de Turing à 2 symboles et n états répondant aux spécifications énoncées dans le paragraphe précédent, lorsqu'elles débutent sur un ruban vierge. Σ est une fonction bien définie : pour chaque n, il existe un nombre fini de machines de Turing à n états définies ainsi, à un isomorphisme près, et donc un nombre fini de temps d'exécution possibles. Le score d'une machine de Turing M étant noté σ(M), toute machine de Turing à 2 symboles et n états pour lequel σ(M) = Σ(n) est appelée un castor affairé. Pour un n donné, le castor affairé n'est pas unique : il en existe au moins deux ; si M est un castor affairé, il suffit de changer le sens de déplacement du ruban lors d'une transition vers l'état d'arrêt pour obtenir un autre castor affairé. Nombre maximal de pas SEn plus de la fonction Σ, Tibor Radó introduit la fonction du nombre maximal de pas S. Pour une machine de Turing M de l'ensemble En des machines de Turing à 2 symboles et n états définies plus haut, s(M) est le nombre de décalages de ruban que M exécute avant de s'arrêter. S(n) est alors le nombre maximal de décalages pour En : S : n ↦ max { s(M) | M ∈En }. Comme les machines de Turing considérées décalent le ruban à chaque transition (y compris dans une transition vers l'état d'arrêt), ce nombre maximal de décalages est également le nombre maximal de pas. Tibor Radó remarque que pour tout n, S(n) ≥ Σ(n), puisqu'un décalage est nécessaire pour écrire un symbole 1 sur le ruban. La fonction S croît donc au moins aussi rapidement que la fonction Σ. Les inégalités suivantes sont valides pour tout n ≥ 1 :
IncalculabilitéDans son article de 1962, Tibor Radó montre que si f : N → N est une fonction calculable, alors Σ(n) > f(n) pour tout n suffisamment grand. La fonction Σ n'est donc pas calculable ; par conséquent, la fonction S n’est pas calculable non plus[1]. Ceci implique qu'il est indécidable par un algorithme général de déterminer si une machine de Turing arbitraire est un castor affairé : un tel algorithme ne peut pas exister puisque son existence permettrait à Σ d'être calculée, ce qui est impossible[2]. Bien que Σ soit une fonction incalculable, il est possible de déterminer sa valeur pour des petites valeurs de n. On peut montrer sans problème que Σ(0) = 0, Σ(1) = 1 et Σ(2) = 4, et avec plus de difficulté que Σ(3) = 6 et Σ(4) = 13[3]. Σ(n) n'est pas connue pour n > 5, bien que des bornes inférieures soient établies. En 2016, Yedidia et Aaronson ont montré qu'une machine de Turing à 7 918 états pouvait énumérer l'ensemble des preuves déductibles dans l'axiomatique ZFC, s'arrêtant si une contradiction était trouvée[4]. Par application du second théorème d'incomplétude de Gödel, Σ(7 918) est incalculable (en n'utilisant que les axiomes de ZFC). Cette borne supérieure sur la calculabilité de Σ a par la suite été rabaissée à 1 919[5], en construisant une machine similaire pour l'axiomatique ZF. Généralisation à m symbolesIl est possible de généraliser le problème à des machines de Turing comportant n états et m symboles, conduisant aux fonctions généralisées suivantes :
Avec 2 états et 3 symboles, la machine la plus active connue s'arrête au bout de 38 pas, avec un ruban qui comporte alors 9 symboles autres que « 0 »[6],[7]. Avec 3 états et 3 symboles, la machine la plus active connue s'arrête au bout de 119 112 334 170 342 540 pas, son ruban contenant alors 374 676 383 exemplaires du même symbole. On ignore s'il s'agit du castor affairé pour cette combinaison d'états et de symboles[6],[8]. Exemples1 étatSi la machine ne contient qu'un seul état (A), le castor affairé correspond à la table de transition suivante :
À partir d'un ruban vierge, cette machine lit tout d'abord le symbole 0 : elle écrit donc le symbole 1, déplace le ruban à droite et s'arrête. On obtient donc S(1) = 1 et Σ(1) = 1. Le résultat serait identique si le ruban était déplacé à gauche plutôt qu'à droite. Si la machine restait à l'état A après le déplacement du ruban, elle recommencerait le même processus et ne s'arrêterait jamais. Dans tous les cas, la valeur de la table de transition pour le symbole 1 n'a aucune importance, une telle machine ne pouvant jamais atterrir sur une cellule contenant ce symbole. 2 étatsPour une machine à deux états (A et B), le castor affairé correspond à la table de transition suivante[6],[9],[1] :
Cette machine s'arrête au bout de 6 pas, avec 4 symboles 1 écrits sur le ruban : S(2) = 6 et Σ(2) = 4. Le tableau suivant donne le détail de ses opérations, en partant d'une bande vierge et d'un état initial A :
La colonne « Ruban » donne l'état du ruban après une opération ; le caractère qui vient d'être écrit est en gras, celui sur lequel se trouve la tête de lecture de la machine est souligné. La direction du déplacement lors de la dernière opération n'a pas d'importance, la machine s'arrêtant de toute façon. Si on inversait toutes les directions dans la table de transition (« droite » à la place de « gauche » et réciproquement), on obtiendrait également un castor affairé, la machine se comportant exactement en miroir de celle décrite ci-dessus. Cette machine, très simple, est déjà décrite par Tibor Radó dans son article initial de 1962[1]. 3 étatsPour une machine à trois états (A, B et C), le castor affairé produisant le plus de 1 correspond à la table de transition suivante[6],[10],[1] :
Cette machine s'arrête au bout de 14 pas avec 6 symboles 1 sur le ruban. Contrairement au cas à 2 états, cette machine n'est pas celle qui s'arrête au bout du plus grand nombre de pas. Il en existe une autre qui est le castor affairé produisant le plus de pas, mais qui produit moins de symboles 1[6],[11],[1] :
Cette machine s'arrête au bout de 21 pas avec 5 symboles 1 sur le ruban. On obtient donc S(3) = 21 et Σ(3) = 6, mais pour deux machines de Turing distinctes. Ces deux résultats sont décrits par Tibor Radó dès 1962[1]. 4 étatsPour une machine à quatre états, le castor affairé correspond à la table de transition suivante[6],[12] :
Cette machine s'arrête au bout de 107 pas avec 13 symboles 1 sur le ruban. Ceux-ci ne sont pas consécutifs, l'état final du ruban étant le suivant : ... 0 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 0 0 ... 5 étatsPour 5 états, le castor affairé est la machine suivante[6],[13] :
Cette machine produit 4 098 symboles 1 en 47 176 870 pas. Les symboles 1 ne sont pas consécutifs : 8 191 symboles 0 sont intercalés. Découverte en 1989, cette machine n'a été démontrée maximale qu'en 2024[14]. 6 étatsÀ partir de 6 états, les castors affairés ne sont pas connus. Pour 6 états, la machine la plus active connue est la suivante, découverte en 2022 par Pavel Kropitz[15] :
Cette machine s'arrête après plus de étapes où est la notation des flèches de Knuth. Autrement dit, le nombre d'étapes qu'elle effectue avant de s'arrêter est avec 15 itérations de puissance de 10. Le précédent record était de 7,412 × 1036 534 étapes[16]. Pour avoir une idée d’à quel point ce précédent record est surpassé par le record actuel, il suffit de se dire que le nombre de chiffres nécessaire pour écrire 7,412 × 1036 534 en base décimale est 36 535, tandis que celui nécessaire pour écrire est ; or, rien que vaut déjà = . Ce nouveau record a également surclassé les records précédemment connus pour 7, 8 et 9 états ; par conséquent, pour ces nombres d’états, les machines les plus actives actuellement connues sont de légères variations de la machine à 6 états ci-dessus, comme expliqué dans l'article de Scott Aaronson[17]. Valeurs connuesLes valeurs de Σ(n) et S(n) ne sont connues que pour n < 6. Pour toutes les autres ne sont connues, au mieux, que des bornes inférieures. En 1964, Milton Green construit un ensemble de machines de Turing qui montre que pour k ≥ 2 : où est la notation des flèches de Knuth et A est la fonction d'Ackermann[18]. Ainsi : (où le dernier terme est une tour de 327 = 7 625 597 484 987 exposants), et : où g1 est l'énorme valeur de départ de la suite qui définit le nombre de Graham. Les tableaux suivants recensent les valeurs exactes et les bornes inférieures connues de S(n, m) et Σ(n, m) pour n et m ≤ 6[19],[6]. Les entrées « ? » sont plus grandes que toutes celles à gauche ou au-dessus d’elles ; soit aucun résultat de recherche n’a été publié à leur sujet, soit des résultats publiés ont été rendus obsolètes par de meilleurs résultats obtenus pour des valeurs plus petites de n et m.
Références
Voir aussiBibliographie
Articles connexesLiens externes
|