Automate temporisé

De testwiki
Version datée du 6 février 2023 à 15:23 par imported>Omar Farouk Sani (Extensions : Correction d'erreur de frappe)
(diff) ← Version précédente | Version actuelle (diff) | Version suivante → (diff)
Aller à la navigation Aller à la recherche

En théorie des automates, un automate temporisé est un automate fini doté d'un ensemble fini d'horloges à valeurs réelles. Au cours d'un calcul de l'automate, les valeurs des horloges augmentent toutes à la même vitesse. Dans les transitions de l'automate, les valeurs d'horloges sont comparées à des entiers. Ces comparaisons constituent des gardes qui activent ou inhibent les transitions et imposent ainsi des contraintes aux comportements de l'automate. Les horloges peuvent être réinitialisées. Les automates temporisés ont été introduits par Alur et Dill en 1994[1]. Les auteurs ont reçu, pour cet article, le prix Alonzo Church 2016 de l'European Association for Theoretical Computer Science.

Les automates temporisées peuvent être utilisés pour modéliser et analyser le comportement temporel de systèmes informatiques, par exemple, des systèmes ou des réseaux opérant en temps réel. Des méthodes pour vérifier les propriétés de sûreté et de vivacité ont été développées et étudiées depuis l'introduction des automates temporisées en 1994.

Un automate temporisé accepte des mots temporisés — des suites infinies où une valeur réelle de moment d'occurrence est associé à chaque symbole.

Description

Un automate temporisé possède un nombre fini de places ou états. Les transitions entre états sont instantanées. Dans chaque place, le temps peut s’écouler: à tout instant, la valeur d’une horloge x est le temps écoulé depuis la dernière mise à zéro de x. Les transitions entre états sont conditionnées par des contraintes sur les horloges, appelés gardes, et peuvent remettre certaines horloges à zéro. À chaque place est associée une contrainte sur les horloges, appelée invariant[2].

Un exemple

Un automate temporisé[3]Modèle:,[2] à deux états.

L'automate temporisé ci-contre est composé de deux états s et t. L'état sest l'état initial. Il y a deux transitions étiquetées respectivement par les lettres d'entrée a et b. L'automate a aussi deux horloges x et y. L'invariant de l'état s indique que l'horloge y peut valoir au plus 5. Quand elle est au moins égale à 3, la transition vers l'état t peut être effectuée. Cette transition entraîne que la réinitialisation de l’horloge y, i.e. l'horloge y est remise à zéro.

L'invariant de l'état t porte sur les deux horloges : x doit être au plus 8 et y au plus 10. La transition vers l'état s est possible quand xest plus grand que 6 et y plus grand que 4, et entraîne que la réinitialisation de 'horloge x à zéro.

Une trajectoire est une exécution de l'automate. Un automate peut rester dans un état tant que son invariant est satisfait. Il doit quitter l'état avant que l’invariant soit invalide. Pour franchir une transition, il faut que sa garde soit vraie et que l'invariant de l’état d'arrivée soit valide. Voici un exemple d'exécution, où on a séparé la progression du temps dans un état du franchissement de la transition :

(s,0,0)3(s,3,3)a(t,3,0)4(t,7,4)b(s,0,4)1(s,1,5)
Dans cette exécution, la première coordonnée est l'état dans lequel se trouve l'automate temporisée, la deuxième coordonnée est la valeur de l'horloge xet la troisième coordonnée, celle de l'horloge y.

On voit aussi l'écriture plus ramassée

(s,0,0)3a(t,3,0)4b(s,0,4)1(s,1,5)

Voici une autre trajectoire

(s,0,0)5a(t,5,0)3(t,8,3).

Ici, l'exécution est bloquée parce que, d'une part l'horloge x a atteint 8, qui est la valeur maximale autorisée par l'invariant de l'état t, et d'autre part la garde de la transition de t vers s, qui demande y4, n'est pas vérifiée puisque y vaut 3[3].

Définition formelle

Formellement, un automate temporisé 𝒜=(Q,Σ,C,E,q0,F) est composé des éléments suivants :

  • Q : un ensemble fini, dont les éléments sont appelés les états, les nœuds ou les places ;
  • Σ : un ensemble fini appelé l'alphabet ou ensemble dModèle:'actions ;
  • C : un ensemble fini, aussi noté X, dont les éléments sont appelés les horloges ;
  • EQ×Σ×𝔹(C)×𝔓()×Q : un ensemble de transitions ; ici :
    • 𝔹(C) est l'ensemble des contraintes booléennes des horloges de C,
    • 𝔓(C) est l'ensemble des parties C ;
  • q0 : un élément de Q appelé l'état initial. On autorise parfois un ensemble d'états initiaux Q0Q ;
  • F : une partie de Q dont les éléments sont appelés les états finals[N 1].

Un élément (q,a,g,r,q) de E est une transition de l'état q à l'état q avec l'action a, la garde g et les horloges de r réinitialisées.

Une horloge est une variable à valeurs réelles positives ou nulles. Une contrainte d'horloge est de l'une des formes x<c,xc, x>c ou xc, où x est une horloge et c est une constante rationnelle. Un ensemble de contraintes est une conjonction d'un ensemble fini de contraintes.

Propriétés

On peut définir des classes d'automates temporisés déterministe ou non déterministes, et comparer les conditions d'acceptation de Büchi ou de Muller. Les langages acceptés par des automates temporisés non déterministes sont fermés pour l'union et l'intersection, mais pas par complémentation ; au contraire, les langages acceptés par des automates temporisés de Muller sont fermés pour toutes les opérations booléennes. Il existe un algorithme de complexité pour tester si le langage d'un automate temporisé non déterministe est vide, en espace polynomial. D'ailleurs, ce problème est PSPACE-complet[1]. Le problème de l'accessibilité est décidable pour les automates temporisés[1]. Des extensions ont été largement étudiées.

Le problème d'universalité (savoir si tous les mots sont acceptés par un automate temporisé non-déterministe) est indécidable. Il est décidable lorsqu'il n'y a qu'une seule horloge, bien que non primitif récursif[4].

Implémentation

Il existe une variété de outils de recherche pour la saisie et l'analyse d'automates temporisés et de leurs extensions, parmi lesquels les model checkers  UPPAAL, Kronos, et l'analyseur d'ordonnancement TIMES.

Extensions

Les automates temporisées ont été étendues avec des coûts[5]. On indique dans chaque état, le coût de rester dans cet état par unité de temps ; et pour chaque transition, on indique le coût de prendre cette transition. Ainsi, on peut associer un coût global à une exécution en sommant les coûts des délais dans chaque état et les coûts des transitions prises.

Notes et références

Notes

Modèle:Références

Références

Modèle:Références

Bibliographie

Articles
Cours

Articles liés

Modèle:Palette Modèle:Portail


Erreur de référence : Des balises <ref> existent pour un groupe nommé « N », mais aucune balise <references group="N"/> correspondante n’a été trouvée