Aufzählungsoperator

Aus testwiki
Zur Navigation springen Zur Suche springen

Aufzählungsoperatoren (engl.: enumeration operator) sind in der theoretischen Informatik, genauer in der Berechenbarkeitstheorie, bestimmte berechenbare Abbildungen zwischen Mengen natürlicher Zahlen. Sie sind damit eine Verallgemeinerung von berechenbaren Operatoren. Aufzählungsoperatoren definieren eine Reduktion zwischen den beteiligten Mengen.

Definition

Aufzählungsoperator

Es sei {Di}i eine effektive Nummerierung aller endlichen Teilmengen von (bspw. Di={x1;x2;;xn} für i=2x1+2x2++2xn). Weiter sei ;:2 eine berechenbare Kodierungsfunktion für Paare natürlicher Zahlen.

  • Eine Abbildung Ψ:𝒫()𝒫() zwischen Teilmengen natürlicher Zahlen heiße Aufzählungsoperator, falls es eine rekursiv aufzählbare Menge S gibt, so dass für beliebige Mengen A gilt: xΨ(A)i:(DiAi;xS).

Aufzählungsoperatoren lassen sich offenbar von Turing-Maschinen realisieren: Die entsprechende Maschine erhält von einer externen Quelle – zum Beispiel einem menschlichen Nutzer – immer größere, endliche Teilmengen von A als Eingabe. Parallel dazu durchsucht sie den Suchraum S nach passenden Einträgen i;x, wird ein solcher gefunden lautet die Ausgabe x. Nach und nach wird so die gesamte Menge Ψ(A) aufgezählt.

Aufzählbare Reduktion

  • Eine Menge B heiße aufzählbar reduzierbar auf A (engl.: enumeration reducible), BeA, falls es einen Aufzählungsoperator Ψ gibt, so dass Ψ(A)=B gilt.

Ist eine Aufzählung der Menge A gegeben (sei diese berechenbar oder nicht), so vermittelt der Operator Ψ auch eine Aufzählung von B (vgl. Reduktion (Theoretische Informatik)). Es folgt, dass die Menge B rekursiv aufzählbar in A ist (vgl. Orakel-Turingmaschine), die Umkehrung gilt im Allgemeinen nicht. Aufzählungsoperatoren bilden daher stets rekursiv aufzählbare Mengen wieder auf rekursiv aufzählbare Mengen ab, dies motiviert die Bezeichnung.

Beispiele

Es gibt einige triviale Aufzählungsoperatoren, zum Beispiel die Identität ΨI(A)=A oder den Links-Shift ΨL(A)={a+1|aA}. Konstante Operatoren sind genau dann Aufzählungsoperatoren, wenn die Zielmenge rekursiv aufzählbar ist, wie etwa Ψc;K(A)=K für das spezielle Halteproblem K. Auch andere berechenbare Manipulationen der Eingabemengen können durch Aufzählungsoperatoren vermittelt werden, Ψπ2(A)={y|x:x;yA}.

Die eigentliche Intention der obigen Definition ist aber ein berechenbares Analogon zu induktiven Definitionen zu schaffen. Eine Menge induktiver Gleichungen könnte beispielsweise wie folgt lauten (vgl. Fibonacci-Folge):

f(0)=0;
f(1)=1;
f(n+2)=f(n)+f(n+1).

Dies lässt sich in einen Aufzählungsoperator Ψf für die Graphen möglicher Lösungen f umformulieren, indem man explizit den zugrunde liegenden Suchraum S angibt. Zur besseren Lesbarkeit werden hier direkt die endlichen Mengen Di statt ihrer Kodnummern i verwendet. Außerdem werden die Elemente der Zielmenge als kodierte Paare natürlicher Zahlen aufgefasst. Notwendig enthält S dann die Elemente ;(0;0) und ;(1;1), da jede Lösung auf Grund der ersten beiden Gleichungen die 0 und die 1 jeweils auf sich selbst abbilden muss. Außerdem enthalte S für beliebige natürliche Zahlen n;m;k jeweils das Paar {(n;m);(n+1;k)};(n+2;m+k). Dies realisiert die dritte Gleichung, denn ist durch die Eingabemenge nun die Information bekannt, dass für die angepeilte Lösung nm und n+1k gilt, dann erzwingt Ψf auch n+2m+k für die Ausgabemenge.

Eigenschaften

  • Es gibt eine effektive Nummerierung {Ψp}p aller Aufzählungsoperatoren, diese ergibt sich sofort aus der kanonischen Nummerierung aller rekursiv aufzählbaren Mengen.

Für einen Aufzählungsoperator Ψ, Mengen A;B und natürliche Zahlen x gilt:

  • Monotonie: ABΨ(A)Ψ(B).
  • Kompaktheit: xΨ(A)DfinA:xΨ(D).

Aus der Kompaktheit folgt außerdem, dass Aufzählungsoperatoren als Abbildungen stetig sind, wenn man die Potenzmenge 𝒫() mit der Topologie versieht, die durch die Basismengen {A|DifinA}i erzeugt wird.

  • Es gibt eine total berechenbare Funktion g, so dass p;q:Ψg(p;q)=ΨpΨq.
    • Insbesondere ist also die Klasse der Aufzählungsoperatoren unter Komposition abgeschlossen.
  • Wie alle Reduktionen ist e eine Präordnung auf 𝒫(), die Relation also insbesondere transitiv.
  • Die Truth-table-Reduktion (und damit auch die Many-one-Reduktion) impliziert die aufzählbare Reduktion, B1ABmABttABeA.

Die Implikationen sind dabei jeweils strikt.

  • Die aufzählbare Reduktion und die Turing-Reduktion sind dagegen unvergleichbar.

Berechenbare Operatoren

Vorlage:Hauptartikel

Eine Menge A natürlicher Zahlen heiße rechtseindeutig, falls gilt: x;y;x;zAy=z. Es bezeichne 𝔓 die Menge aller partiellen Abbildungen ψ: natürlicher Zahlen. Identifiziert man eine Funktion ψ𝔓 mit ihrem Graphen, so erlaubt ; diese als Teilmenge der natürlichen Zahlen aufzufassen. Dadurch ist eine Einbettung 𝔓𝒫(); ψ{x;ψ(x)|xdom(ψ)} erklärt. Ihr Bild besteht gerade aus den rechtseindeutigen Mengen.

Gilt nun für einen Aufzählungsoperator Ψ(𝔓)𝔓, überführt er also rechtseindeutige Mengen wieder in rechtseindeutige, so ist die Einschränkung Ψ|𝔓 ein berechenbarer Operator. Auf diese Weise erhält man alle berechenbaren Operatoren. Notwendig bildet Ψ dann auch berechenbare Funktionen wieder auf berechenbare ab.

Rekursionssatz

Vorlage:Hauptartikel

Es gibt einen Rekursionssatz für Aufzählungsoperatoren. Dieser ist schwächer als der entsprechende Satz für berechenbare Operatoren, weshalb er in der englischen Literatur auch gelegentlich als weak recursion theorem bezeichnet wird.

  • Für jeden Aufzählungsorperator Ψ gibt es eine rekursiv aufzählbare Menge F derart, dass F ein Fixpunkt ist, Ψ(F)=F, und jeder Fixpunkt von Ψ die Menge F enthält.
  • Ist Ψ|𝔓 sogar ein berechenbarer Operator, so gibt es eine partiell berechenbare Funktion ψ, so dass Ψ(ψ)=ψ und jeder rechtseindeutige Fixpunkt von Ψ die Funktion ψ als Einschränkung besitzt.

Der Fixpunkt F lässt sich sogar explizit angeben: Es sei F0= und für jede natürliche Zahl k sei Fk+1=FkΨ(Fk), dann ist F=kFk. Der zweite Teil folgt nun aus dem ersten durch die Beobachtung, dass in diesem Fall die Menge F rechtseindeutig ist.

Betrachtet man beispielsweise den oben definierten Operator Ψf, so erhält man als den kleinsten Fixpunkt den Graphen der durch die Gleichungen eindeutig definierten Fibonacci-Funktion fib. Ein weiterer, allerdings nicht mehr rechtseindeutiger, Fixpunkt ist die Menge {x;y|yfib(x)}, da auch sie den obigen Gleichungen genügt. Der Fixpunkt enthält offenbar den Graphen von fib als Teilmenge.

Quellen

en:Kleene's recursion theorem#The first recursion theorem