Automate séquentielEn informatique théorique, et notamment en théorie des automates, un automate séquentiel est un automate fini déterministe avec sorties. C'est un cas particulier d'un transducteur fini, où l'automate des entrées est déterministe. Une sous-famille des automates séquentiels est celle des automates séquentiels dits purs, où certaines modalités de calcul sont simplifiées. Lorsque de plus les sorties sont des lettres, un automate séquentiel est un automate de Mealy. Les transductions rationnelles réalisées par les automates séquentiels sont des fonctions (partielles) appelées fonctions séquentielles. Définition informelleLes automates séquentiels sont des automates finis déterministes qui produisent un mot de sortie. Un tel automate peut réaliser certaines transformations comme l’addition des entiers dans une certaine représentation, la multiplication par une constante ou divers codages et décodages. Dans un automate séquentiel, comme dans une transducteur fini, les transitions sont étiquetées par des couples formés d’une lettre d'entrée et d’un mot de sortie. De plus l’état initial est étiqueté par un mot appelé le « préfixe initial » et chaque état porte de plus un mot qui est la valeur d'une « fonction terminale ». Le mot de sortie calculé pour un mot d’entrée s’obtient en lisant l’entrée depuis l’état initial et en produisant les sorties spécifiées par les transitions ; le mot formé par ces sorties est préfixé par le préfixe initial et suffixé par le mot donné pour l’état final atteint. Si la fonction terminale n'est pas définie pour cet état, aucune sortie n'est produite. Lorsque le préfixe initial et la fonction terminale sont triviales, l'automate est un automate séquentiel pur. La fonction réalisée par un automate séquentiel est une fonction séquentielle. C'est un cas particulier de transduction rationnelle fonctionnelle. Lorsque l'automate sous-jacent est pur, la fonction réalisée est elle-même dite pure. Un automate séquentiel pur est un transducteur fini particulier : l’automate d'entrée sous-jacent est déterministe (mais pas nécessairement complet). ExempleVoici un exemple[1] pour éclairer le concept : Cet automate a deux états ; l'état initial 1 a pour préfixe initial 11 ; la fonction terminale associe à l'état 1 le mot vide et à l'état 2 le mot 00. L'automate est déterministe et incomplet. La lecture du mot fait passer l'automate progressivement par les états 1,2,2,1 et produit les sorties : ; préfixée de 11, concaténées et suivies de 00, on obtient 110100100. La fonction réalisée par cet automate prend donc, pour le d'entrée , la valeur 110100100. DéfinitionOn définit d'abord un automate séquentiel pur[1] : un automate séquentiel pur est un tuple où
Les fonctions de transition et de sortie ont le même domaine de définition . On note l'absence de définition explicite d'états terminaux : un état est terminal s'il appartient au domaine de définition de la fonction de sortie Un automate séquentiel est un tuple où est un automate séquentiel pur, m∈B∗ est le préfixe initial et est une fonction (partielle), appelée la fonction terminale. La fonction de transition s’étend à en posant et, si et sont définies,
La fonction de sortie s’étend à en posant et, si et sont définies,
Cette dernière formule exprime simplement que, lors d'un cheminement dans l'automate, les sorties des transitions sont concaténées à la suite. La fonction réalisée par un automate séquentiel pur est l'application (partielle) définie sur un mot si est définie, et qui prend la valeur
définie sur un mot si est définie, et qui prend la valeur
La valeur est donc le mot obtenu en concaténant le préfixe initial avec le mot produit dans l'automate pur, suivi de la valeur que prend la fonction terminale sur l'état d'arrivée (si cet état est atteint et si la fonction terminale est définie sur cet état). La fonction réalisée par un automate séquentiel pur est appelée une fonction séquentielle pure. De même, la fonction réalisée par un automate séquentiel est appelée une fonction séquentielle. ExemplesExemples de fonctions séquentielles pures
Tout morphisme peut être réalisé par un automate séquentiel pur à un seul état
Par exemple, le mot ab———a—a est transformé en ab—a—a.
Un codage défini par comme tout morphisme, peut être réalisé par un automate séquentiel pur à un seul état. Le décodage est possible par un automate séquentiel pur si le code est préfixe, et plus précisément le décodage est une fonction séquentielle si et seulement si le code est à délai de déchiffrage fini[2]. Ici, l'ensemble est bien un code préfixe et un automate séquentiel pur de décodage existe, donné sur la figure ci-contre[1]. Pour le mot
le décodage donne Exemples de fonctions séquentielles
Une fonction qui ajoute 1 au nombre écrit en binaire retournée (bit le plus faible à gauche), par exemple
Un additionneur binaire prend en argument deux entiers naturels écrits en binaire, et produit en sortie la suite binaire qui représente la somme des deux entiers. Les nombres en arguments sont écrits comme couples de bits, donc sur l'alphabet produit , le plus court des deux nombres binaires est éventuellement complété par des 0 ; l'écriture se fait avec le bit de plus petit poids à gauche[3]. Les deux états 0 et 1 de l'automate correspondent à l'absence respectivement la présence d'une retenue. Par exemple, pour , dont l'écriture binaire est 01101 et , dont l'écriture binaire complétée par un 0 à droite est 10110, la lecture des couples (0,1)(1,0)(1,1)(0,1)(1,0) fait passer successivement par les états 0,0,0,1,1,1; les lettres émises sont 1,1,0,0,0; la fonction de sortie fournit un 1 supplémentaire correspondant à la retenue, de sorte que le mot obtenu est 110001 qui est l'écriture binaire de . Autres exemples
Caractérisations des fonctions séquentiellesLa caractérisation des fonctions séquentielles et fonctions séquentielles pures fait appel à des notions topologiques :
Théorème (Ginsburg et Rose (1966)[5]) — Une fonction est une fonction séquentielle pure si et seulement si
Théorème (Choffrut (1979)[6]) — Une fonction dont le domaine de définition est préfixiel (fermé par préfixe) est une fonction séquentielle si et seulement si
Un autre résultat caractérise des fonctions séquentielles parmi les fonctions rationnelles, c'est-à-dire les transductions rationnelles qui sont des fonctions. Pour cela, on dit qu'une fonction est uniformément bornée si, pour tout entier , il existe un entier tel que pour tous dans le domaine de définition de . Théorème[4] — Soit une fonction rationnelle. Les conditions suivantes sont équivalentes :
PropriétésLes fonctions séquentielles (pures) sont fermées par composition. En d'autres termes, le composé de deux fonctions séquentielles (pures) est encore une fonction séquentielle (pure). Il est décidable si une fonction rationnelle est séquentielle (pure). Note historiqueLe terme de sequential transducer apparaît déjà dans les travaux de Seymour Ginsburg sous le nom de « generalized sequential machine (gsm) »[7]. Un long chapitre est consacré à ces machines et fonctions dans le traité de Samuel Eilenberg. Marcel-Paul Schützenberger[8] appelle sous-séquentielle une fonction séquentielle, et séquentielle une fonction pure, et ne s'écarte ainsi pas des définitions de ses prédécesseurs. Jacques Sakarovitch[4] emploie la terminologie utilisée ici, reprise à sa suite aussi par Jean-Éric Pin[3],[2]. Notes et référencesBibliographie
Articles connexes |
Portal di Ensiklopedia Dunia