Gödelnummer

Eine Gödelnummer ist eine natürliche Zahl, die einem Wort einer formalen Sprache nach einem bestimmten Verfahren zugeordnet wird und dieses Wort eindeutig kennzeichnet. Ein solches Verfahren bezeichnet man als Gödelisierung. Die Bezeichnungen beziehen sich auf Kurt Gödel, der erstmals ein solches Verfahren angab, um seinen Unvollständigkeitssatz zu beweisen.

Formale Definition

Sei M die (abzählbare) Menge der Wörter m einer formalen Sprache. Eine Funktion

g\colon M\to {\mathbb  {N}}

wird Gödelisierung genannt, wenn

g(m) nennt man dann die Gödelnummer von m.

Beispiel

Angenommen, beliebige Wörter der formalen Sprache L, die auf dem Alphabet \Sigma basieren, sollen gödelisiert werden. Hier sei \Sigma =\{a,b,c\}.

Eine Möglichkeit der Kodierung wäre, den Buchstaben zunächst einfach fortlaufende Nummern zuzuweisen. Ein a entspräche der 1, ein b der 2 und ein c der 3. Nun kann man gödelisieren, indem man die dem Buchstaben entsprechenden Potenzen der fortlaufenden Primzahlen 2,3,5,7,\ldots miteinander multipliziert:

Das Wort abccba

Die Gödelnummer für abccba in dieser Kodierung lautet also 2\cdot 9\cdot 125\cdot 343\cdot 121\cdot 13=1\,213\,962\,750

Da es unendlich viele Primzahlen gibt, kann man auf diese Weise tatsächlich beliebig lange Wörter kodieren und aufgrund der Eindeutigkeit der Primfaktorzerlegung lässt sich etwa aus der Zahl 1213962750 wieder das Wort abccba rekonstruieren. Es gibt zwar Zahlen, die keinem Wort der Sprache entsprechen, beispielsweise 3=2^{0}\cdot 3^{1} (kein erster Buchstabe) oder 16=2^{4} (Alphabet \Sigma hat kein viertes Element). Aber zumindest lassen sich diese ungültigen Werte auf berechenbare Weise von den gültigen unterscheiden.

Neben der hier gezeigten gibt es natürlich noch andere Methoden, eine Gödelisierung durchzuführen. Man könnte beispielsweise für die Nummerierung der Zeichen des Alphabets ebenfalls die Primzahlfolge verwenden. Das ist zwar grundsätzlich nicht nötig, erlaubt aber zusätzlich die Struktur von Termen (Formeln) mit zu kodieren.

Die im Buch (Douglas R. Hofstadter: Gödel, Escher, Bach. An Eternal Golden Braid. Basic Books, New York NY 1979, ISBN 0-465-02685-0.) von Douglas Hofstadter beschriebene Methode verwendet beispielsweise ein Stellenwertsystem mit der Basis 1000, was zwar sehr anschaulich ist, aber formal schwieriger zu handhaben ist als eine Methode, die wie die obige auf Primzahlpotenzen beruht. Das gilt erst recht für die im IT-Bereich verwendeten Codierungen – etwa Unicode-Codierungen wie UTF-7, mit denen man auch die Sonderzeichen abbilden kann. Diese ordnen einer Zeichenkette (String) eine Folge von Hexadezimal- bzw. Binärziffern zu, die man als Ganzes als eine Gödelnummer auffassen kann (das Nullbyte bedeutet üblicherweise Ende des Darstellungsstrings, daher sollte es keine Eindeutigkeitsprobleme wegen führender Nullen geben – ansonsten kann eine binäre 1 vorangestellt werden). Die Rekonstruktion der Zeichenfolge aus dieser Zahlendarstellung ist aufgrund der geforderten technischen Funktionalität gegeben.

Gödelisierung von zahlentheoretischen Aussagen

Aussagen der Zahlentheorie (oder auch anderer mathematischer Theorien) lassen sich mit Hilfe eines endlichen Alphabets formulieren, dessen Elemente neben Zeichen für Variablen auch gewisse mathematische und logische Symbole (etwa +, \cdot , =, \land , \Rightarrow , \forall) umfasst. (Die abzählbar unendlich vielen Variablen können als besonders gekennzeichnete Wörter des endlichen Alphabets dargestellt werden.)

Auf diese Weise lassen sich also zahlentheoretische Aussagen (und sogar Beweise) in Zahlen übersetzen. Als Folge hiervon kann die Zahlentheorie, die ja Aussagen über Zahlen behandeln soll, auch Aussagen über zahlentheoretische Aussagen und Beweise behandeln. Diese Tatsache ist der Punkt, an dem Gödels Unvollständigkeitssatz ansetzt.

Gödelisierung von Turingmaschinen

Eine bekannte Anwendung der Gödelnummer ist die Kodierung einer Turingmaschine durch ein Binärwort w. Auf diese Weise wird jeder Turingmaschine eine Zahl zugeordnet (d.h. die Menge aller Turingmaschinen ist abzählbar). Diese Tatsache wird unter anderem im Halteproblem ausgenutzt.

Beispiel

Natürlich lassen sich verschiedenste Konventionen für die Nummerierung vereinbaren. Im Folgenden soll der Vorgang an einem einfachen Beispiel gezeigt werden. Sei

M=(Q,\Sigma ,\Gamma ,\delta ,q_{0},\square ,F)

eine Turingmaschine. Seien o. B. d. A. die Zustandsmenge Q, sowie das Bandalphabet \Gamma durchnummeriert.

Q=\{q_{0},q_{1},\ldots ,q_{k}\},\Gamma =\{a_{0},a_{1},\ldots ,a_{l}\};k,l\in {\mathbb  {N}}

Wir codieren nun vorerst jeden Übergang \delta (q_{m},a_{n})=(q_{{m'}},a_{{n'}},b) mit b\in \{L,N,R\} durch ein Wort über dem Alphabet \{0,1,\#\}. Zustände bzw. Terminalsymbole werden durch die Binärdarstellung ihrer Indizes dargestellt, die einzelnen Elemente werden mit \# getrennt.

\delta (q_{m},a_{n})=(q_{{m'}},a_{{n'}},b)\mapsto \#\#\operatorname {bin}(m)\#\operatorname {bin}(n)\#\operatorname {bin}(m')\#\operatorname {bin}(n')\#\operatorname {bin}(b)

wobei b die Kopfbewegung darstellt (L=0,N=1,R=2). Um uns auf das zweistellige Alphabet \{0,1\} beschränken zu können, führen wir eine Abbildung der Menge \{0,1,\#\} auf \{0,1\} ein:

0\mapsto 00,1\mapsto 01,\#\mapsto 10.

Die Turingmaschine mit der einzigen Produktion \delta (q_{0},0)\mapsto (q_{0},0,N) wird so zu 1010001000100010001001_{2}=2656393_{{10}}.

Eine Alternative, die auf das Trennzeichen verzichtet, nutzt die Eindeutigkeit der Primfaktorzerlegung aus, um Tupel in einer Zahl codieren zu können.

Siehe auch

Trenner
Basierend auf einem Artikel in: Extern Wikipedia.de
Seitenende
Seite zurück
©  biancahoegel.de
Datum der letzten Änderung: Jena, den: 29.08. 2021