Mehrband-Turingmaschine

Aus testwiki
Zur Navigation springen Zur Suche springen

Eine Mehrband-Turingmaschine (Vorlage:EnS) ist eine abstrakte Maschine in der theoretischen Informatik und eine Erweiterung der klassischen Turingmaschine.

3-Band-Turing-Maschine

Die Mehrband-Turingmaschine verfügt über mehrere Speicherbänder, die jeweils einen eigenen Lese- und Schreibkopf besitzen, wobei diese Lese- und Schreibköpfe unabhängig voneinander bewegt werden können (ein wesentlicher Unterschied zur Mehrspuren-Turingmaschine). Ansonsten verhält sich eine Mehrband-Turingmaschine genau so wie eine klassische Turingmaschine.

Eine Mehrband-Turingmaschine mit nur einem Band entspricht genau der klassischen Turingmaschine und jede Mehrband-Turingmaschine kann durch eine klassische Turingmaschine (mit nur einem Band) simuliert werden. Die beiden Maschinenmodelle sind also bezüglich der Berechenbarkeit von Funktionen äquivalent, d. h., beide Modelle können die gleichen Funktionen berechnen.

Die Mehrband-Turingmaschine arbeitet im Allgemeinen effizienter als eine Einband-Maschine, aber nicht entscheidend im Sinne der wichtigsten Fragen der Komplexitätstheorie, d. h., vor allem für die Frage, welche Probleme in Polynomialzeit gelöst werden können: Eine Mehrband-Maschine, die ein Problem in Polynomialzeit löst, kann von einer Einband-Maschine in Polynomialzeit simuliert werden, wobei aber im Allgemeinen der Grad des die Laufzeit beschränkenden Polynoms höher ist.

Formale Definition

Formal kann eine (deterministische) k-Band-Turingmaschine als Tupel M=(Q,Σ,Γ,δ,q0,,F) dargestellt werden.

  • Q ist die endliche Zustandsmenge.
  • Σ ist das endliche Eingabealphabet.
  • Γ ist das endliche Bandalphabet und es gilt ΣΓ.
  • δ:(QF)×ΓkQ×Γk×{L,N,R}k ist die (partielle) Überführungsfunktion.
  • q0Q ist der Anfangszustand.
  • ΓΣ steht für das leere Feld (Blank).
  • FQ die Menge der Endzustände.

Die Definition unterscheidet sich von der einer klassischen Turingmaschine (oder auch einer Mehrspuren-Turingmaschine) nur in der Definition der Überführungsfunktion δ. Die Überführungsfunktion δ liefert zu einem Zustand und den k von den verschiedenen Bändern gelesenen Bandsymbolen (i) den nächsten Zustand, (ii) k Bandsymbole, die in das aktuelle Feld geschrieben werden, und (iii) die k Bewegungsrichtungen der Lese-Schreib-Köpfe (L … ein Feld nach links, N … nicht bewegen, R … ein Feld nach rechts). Im Kontrast zur klassischen Turingmaschine werden k Symbole statt nur einem Symbol gelesen und geschrieben und k Lese-Schreib-Köpfe bewegt. Der Unterschied zur Mehrspuren-Turingmaschine besteht darin, dass δ k Bewegungsrichtungen festlegt (eine für jeden Lese-Schreib-Kopf), während δ bei Mehrspuren-Turingmaschinen nur eine Bewegungsrichtung für den Lese-Schreib-Kopf festlegt, der sich auf allen Spuren gleich bewegt.

Um eine nichtdeterministische Variante der k-Band-Turingmaschine zu definieren, ersetzt man die Überführungsfunktion durch eine Übergangsrelation δ:

  • δ(QF)×Γk×Q×Γk×{L,N,R}k

Beispiel

Das folgende Beispiel ist eine 3-Band-Turingmaschine, die zwei Binärzahlen addiert. Dabei sind zu Beginn die zwei gegebenen Zahlen auf den ersten beiden Bändern gespeichert und die Ausgabe wird am dritten Band gespeichert. M=({q0,q1,q2,qf},{0,1},{0,1,b},δ,q0,b,{qf})

Die Überführungsfunktion δ wird schrittweise definiert. Im Zustand q0 bewegt die Maschine die Lese-Schreib-Köpfe der ersten beiden Bänder an das rechte Ende der Eingabe. Wenn die Maschine den Zustand q0 verlassen hat, stehen die Lese-Schreib-Köpfe auf der jeweils letzten Ziffer der Eingabe.

aktueller
Zustand
geles.
Symbol
  schr.
Symbol
neuer
Zustand
Kopf-
richtungen
q0 b 0 b b 0 b q0 N R N
q0 b 1 b b 1 b q0 N R N
q0 0 b b 0 b b q0 R N N
q0 0 0 b 0 0 b q0 R R N
q0 0 1 b 0 1 b q0 R R N
q0 1 b b 1 b b q0 R N N
q0 1 0 b 1 0 b q0 R R N
q0 1 1 b 1 1 b q0 R R N
q0 b b b b b b q1 L L N

Für die eigentliche Addition werden die zwei Zustände q1 und q2 verwendet. Hier entspricht q1 der Addition an der aktuellen Stelle ohne Übertragsbit aus dem vorherigen Schritt und q2 der Addition mit einem Übertragsbit aus dem letzten Schritt. Wir definieren schließlich noch δ für q1 und q2.

aktueller
Zustand
geles.
Symbol
  schr.
Symbol
neuer
Zustand
Kopf-
richtungen
q1 b 0 b b 0 0 q1 N L L
q1 b 1 b b 1 1 q1 N L L
q1 0 b b 0 b 0 q1 L N L
q1 0 0 b 0 0 0 q1 L L L
q1 0 1 b 0 1 1 q1 L L L
q1 1 b b 1 b 1 q1 L N L
q1 1 0 b 1 0 1 q1 L L L
q1 1 1 b 1 1 0 q2 L L L
q1 b b b b b b qf R R R
aktueller
Zustand
geles.
Symbol
  schr.
Symbol
neuer
Zustand
Kopf-
richtungen
q2 b 0 b b 0 1 q1 N L L
q2 b 1 b b 1 0 q2 N L L
q2 0 b b 0 b 1 q1 L N L
q2 0 0 b 0 0 1 q1 L L L
q2 0 1 b 0 1 0 q2 L L L
q2 1 b b 1 b 0 q2 L N L
q2 1 0 b 1 0 0 q2 L L L
q2 1 1 b 1 1 1 q2 L L L
q2 b b b b b 1 qf R R N

Wir betrachten als Beispiel die Addition von 11 und 1010.

Schritt Zust. Bänder
1 q0 b11b
b1010b
bbbbb
2 q0 b11b
b1010b
bbbbb
3 q0 b11b
b1010b
bbbbb
4 q0 b11b
b1010b
bbbbb
5 q0 b11b
b1010b
bbbbb
6 q1 b11b
b1010b
bbbbb
Schritt Zust. Bänder
7 q1 b11b
b1010b
bbbb1
8 q2 b11b
b1010b
bbb01b
9 q1 b11b
b1010b
bb101b
10 q1 b11b
b1010b
b1101b
hält qf b11b
b1010b
b1101b

Literatur