Orakel-Turingmaschine

Eine Orakel-Turingmaschine ist eine Turingmaschine, die mit einem Orakel verbunden ist. Bildhaft kann man sich ein Orakel als eine Black-Box vorstellen, die von der Turingmaschine befragt werden kann und ein Problem in einem Schritt löst. Der Begriff der Orakel-Turingmaschine dient in der Theoretischen Informatik dazu, Hierarchien von Berechenbarkeiten und Komplexitäten zu definieren und deren Eigenschaften zu studieren.

Durch geeignete Orakel kann man die Berechenbarkeit verstärken oder die Komplexität verringern. Zum Beispiel können Turingmaschinen mit dem Halteproblem als Orakel das Halteproblem für Turingmaschinen lösen. Turingmaschinen mit SAT als Orakel können jedes Problem aus NP in polynomialer Zeit lösen. Orakel werden auch verwendet, um Nichtdeterminismus deterministisch zu modellieren. Eine nichtdeterministische Turingmaschine kann nämlich als Schar von deterministischen Orakel-Turingmaschinen wiedergegeben werden. Der Scharparameter, das Orakel, drückt dabei die Folge der nichtdeterministischen Entscheidungen aus (vergleiche Pfad (Stochastik)).

Definition

Sei A Σ {\displaystyle A\subseteq \Sigma ^{*}} eine Sprache über dem Alphabet Σ {\displaystyle \Sigma } . Eine Orakel-Turingmaschine mit Orakel A {\displaystyle A} ist eine Turingmaschine M {\displaystyle M} mit einem zusätzlichen Eingabeband, dem Orakelband, und drei ausgezeichneten Zuständen: q j ,   q n ,   q ? {\displaystyle q_{j},~q_{n},~q_{?}} . Schreibt M {\displaystyle M} ein Wort w Σ {\displaystyle w\in \Sigma ^{*}} auf das Orakelband und geht in den Zustand q ? {\displaystyle q_{?}} über, so befragt M {\displaystyle M} das Orakel: Der Nachfolgezustand von q ? {\displaystyle q_{?}} sei q j {\displaystyle q_{j}} falls w A {\displaystyle w\in A} gilt und andernfalls q n {\displaystyle q_{n}} . Anschließend wird das Orakelband gelöscht.

Wenn T {\displaystyle T} und K {\displaystyle K} Klassen von Sprachen sind, dann bezeichnet T K {\displaystyle T^{K}} die Klasse der Sprachen, die von Turingmaschine M {\displaystyle M} mit Orakel A {\displaystyle A} akzeptiert werden, wobei L ( M ) T {\displaystyle L(M)\in T} und A K {\displaystyle A\in K} sind. Typische Klassen sind einelementige Klassen, Komplexitätsklassen wie P oder NP, oder auch die Klasse aller rekursiv aufzählbaren Sprachen.

Beispiele:

  • P S A T {\displaystyle P^{SAT}} bezeichnet die Klasse der Sprachen, die von einer deterministischen, polynomiell zeitbeschränkten Turingmaschine mit Orakel S A T {\displaystyle SAT} akzeptiert werden.
  • N P N P {\displaystyle NP^{NP}} bezeichnet die Klasse der Sprachen, die von einer nichtdeterministischen, polynomiell zeitbeschränkten Turingmaschine mit Orakel aus der Klasse N P {\displaystyle NP} akzeptiert werden.

Diese Komplexitätsklassen werden unter anderem dazu genutzt, um die Polynomialzeithierarchie zu definieren.

Eigenschaften

  • Für zwei Komplexitätsklassen T {\displaystyle T} , K {\displaystyle K} und eine Sprache L K {\displaystyle L\in K} gilt T K = T L {\displaystyle T^{K}=T^{L}} , falls folgende Bedingungen erfüllt sind:
    1. L {\displaystyle L} ist K {\displaystyle K} -vollständig bezüglich einer Reduktion {\displaystyle \preceq }
    2. Die T {\displaystyle T} zugrundeliegende Klasse von Turingmaschinen ist mächtig genug, die Reduktion {\displaystyle \preceq } zu berechnen

     Beispielsweise gilt P N P = P S A T {\displaystyle P^{NP}=P^{SAT}} , da S A T {\displaystyle SAT} N P {\displaystyle NP} -vollständig bezüglich Polynomialzeitreduktion ist.

  • Jede Orakel-Turingmaschine hat mindestens die Fähigkeiten seiner Turingmaschine, seines Orakels und der Komplementsprache seines Orakels. Es gilt daher T T K {\displaystyle T\subseteq T^{K}} , K T K {\displaystyle K\subseteq T^{K}} und c o K T K {\displaystyle coK\subseteq T^{K}} für alle Klassen T {\displaystyle T} und K {\displaystyle K} . Letztere Eigenschaft ergibt sich, wenn man die Zustände q j {\displaystyle q_{j}} und q n {\displaystyle q_{n}} vertauscht interpretiert. Insbesondere gilt also T K = T c o K {\displaystyle T^{K}=T^{coK}}
  • Es gilt P P = P {\displaystyle P^{P}=P} und N P P = N P {\displaystyle NP^{P}=NP} , da die Turingmaschine anstatt das Orakel zu befragen, sich die Antwort des Orakels selber berechnen kann. Die Aussage lässt sich nicht auf nichtdeterministische Komplexitätsklassen verallgemeinern. Grund dafür ist die notwendige Eigenschaft K = c o K {\displaystyle K=coK} der Orakelklasse K {\displaystyle K} . Beispielsweise würde aus N P N P = N P {\displaystyle NP^{NP}=NP} die bislang ungeklärte Beziehung c o N P = N P {\displaystyle coNP=NP} folgen ( S A T ¯ N P ) {\displaystyle ({\overline {SAT}}\in NP)} .

Zum Halteproblem

Man beachte, dass das Orakel in keiner Weise beschränkt ist. Auch Sprachen, die nicht entscheidbar sind, kommen als Orakel in Frage. Also kann man zum Beispiel das Halteproblem als Orakel verwenden. Solche Halteorakel-Turingmaschinen können offensichtlich das Halteproblem von Turingmaschinen (ohne Orakel) lösen. Das steht natürlich nicht im Widerspruch zum Unentscheidbarkeitresultat des Halteproblems, denn dieses besagt ja nur, dass es keine Turingmaschine ohne Orakel gibt, die das Problem löst. Allerdings ist auch das Halteproblem von Halteorakel-Turingmaschinen nicht durch Halteorakel-Turingmaschinen lösbar.

Die Konstruktion von immer stärkeren Orakel-Turingmaschinen führt zur arithmetischen Hierarchie und den Turinggraden.

Relative Berechenbarkeit

Wie oben bereits erwähnt übertragen sich die meisten Theoreme der Berechenbarkeitstheorie auch auf Orakel-Turingmaschinen. Allen voran das Smn-Theorem zusammen mit den daraus folgenden Rekursionssätzen sowie die Unentscheidbarkeit des (Orakel-)Halteproblems. Man spricht dann auch von relativer Berechenbarkeit (am. engl.: relativized recursion theory), dies spiegelt sich auch in den folgenden Definitionen wider:

Seien A ; B N {\displaystyle A;B\subseteq \mathbb {N} } Mengen natürlicher Zahlen.

  • Die Menge A {\displaystyle A} heiße berechenbar in B {\displaystyle B} falls es eine Turingmaschine mit Orakel für B {\displaystyle B} gibt, die die charakteristische Funktion χ A {\displaystyle \chi _{A}} berechnet, also A {\displaystyle A} entscheidet.

Dies ist per Definition genau dann der Fall, wenn sich A {\displaystyle A} auf B {\displaystyle B} Turing-reduzieren lässt, A T B {\displaystyle A\preceq _{T}B} .

  • Die Menge A {\displaystyle A} heiße entsprechend rekursiv aufzählbar in B {\displaystyle B} , falls es eine Turingmaschine mit Orakel für B {\displaystyle B} gibt, die die partielle charakteristische Funktion χ A {\displaystyle \chi _{A}^{\bot }} berechnet, also A {\displaystyle A} aufzählt.

Offenbar impliziert die relative Berechenbarkeit die relative Aufzählbarkeit, die Umkehrung gilt im Allgemeinen nicht. Allerdings ist auch hier A {\displaystyle A} genau dann berechenbar in B {\displaystyle B} , wenn sowohl A {\displaystyle A} als auch sein Komplement A ¯ {\displaystyle {\bar {A}}} aufzählbar in B {\displaystyle B} sind.

Hinweis: Relative Aufzählbarkeit sollte nicht mit der aufzählbaren Reduktion verwechselt werden. Letztere ist echt schwächer als relative Aufzählbarkeit und im Allgemeinen unvergleichbar mit der Turing-Reduktion.

Literatur

  • John E. Hopcroft, Jeffrey D. Ullman: Einführung in die Automatentheorie, formale Sprachen und Komplexitätstheorie. 4. durchgesehene Auflage. Oldenbourg, München u. a. 2000, ISBN 3-486-25495-2. 
  • Christos H. Papadimitriou: Computational Complexity. Addison-Wesley, Reading MA u. a. 1994, ISBN 0-201-53082-1. 
  • Hartley Rogers, Jr.: Theory of Recursive Functions and Effective Computability. McGraw-Hill, Cambridge, Massachusetts 1987, ISBN 0-262-68052-1, S. 145–149.