Transitionssystem

Ein Transitionssystem (englisch transition system) beschreibt in der Automatentheorie die möglichen Zustände eines zustandsbasierten Systems und die möglichen Übergänge (Transitionen) zwischen diesen Zuständen.

Man unterscheidet dabei diskrete und kontinuierliche Systeme. In der Regel betrachtet man nur diskrete Systeme, da diese wesentlich leichter überprüft werden können.

Ferner unterscheidet man deterministische und nichtdeterministische Transitionssysteme. Im ersten Fall wird einem Zustand und einer Transition höchstens ein Folgezustand zugeordnet, während im nichtdeterministischen Fall derselbe Zustand zu einer Transition mehrere Nachfolgezustände besitzen kann. Deterministische Transitionssysteme sind in diesem Sinne Spezialfälle von nichtdeterministischen Transitionssystemen.

Ein Transitionssystem kann verwendet werden, um bestimmte Eigenschaften eines zustandsbasierten Systems zu zeigen, insbesondere die Terminiertheit. Aus diesem Grund wird es zur Verifikation der Korrektheit von Algorithmen eingesetzt. Auch zum Beweis der Verklemmungsfreiheit von verteilten Systemen kann dieses Konstrukt angewendet werden.

Formale Definition

Formal wird ein diskretes Transitionssystem beschrieben durch ein Quadrupel T S = ( S , S 0 , A , T ) {\displaystyle TS=(S,S_{0},A,T)} , wobei

  • S {\displaystyle S} ist eine Menge von Zuständen.
  • S 0 S {\displaystyle S_{0}\subseteq S} ist eine nichtleere Menge von Startzuständen.
  • A {\displaystyle A} ist ein endliches Alphabet, wobei S A = {\displaystyle S\cap A=\emptyset } . Die Elemente von A heißen Markierungen (engl. label) von TS.
  • T S × A × S {\displaystyle T\subseteq S\times A\times S} ist die Transitionsrelation von T S {\displaystyle TS} , die für jeden Zustand und jedes Eingabezeichen bestimmt, welche Nachfolgezustände existieren.

Das Transitionssystem entspricht also einem endlichen Automaten, nur dass die Zustandsmenge nicht endlich sein muss und die Transitionsrelation daher beliebig komplex sein kann. Schon diese scheinbar kleinen Erweiterungen führen dazu, dass Transitionssysteme im Allgemeinen turingmächtig sind.

Ein Transitionssystem heißt deterministisch, wenn die folgenden beiden Bedingungen erfüllt sind:

  • S 0 {\displaystyle S_{0}} enthält genau ein Element.
  • Wenn ( z 0 , a , z 1 ) T {\displaystyle (z_{0},a,z_{1})\in T} , dann folgt für alle ( w 0 , b , w 1 ) T {\displaystyle (w_{0},b,w_{1})\in T} mit w 0 = z 0 {\displaystyle w_{0}=z_{0}} und b = a {\displaystyle b=a} auch w 1 = z 1 {\displaystyle w_{1}=z_{1}} .

In jedem Zustand ist also für jedes Eingabezeichen eindeutig festgelegt, was der nächste Zustand sein muss.

Eigenschaften

Ein Transitionssystem heißt endlich, falls die Menge der Zustände S {\displaystyle S} endlich ist. Ein endliches Transitionssystem ist ein endlicher Automat. Solche Transitionssysteme können als Transitionsdiagramm dargestellt werden: Es bildet im Allgemeinen einen gerichteten zyklischen Graphen mit benannten Kanten.

Mit (zumeist) endlichen Graphen beschäftigt sich ein ganzer Zweig der Theoretischen Informatik, die sogenannte Modellprüfung (model checking). Ziel ist es, das in einer Sprache (zum Beispiel Guarded Commands, Petri-Netze) definierte Transitionssystem automatisch daraufhin zu überprüfen, ob es eine Spezifikation erfüllt, die ebenfalls in einer geeigneten Sprache (meist einer Temporalen Logik, wie LTL, CTL oder CTL*) gegeben ist.

Beispiele

Ampel

Eine Ampel lässt sich als Transitionssystem verstehen. Eine Ampel besitzt die fünf Zustände { r o t , r o t g e l b , g r u e n , g e l b , a u s } {\displaystyle \{rot,rot-gelb,gruen,gelb,aus\}} . Im Normalbetrieb wechselt die Ampel ihre Zustände in folgender Reihenfolge: r o t   a   r o t g e l b   a   g r u e n   a   g e l b   a   r o t {\displaystyle rot\ {\overrightarrow {a}}\ rot-gelb\ {\overrightarrow {a}}\ gruen\ {\overrightarrow {a}}\ gelb\ {\overrightarrow {a}}\ rot} . Außerdem besitzt eine Ampel einen Nachtbetrieb: g e l b   b   a u s   b   g e l b {\displaystyle gelb\ {\overrightarrow {b}}\ aus\ {\overrightarrow {b}}\ gelb} . Die Beschreibung dieser beiden Zyklen als Zustandsänderung nennt man Transitionssystem.

Deterministischer endlicher Automat

Beispiel eines deterministischen endlichen Automaten

Der oben abgebildete Graph ist ein DEA mit den drei Zuständen S 0 {\displaystyle S_{0}} , S 1 {\displaystyle S_{1}} und S 2 {\displaystyle S_{2}} . Der Zustand S 1 {\displaystyle S_{1}} ist ein Endzustand. Das Alphabet besteht aus den beiden Buchstaben a {\displaystyle a} und b {\displaystyle b} . Andere Buchstaben akzeptiert der Automat nicht. Der reguläre Ausdruck a b ( a + b | b + a ) {\displaystyle a^{*}b(a^{+}b|b^{+}a)^{*}} entspricht der Sprache, die dieser DEA akzeptiert.

Literatur

  • John E. Hopcroft, Jeffrey Ullman: Einführung in die Automatentheorie, formale Sprachen und Komplexitätstheorie. 2. Auflage. Addison-Wesley, Bonn / München 1990, ISBN 3-89319-181-X (englisch, Originaltitel: Introduction to automata theory, languages and computation.). 
  • Peter Sander, Wolffried Stucky, Rudolf Herschel: Automaten, Sprachen, Berechenbarkeit, ISBN 3-519-02937-5
Normdaten (Sachbegriff): GND: 4329099-1 (lobid, OGND, AKS)