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 , wobei
- ist eine Menge von Zuständen.
- ist eine nichtleere Menge von Startzuständen.
- ist ein endliches Alphabet, wobei . Die Elemente von A heißen Markierungen (engl. label) von TS.
- ist die Transitionsrelation von , 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:
- enthält genau ein Element.
- Wenn , dann folgt für alle mit und auch .
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 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 . Im Normalbetrieb wechselt die Ampel ihre Zustände in folgender Reihenfolge: . Außerdem besitzt eine Ampel einen Nachtbetrieb:. Die Beschreibung dieser beiden Zyklen als Zustandsänderung nennt man Transitionssystem.
Deterministischer endlicher Automat
Der oben abgebildete Graph ist ein DEA mit den drei Zuständen , und . Der Zustand ist ein Endzustand. Das Alphabet besteht aus den beiden Buchstaben und . Andere Buchstaben akzeptiert der Automat nicht. Der reguläre Ausdruck 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 (Originaltitel: Introduction to automata theory, languages and computation.).
- Peter Sander, Wolffried Stucky, Rudolf Herschel: Automaten, Sprachen, Berechenbarkeit, ISBN 3-519-02937-5