Deterministische Turing-Maschinen
|
|
- Björn Rosenberg
- vor 7 Jahren
- Abrufe
Transkript
1 Deterministische Turing-Maschinen Um 900 präsentierte David Hilbert auf einem internationalen Mathematikerkongress eine Sammlung offener Fragen, deren Beantwortung er von zentraler Bedeutung für die weitere Entwicklung der Mathematik im 0. Jahrhundert hielt. Eine dieser Fragen befasste sich mit den logischen Grundlagen der Mathematik und lässt sich folgendermaßen formulieren:. Ist die Mathematik vollständig, d.h., kann jede mathematische Aussage bewiesen oder widerlegt werden?. Ist die Mathematik konsistent, d.h., ist es ausgeschlossen, dass sowohl eine Aussage als auch ihr Gegenteil bewiesen werden kann? 3. Ist die Mathematik entscheidbar, d.h., gibt es eine definitive Methode, die für jede mathematische Aussage feststellt, ob diese wahr oder falsch ist? Hilbert war der festen Überzeugung, dass alle diese Fragen positiv beantwortet werden könnten. Im Jahr 93 zeigte allerdings Kurt Gödel 3, dass jede Formalisierung der Arithmetik entweder inkonsistent oder unvollständig sein muss; darüber hinaus bewies er, dass es nicht möglich ist, die Konsistenz der Arithmetik innerhalb dieser selbst zu zeigen. Offen blieb vorerst der dritte Teil der Frage, wenn auch in etwas veränderter Form: 3. Gibt es eine definitive Methode, die für jede mathematische Aussage feststellt, ob diese beweisbar ist oder nicht? Definitive Methode bedeutet hier mechanisches Verfahren oder Algorithmus. Um diese Frage positiv beantworten zu können, genügt es, einen Algorithmus anzugeben, der in der Lage ist, jede Aussage auf Beweisbarkeit zu überprüfen. Eine Verneinung der Frage hingegen verlangt den Nachweis, dass kein einziger Algorithmus dazu in der Lage ist. Dies setzt aber einen exakten Begriff davon voraus, was Algorithmus bzw. mechanisch machbar bedeutet. Zu diesem Zweck führte Alan Turing in seiner Arbeit On computable numbers, with an application to the Entscheidungsproblem (936) ein abstraktes Maschinenmodell (die sogenannte Turing-Maschine) ein, mit dem jedes mechanische Verfahren simuliert werden kann. Turing zeigte in diesem Artikel, dass es keine Turing-Maschine geben kann, die die (Un)Beweisbarkeit jeder beliebigen Aussage feststellt, und beantwortete damit den dritte Teil von Hilbert s Frage negativ. Eine Turing-Maschine besteht aus einem unendlichen Band, das beschrieben und gelesen werden kann, sowie aus einem endlichen Automaten, der das Lesen und Schreiben des Bandes steuert (Abb. ). In der Terminologie realer Computer entspricht der endliche Deutscher Mathematiker, Das sogenannte Hilbert-Programm. 3 Österreichischer Mathematiker, geboren 906 in Brünn (Brno, Tschechische Republik), gestorben 978 in der USA Englischer Mathematiker, 9 95
2 Endlicher Automat Band Schreib-/Lesekopf Abbildung : Schematische Darstellung einer deterministischen Turing-Maschine Automat dem Prozessor und das Band dem Speicher. Formal lässt sich eine Turing- Maschine folgendermaßen definieren: Definition Eine deterministische Turing-Maschine wird durch ein Siebentupel T = Q, Σ, Γ, δ, q 0,, F beschrieben, wobei wie bei den endlichen Automaten Q eine endliche Menge von Zuständen, q 0 Q der Anfangszustand, F Q eine Menge von Endzuständen und Σ das Eingabealphabet ist. Die Menge Γ heißt Bandalphabet und enthält sowohl das Eingabealphabet als auch das Leersymbol. Letzteres darf nicht im Eingabealphabet vorkommen, d.h., Σ Γ {}. Die Funktion δ: Q Γ Q Γ {L, R} heißt Übergangsfunktion. Als Eingabe für eine Turing-Maschine dient eine Zeichenkette x Σ, die sich in den Feldern bis x des Bandes befindet, wobei jedes Zeichen genau ein Feld belegt. Alle anderen Felder sind zu Beginn mit dem Leersymbol initialisiert. Die Berechnung beginnt im Anfangszustand q 0, der Schreib-/Lesekopf befindet sich über dem Feld mit der Nummer. Die weiteren Schritte erfolgen nun entsprechend der Übergangsfunktion δ. Sei q der momentane Zustand. Falls q ein Endzustand ist, gilt die Eingabe als akzeptiert. Andernfalls wird das Symbol s Γ unter dem Schreib-/Lesekopf gelesen. Ist δ(q, s) = (q, s, ), wechselt die Turing-Maschine vom Zustand q in den Zustand q, das Bandsymbol s wird durch das Symbol s überschrieben, und der Schreib-/Lesekopf rückt ein Feld nach links, falls = L, oder ein Feld nach rechts, falls = R. Die momentane Berechnungssituation einer Turing-Maschine wird vollständig durch den Inhalt des Bandes, die Position des Schreib-/Lesekopfes und den Zustand beschrieben. Diese drei Komponenten werden in der sogenannten Konfiguration zusammengefasst. Diese ist eine Zeichenkette der Form w qw, wobei w, w Γ und q Q. Intuitiv bedeutet w qw, dass sich die Turing-Maschine im Zustand q befindet, das Band mit w w beschriftet ist und der Schreib/Lesekopf über dem ersten Zeichen von w steht. Zusätzlich vereinbaren wir, dass w qw gleichbedeutend mit m w qw n für alle m, n 0 ist, d.h., vor und nach w w können bei Bedarf beliebig viele Leersymbole eingefügt werden. Der Berechnungsvorgang kann nun formal durch die Rechenschrittrelation beschrieben werden:
3 x R 0 y a/x R a,y b/y R b,z c/z L 3 a,b,y,z R y,z R 5 Abbildung : Turing-Maschine für {a n b n c n n 0} uqav ubq v falls δ(q, a) = (q, b, R) ucqav uq cbv falls δ(q, a) = (q, b, L) wobei u, v Wörter über dem Bandalphabet, a, b, c Symbole des Bandalphabets und q, q Zustände sind. Die reflexive und transitive Hülle von wird mit bezeichnet. Damit lässt sich die von einer Turing-Maschine T akzeptierte Sprache definieren als L(T ) = {w Σ q 0 w uq f v, q f F, u, v Γ } Graphische Darstellung von Turing-Maschinen Turing-Maschinen können als Graphen dargestellt werden. Jeder Knoten des Graphen entspricht einem Zustand aus Q, jede Kante einem möglichen Zustandsübergang. Vom Knoten q führt genau dann eine mit (s, s, ) beschriftete Kante zum Knoten q, wenn δ(q, s) = (q, s, ) gilt: (s, s, ) q q wenn δ(q, s) = (q, s, ). Die graphische Darstellung lässt sich vereinfachen, wenn die Turing-Maschine richtungsgebunden ist, d.h., wenn für jeden Zustand q gilt: jede Kante, die zum Knoten q führt, ist mit derselben Richtungsangabe, L oder R, beschriftet. Diese Angabe kann daher direkt zum Knoten, der q entspricht, geschrieben werden. Da weiters meist das gelesene und das geschriebene Symbol identisch sind, reicht es in diesen Fällen, die Kante lediglich mit einem einzigen Bandsymbol zu beschriften. Wir erhalten damit: q s q wenn δ(q, s) = (q, s, ), und q s/s q wenn δ(q, s) = (q, s, ), wobei s s. Beispiel Abbildung zeigt den Graphen einer Turing-Maschine, die die Sprache {a n b n c n n 0} akzeptiert. In Tupel- und Tabellenschreibweise wird die Turing-Maschine be- 3
4 R 0 a X R R 5 X a/x R a a/x R X 3 a,x L Abbildung 3: Turing-Maschine für {a n n 0} schrieben durch wobei δ definiert ist durch: {0,,, 3,, 5}, {a, b, c}, {a, b, c, x, y, z, }, δ, 0,, {5} δ a b c x y z 0 (, x, R) (, y, R) (5,, R) (, a, R) (, y, R) (, y, R) (, b, R) (3, z, L) (, z, R) 3 (3, a, L) (3, b, L) (0, x, R) (3, y, L) (3, z, L) (, y, R) (, z, R) (5,, R) Wie schon bei den Automaten lässt sich die Übergangsfunktion zu einer totalen Funktion machen, indem man eine Falle hinzufügt. Beispiel Abbildung 3 zeigt den Graphen einer Turing-Maschine, die die Sprache {a n n 0} akzeptiert. In Tupel- und Tabellenschreibweise wird die Turing-Maschine beschrieben durch {0,,, 3,, 5}, {a}, {, a, X}, δ, 0,, {5} wobei δ definiert ist durch: δ a X 0 (, a, R) (5,, R) (, X, R) (, X, R) (,, L) (3, a, R) (, X, R) 3 (, X, R) (3, X, R) (0,, R) (, a, L) (, X, L) Funktionsweise der Turing-Maschine: n ist genau dann eine Zweierpotenz, wenn entweder n = oder wenn n durch teilbar und n eine Zweierpotenz ist. Entsprechend wird
5 in jedem Durchlauf durch die Schleife 0, 3 0 die Anzahl der auf dem Band stehenden a s halbiert, indem jedes zweite a durch X ersetzt wird. Ist die Anzahl der a s ungerade, trifft die Turing-Maschine entweder im Zustand oder im Zustand 3 auf ein Leersymbol. In bedeutet dies, dass nur mehr ein einziges a vorhanden ist; damit terminiert die Turing-Maschine im Endzustand 5. In 3 hingegen zeigt das Leersymbol an, dass die Halbierung nicht möglich ist, da die Anzahl der a s zu Beginn des Schleifendurchlaufes ungerade war. Die Turing-Maschine bleibt aufgrund fehlender Übergangsmöglichkeiten daher in diesem Nicht-Endzustand stecken und akzeptiert die Eingabe nicht. Dasselbe gilt, falls das Band zu Beginn der Ausführung ganz leer ist (n = 0). Als Beispiel einer Berechnung zeigen wir, dass das Wort aaaa von der Turing-Maschine akzeptiert wird. Wir nehmen in der Konfigurationsbeschreibung links und rechts der Eingabe noch ein Leersymbol hinzu, da diese Felder während der Abarbeitung inspiziert werden. 0 aaaa a aaa ax aa axa 3 a axax axa X ax ax a XaX axax axax ( ) ( ) 0 axax a XaX ax ax axx X axxx axx X ax XX a XXX axxx axxx ( ) ( ) 0 axxx a XXX ax XX axx X axxx axxx 5 Beispiel Abbildung zeigt den Graphen einer Turing-Maschine, die die Sprache {w {a, b} na(w) = n b (w)} akzeptiert. (n s (w) bezeichnet die Anzahl der Vorkommnisse des Symbols s im Wort w.) In Tupel- und Tabellenschreibweise wird die Turing-Maschine beschrieben durch wobei δ definiert ist durch: {0,,, 3,, 5, 6}, {a, b}, {, a, b, X}, δ, 0,, {6} δ a b X 0 (6,, R) (3, X, R) (, X, R) (0, X, R) (, X, R) (, b, R) (, X, R) (5, X, L) (, b, R) (, X, R) 3 (, X, R) (, X, R) (3, X, R) (, a, R) (5, X, L) (, X, R) 5 (0,, R) (5, a, L) (5, b, L) (5, X, L) 5
6 b,x b,x R a/x R b/x a/x R L 0 5 b/x a/x b/x R a/x R R 6 3 X a,x Abbildung : Turing-Maschine für {w {a, b} na(w) = n b (w)} Funktionsweise der Turing-Maschine: Das Band wird von links nach rechts gelesen; dabei wird das erste Vorkommnis des Symbols b sowie die ersten beiden Vorkommnisse von a in ein X umgewandelt. Es müssen drei mögliche Anordnungen berücksichtigt werden: ein b gefolgt von zwei a s (entspricht den Zustandsübergängen 0 5), ein a gefolgt von einem b gefolgt von einem a (0 3 5), sowie zwei a s gefolgt von einem b (0 3 5). Anschließend geht der Schreib-/Lesekopf zurück an den Anfang des Bandes, ein neuer Zyklus beginnt. Wird im Zustand 0 ein Leersymbol angetroffen, wurden genau zweimal so viele a s wie b s in ein X umgewandelt, daher erfolgt der Übergang in den Endzustand 6. In den Zuständen q,..., q bedeutet ein hingegen, dass das analysierte Wort nicht in der Sprache liegt, daher gibt es keine entsprechenden Übergänge. Trotz ihrer Einfachheit können Turing-Maschinen jede beliebige Aufgabe lösen, die auch von einem Computer ausgeführt werden kann; sie können etwa dazu verwendet werden, Funktionen zu berechnen. Insbesondere lässt sich mittels Turing-Maschinen auch der Begriff des Algorithmus exakt definieren. Definition Eine Funktion f: D R heißt Turing-berechenbar oder einfach nur berechenbar, wenn es eine Turing-Maschine Q, Σ, Γ, δ, q 0,, F gibt, sodass q 0 d q f f(d) (q f F ) gilt für alle d D. Diese Turing-Maschine wird als Algorithmus zur Berechnung der Funktion bezeichnet. Für mehrstellige Funktionen vereinbart man irgendein beliebiges Symbol, mit dem die einzelnen Argumente auf dem Band voneinander getrennt werden. Beispiel Wir zeigen, dass die Addition natürlicher Zahlen, d.h. die Funktion f(x, y) = x + y für x, y ω, Turing-berechenbar ist. Wir kodieren zunächst jede Zahl n unär als 6
7 Zeichenkette n und vereinbaren, dass die beiden Argumente der Addition durch das Symbol + getrennt werden. Die folgende Turing-Maschine berechnet f. +/ / R R L L R 0 3 Die Berechnung für f(, 3) sieht folgendermaßen aus: ( ) ( )
Turing Maschine. Thorsten Timmer. SS 2005 Proseminar Beschreibungskomplexität bei Prof. D. Wotschke. Turing Maschine SS 2005 p.
Thorsten Timmer SS 2005 Proseminar Beschreibungskomplexität bei Prof. D. Wotschke Turing Maschine SS 2005 p. 1/35 Inhalt Einführung Formale Definition Berechenbare Sprachen und Funktionen Berechnung ganzzahliger
MehrTheoretische Informatik 1
heoretische Informatik 1 uringmaschinen David Kappel Institut für Grundlagen der Informationsverarbeitung echnische Universität Graz 11.03.2016 Übersicht uring Maschinen Algorithmusbegriff konkretisiert
MehrProseminar Komplexitätstheorie P versus NP Wintersemester 2006/07. Nichtdeterministische Turingmaschinen und NP
Proseminar Komplexitätstheorie P versus NP Wintersemester 2006/07 Vortrag am 17.11.2006 Nichtdeterministische Turingmaschinen und NP Yves Radunz Inhaltsverzeichnis 1 Wiederholung 3 1.1 Allgemeines........................................
MehrTheorie der Informatik
Theorie der Informatik 11. Kontextsensitive und Typ-0-Sprachen Malte Helmert Gabriele Röger Universität Basel 7. April 2014 Kontextsensitive und allgemeine Grammatiken Wiederholung: (kontextsensitive)
Mehr1 Einführung. 2 Typ-0- und Typ-1-Sprachen. 3 Berechnungsmodelle. 4 Unentscheidbarkeit. 5 Unentscheidbare Probleme. 6 Komplexitätstheorie
1 Einführung 2 Typ-0- und Typ-1-Sprachen 3 Berechnungsmodelle 4 Unentscheidbarkeit 5 Unentscheidbare Probleme 6 Komplexitätstheorie 15 Ziele vgl. AFS: Berechnungsmodelle für Typ-0- und Typ-1-Sprachen (Nicht-)Abschlußeigenschaften
Mehr11. Woche: Turingmaschinen und Komplexität Rekursive Aufzählbarkeit, Entscheidbarkeit Laufzeit, Klassen DTIME und P
11 Woche: Turingmaschinen und Komplexität Rekursive Aufzählbarkeit, Entscheidbarkeit Laufzeit, Klassen DTIME und P 11 Woche: Turingmaschinen, Entscheidbarkeit, P 239/ 333 Einführung in die NP-Vollständigkeitstheorie
MehrALP I Turing-Maschine
ALP I Turing-Maschine Teil I WS 2012/2013 Äquivalenz vieler Berechnungsmodelle Alonzo Church λ-kalkül Kombinatorische Logik Alan Turing Turing-Maschine Mathematische Präzisierung Effektiv Berechenbare
MehrTuringmaschinen Vorlesung Berechenbarkeit und Komplexität alias Theoretische Informatik: Komplexitätstheorie und effiziente Algorithmen
Vorlesung Berechenbarkeit und Komplexität alias Theoretische Informatik: und effiziente Algorithmen Wintersemester 2011/12 Schematische Darstellung einer Turing-Maschine: Kopf kann sich nach links und
Mehr11.1 Kontextsensitive und allgemeine Grammatiken
Theorie der Informatik 7. April 2014 11. Kontextsensitive und Typ-0-Sprachen Theorie der Informatik 11. Kontextsensitive und Typ-0-Sprachen 11.1 Kontextsensitive und allgemeine Grammatiken Malte Helmert
MehrTuring-Maschinen. Definition 1. Eine deterministische Turing-Maschine (kurz DTM) ist ein 6- Dem endlichen Alphabet Σ von Eingabesymbolen.
Turing-Maschinen Nachdem wir endliche Automaten und (die mächtigeren) Kellerautomaten kennengelernt haben, werden wir nun ein letztes, noch mächtigeres Automatenmodell kennenlernen: Die Turing-Maschine
MehrBerechenbarkeit. Script, Kapitel 2
Berechenbarkeit Script, Kapitel 2 Intuitiver Berechenbarkeitsbegriff Turing-Berechenbarkeit WHILE-Berechenbarkeit Church sche These Entscheidungsprobleme Unentscheidbarkeit des Halteproblems für Turingmaschinen
Mehr5.2 Endliche Automaten
114 5.2 Endliche Automaten Endliche Automaten sind Turingmaschinen, die nur endlichen Speicher besitzen. Wie wir bereits im Zusammenhang mit Turingmaschinen gesehen haben, kann endlicher Speicher durch
Mehrmehreren Präzisierungen des intuitiven Begriffs des Verfahren sein muss, so legt sich nahe, dass er Der Begriff der TURING-Maschine ist eine unter
7\S*UDPPDWLNHQ 7\S6SUDFKHQ XQG 7XULQJPDVFKLQHQ 258 785,1*0DVFKLQH70 Der Begriff der TURING-Maschine ist eine unter mehreren Präzisierungen des intuitiven Begriffs des $OJRULWKPXV bzw. der %HUHFKHQEDUNHLW
Mehr1.5 Turing-Berechenbarkeit
A.M. Turing (1937): Maschinenmodell zur exakten Beschreibung des Begriffs effektiv berechenbar Stift Mensch a c b b Rechenblatt a b b c Lese-/Schreibkopf endliche Kontrolle Turingmaschine Eine Turingmaschine
Mehr2. Gegeben sei folgender nichtdeterministischer endlicher Automat mit ɛ-übergängen:
Probeklausur Automatentheorie & Formale Sprachen WiSe 2012/13, Wiebke Petersen Name: Matrikelnummer: Aufgabe A: Typ3-Sprachen 1. Konstruieren Sie einen endlichen Automaten, der die Sprache aller Wörter
Mehr1.5 Turing-Berechenbarkeit
A.M. Turing (1937): Maschinenmodell zur exakten Beschreibung des Begriffs effektiv berechenbar Stift Mensch a c b b Rechenblatt a b b c Lese-/Schreibkopf endliche Kontrolle Turingmaschine Eine Turingmaschine
Mehr2.6 Verdeutlichung verwendeter Begriffe
2.6 Verdeutlichung verwendeter Begriffe endlich/finit: die Mengen der Zustände und der Ein- bzw. Ausgabezeichen sind endlich synchron: die Ausgabezeichen erscheinen synchron mit dem Einlauf der Eingabezeichen
MehrRekursiv aufzählbare Sprachen
Kapitel 4 Rekursiv aufzählbare Sprachen 4.1 Grammatiken und die Chomsky-Hierarchie Durch Zulassung komplexer Ableitungsregeln können mit Grammatiken größere Klassen als die kontextfreien Sprachen beschrieben
MehrEinführung in die Informatik
Universität Innsbruck - Institut für Informatik Datenbanken und Informationssysteme Prof. Günther Specht, Eva Zangerle 24. November 28 Einführung in die Informatik Übung 7 Allgemeines Für die Abgabe der
Mehr1936 von Alan Turing zum theoretischen Studium der Berechenbarkeit eingeführt Besteht aus
//5 Abstrakte Maschinenmodelle: Turingmaschine (TM) 96 von Alan Turing zum theoretischen Studium der Berechenbarkeit eingeführt Besteht aus einem festen Teil ( "Hardware ) einem variablen Teil ( "Software
MehrTuring-Maschine. Berechenbarkeit und Komplexität Turing-Maschinen. Turing-Maschine. Beispiel
Berechenbarkeit und Komplexität Turing-Maschinen Wolfgang Schreiner Wolfgang.Schreiner@risc.jku.at Research Institute for Symbolic Computation (RISC) Johannes Kepler University, Linz, Austria http://www.risc.jku.at
MehrWeitere universelle Berechnungsmodelle
Weitere universelle Berechnungsmodelle Mehrband Turingmaschine Nichtdeterministische Turingmaschine RAM-Modell Vektoradditionssysteme λ-kalkül µ-rekursive Funktionen 1 Varianten der dtm Mehrkopf dtm Kontrolle
MehrFunktionale Programmierung ALP I. λ Kalkül WS 2012/2013. Prof. Dr. Margarita Esponda. Prof. Dr. Margarita Esponda
ALP I λ Kalkül WS 2012/2013 Berechenbarkeit - inspiriert durch Hilbert's Frage - im Jahr 1900, Paris - Internationaler Mathematikerkongress Gibt es ein System von Axiomen, aus denen alle Gesetze der Mathematik
MehrBerechenbarkeit/Entscheidbarkeit
Berechenbarkeit/Entscheidbarkeit Frage: Ist eine algorithmische Problemstellung lösbar? was ist eine algorithmische Problemstellung? formale Sprachen benötigen einen Berechenbarkeitsbegriff Maschinenmodelle
Mehr1 Einführung. 2 Typ-0- und Typ-1-Sprachen. 3 Berechnungsmodelle. 4 Unentscheidbarkeit. 5 Unentscheidbare Probleme. 6 Komplexitätstheorie
1 Einführung 2 Typ-0- und Typ-1-Sprachen 3 Berechnungsmodelle 4 Unentscheidbarkeit 5 Unentscheidbare Probleme 6 Komplexitätstheorie 139 Unentscheidbarkeit Überblick Zunächst einmal definieren wir formal
MehrEndliche Automaten. Endliche Automaten J. Blömer 1/23
Endliche Automaten Endliche Automaten sind ein Kalkül zur Spezifikation von realen oder abstrakten Maschinen regieren auf äußere Ereignisse (=Eingaben) ändern ihren inneren Zustand produzieren gegebenenfalls
MehrLösung zur Klausur. Grundlagen der Theoretischen Informatik im WiSe 2003/2004
Lösung zur Klausur Grundlagen der Theoretischen Informatik im WiSe 2003/2004 1. Geben Sie einen deterministischen endlichen Automaten an, der die Sprache aller Wörter über dem Alphabet {0, 1} akzeptiert,
MehrTheoretische Informatik II
Theoretische Informatik II Einheit 4.2 Modelle für Typ-0 & Typ-1 Sprachen 1. Nichtdeterministische Turingmaschinen 2. Äquivalenz zu Typ-0 Sprachen 3. Linear beschränkte Automaten und Typ-1 Sprachen Maschinenmodelle
Mehrc) {abcde, abcfg, bcade, bcafg} d) {ade, afg, bcde, bcfg} c) {abcabc} d) {abcbc, abc, a} c) {aa, ab, ba, bb} d) {{aa}, {ab}, {ba}, {bb}}
2 Endliche Automaten Fragen 1. Was ergibt sich bei {a, bc} {de, fg}? a) {abc, defg} b) {abcde, abcfg} c) {abcde, abcfg, bcade, bcafg} d) {ade, afg, bcde, bcfg} 2. Was ergibt sich bei {abc, a} {bc, λ}?
Mehr2. Klausur zur Vorlesung Theoretische Grundlagen der Informatik Wintersemester 2014/2015
2. Klausur zur Vorlesung Theoretische Grundlagen der Informatik Wintersemester 2014/2015 Hier Aufkleber mit Name und Matrikelnummer anbringen Vorname: Nachname: Matrikelnummer: Beachten Sie: Bringen Sie
MehrDie mathematische Seite
Kellerautomaten In der ersten Vorlesung haben wir den endlichen Automaten kennengelernt. Mit diesem werden wir uns in der zweiten Vorlesung noch etwas eingängiger beschäftigen und bspw. Ansätze zur Konstruktion
Mehr1 Einführung. 2 Typ-0- und Typ-1-Sprachen. 3 Berechnungsmodelle. 4 Unentscheidbarkeit. 5 Unentscheidbare Probleme. 6 Komplexitätstheorie
1 Einführung 2 Typ-0- und Typ-1-Sprachen 3 Berechnungsmodelle 4 Unentscheidbarkeit 5 Unentscheidbare Probleme 6 Komplexitätstheorie WS 11/12 155 Überblick Zunächst einmal definieren wir formal den Begriff
MehrBerechenbarkeit. Script, Kapitel 2
Berechenbarkeit Script, Kapitel 2 Intuitiver Berechenbarkeitsbegriff Turing-Berechenbarkeit WHILE-Berechenbarkeit Church sche These Entscheidungsprobleme Unentscheidbarkeit des Halteproblems für Turingmaschinen
Mehr2. Gegeben sei folgender nichtdeterministischer endlicher Automat mit ɛ-übergängen:
Probeklausur Automatentheorie & Formale Sprachen WiSe 2012/13, Wiebke Petersen Name: Matrikelnummer: Aufgabe A: Typ3-Sprachen 1. Konstruieren Sie einen endlichen Automaten, der die Sprache aller Wörter
MehrTheoretische Informatik 1
heoretische Informatik 1 eil 2 Bernhard Nessler Institut für Grundlagen der Informationsverabeitung U Graz SS 2009 Übersicht 1 uring Maschinen uring-berechenbarkeit 2 Kostenmaße Komplexität 3 Mehrband-M
MehrFrank Heitmann 2/47. 1 Ein PDA beginnt im Startzustand z 0 und mit im Keller. 2 Ist der Automat
Formale Grundlagen der Informatik 1 Kapitel 5 Über reguläre Sprachen hinaus und (Teil 2) Frank Heitmann heitmann@informatik.uni-hamburg.de 21. April 2015 Der Kellerautomat - Formal Definition (Kellerautomat
MehrTheoretische Grundlagen der Informatik
Theoretische Grundlagen der Informatik 0 KIT 17.05.2010 Universität des Dorothea Landes Baden-Württemberg Wagner - Theoretische und Grundlagen der Informatik nationales Forschungszentrum Vorlesung in am
MehrEinführung in die Informatik Turing Machines
Einführung in die Informatik Turing Machines Eine abstrakte Maschine zur Präzisierung des Algorithmenbegriffs Wolfram Burgard 1 Motivation und Einleitung Bisher haben wir verschiedene Programmiersprachen
Mehr2 2 Reguläre Sprachen. 2.2 Endliche Automaten. Übersicht
Formale Systeme, Automaten, Prozesse Übersicht 2 2. Reguläre Ausdrücke 2.3 Nichtdeterministische endliche Automaten 2.4 Die Potenzmengenkonstruktion 2.5 NFAs mit ɛ-übergängen 2.6 Minimale DFAs und der
MehrTheoretische Informatik I
heoretische Informatik I Einheit 2 Endliche Automaten & Reguläre Sprachen. Deterministische endliche Automaten 2. Nichtdeterministische Automaten 3. Reguläre Ausdrücke 4. Grammatiken 5. Eigenschaften regulärer
MehrKlausur: Berechenbarkeit und Komplexität (Niedermeier/Chen/Froese/Sorge, Sommersemester 2016)
Technische Universität Berlin, Berlin, 28.07.2016 Name:... Matr.-Nr.:... Klausur: Berechenbarkeit und Komplexität (Niedermeier/Chen/Froese/Sorge, Sommersemester 2016) Einlesezeit: Bearbeitungszeit: Max.
Mehr1 Prädikatenlogik: Korrektheit, Vollständigkeit, Entscheidbarkeit
1 Prädikatenlogik: Korrektheit, Vollständigkeit, Entscheidbarkeit 1.1 Korrektheit Mit dem Kalkül der Prädikatenlogik, z.b. dem Resolutionskalkül, können wir allgemeingültige Sätze beweisen. Diese Sätze
MehrEinführung in die Informatik Turing Machines
Einführung in die Informatik Turing Machines Eine abstrakte Maschine zur Präzisierung des Algorithmenbegriffs Wolfram Burgard Cyrill Stachniss 1/14 Motivation und Einleitung Bisher haben wir verschiedene
MehrWir suchen Antworten auf die folgenden Fragen: Was ist Berechenbarkeit? Wie kann man das intuitiv Berechenbare formal fassen?
Einige Fragen Ziel: Wir suchen Antworten auf die folgenden Fragen: Wie kann man das intuitiv Berechenbare formal fassen? Was ist ein Algorithmus? Welche Indizien hat man dafür, dass ein formaler Algorithmenbegriff
MehrDeterministische und nichtdeterministische Turing-Maschinen, Typ1- und Typ0-Sprachen
Dr. Sebastian Bab WiSe 12/13 Theoretische Grundlagen der Informatik für TI Termin: VL 15 + 16 vom 17.12.2012 und 20.12.2012 Deterministische und nichtdeterministische Turing-Maschinen, Typ1- und Typ0-Sprachen
MehrTheoretische Informatik für Wirtschaftsinformatik und Lehramt
Theoretische Informatik für Wirtschaftsinformatik und Lehramt Universelle Turingmaschinen und Church sche These Priv.-Doz. Dr. Stefan Milius stefan.milius@fau.de Theoretische Informatik Friedrich-Alexander
MehrKapitel 3: Reguläre Grammatiken und Endliche. Automaten
Kapitel 3: Reguläre Grammatiken und Endliche Automaten Prof.-Dr. Peter Brezany Institut für Softwarewissenschaft Universität Wien, Liechtensteinstraße 22 090 Wien Tel. : 0/4277 38825 E-mail : brezany@par.univie.ac.at
Mehr1. Klausur zur Vorlesung Informatik III Wintersemester 2003/2004. Mit Lösung!
Universität Karlsruhe Theoretische Informatik Fakultät für Informatik WS 23/4 ILKD Prof. Dr. D. Wagner 2. Februar 24. Klausur zur Vorlesung Informatik III Wintersemester 23/24 Mit Lösung! Beachten Sie:
MehrKlausur zur Vorlesung Informatik III Wintersemester 2007/2008
Institut für Theoretische Informatik Lehrstuhl Prof. Dr. D. Wagner Klausur zur Vorlesung Informatik III Wintersemester 2007/2008 Hier Aufkleber mit Name und Matrikelnr. anbringen Vorname: Nachname: Matrikelnummer:
MehrFragen 1. Muss eine DTM ein Wort zu Ende gelesen haben, um es zu akzeptieren? a) Ja! b) Nein!
4 Turingmaschinen Eingabeband nicht nur lesen, sondern auch schreiben kann und die zudem mit ihrem Lese-Schreib-Kopf (LSK) nach links und rechts gehen kann. Das Eingabeband ist zudem in beide Richtungen
MehrLaufzeit einer DTM, Klasse DTIME
Laufzeit einer DTM, Klasse DTIME Definition Laufzeit einer DTM Sei M eine DTM mit Eingabealphabet Σ, die bei jeder Eingabe hält. Sei T M (w) die Anzahl der Rechenschritte d.h. Bewegungen des Lesekopfes
MehrTuringmaschinen. Sabine Kuske: Turingmaschinen; 23.Juni 2008
1 Turingmaschinen Von Alan Turing in den 30er Jahren dieses Jahrhunderts eingeführt Eines der ältesten Berechenbarkeitsmodelle Idee: den mechanischen Anteil des Rechnens mit Bleistift und Radiergummi auf
MehrHauptklausur zur Vorlesung Theoretische Grundlagen der Informatik Wintersemester 2011/2012
Institut für Theoretische Informatik Lehrstuhl Prof. Dr. D. Wagner Hauptklausur zur Vorlesung Theoretische Grundlagen der Informatik Wintersemester 2011/2012 Hier Aufkleber mit Name und Matrikelnr. anbringen
MehrEinführung in Berechenbarkeit, Komplexität und formale Sprachen
Johannes Blömer Skript zur Vorlesung Einführung in Berechenbarkeit, Komplexität und formale Sprachen Universität Paderborn Wintersemester 2011/12 Inhaltsverzeichnis 1 Einleitung 2 1.1 Ziele der Vorlesung...................................
MehrEndliche Automaten. Endliche Automaten 1 / 102
Endliche Automaten Endliche Automaten 1 / 102 Endliche Automaten Endliche Automaten erlauben eine Beschreibung von Handlungsabläufen: Wie ändert sich ein Systemzustand in Abhängigkeit von veränderten Umgebungsbedingungen?
MehrEinführung in die Theoretische Informatik
Technische Universität München Fakultät für Informatik Prof. Tobias Nipkow, Ph.D. Sascha Böhme, Lars Noschinski Sommersemester 2011 Lösungsblatt 9 25. Juli 2011 Einführung in die Theoretische Informatik
MehrUnentscheidbarkeit von Problemen mittels Turingmaschinen
Unentscheidbarkeit von Problemen mittels Turingmaschinen Daniel Roßberg 0356177 Roland Schatz 0355521 2. Juni 2004 Zusammenfassung In dieser Arbeit befassen wir uns mit der Unentscheidbarkeit von Problemen
MehrDiskrete Mathematik II
Diskrete Mathematik II Alexander May Fakultät für Mathematik Ruhr-Universität Bochum Sommersemester 2011 DiMa II - Vorlesung 01-04.04.2011 1 / 252 Organisatorisches Vorlesung: Mo 12-14 in HZO 70, Di 09-10
MehrTheoretische Informatik SS 03 Übung 3
Theoretische Informatik SS 03 Übung 3 Aufgabe 1 a) Sind die folgenden Funktionen f : partiell oder total: f(x, y) = x + y f(x, y) = x y f(x, y) = x y f(x, y) = x DIV y? Hierbei ist x DIV y = x y der ganzzahlige
MehrWS06/07 Referentin: Katharina Blinova. Formale Sprachen. Hauptseminar Intelligente Systeme Dozent: Prof. Dr. J. Rolshoven
WS06/07 Referentin: Katharina Blinova Formale Sprachen Hauptseminar Intelligente Systeme Dozent: Prof. Dr. J. Rolshoven 1. Allgemeines 2. Formale Sprachen 3. Formale Grammatiken 4. Chomsky-Hierarchie 5.
Mehr7. Übungsblatt zu Theoretische Grundlagen der Informatik im WS 2015/16
Karlsruher Institut für Technologie Institut für Theoretische Informatik Prof. Dr. Peter Sanders L. Hübschle-Schneider, T. Maier 7. Übungsblatt zu Theoretische Grundlagen der Informatik im WS 2015/16 http://algo2.iti.kit.edu/tgi2015.php
MehrKlassische Informationstheorie: Berechenbarkeit und Komplexität
Klassische Informationstheorie: Berechenbarkeit und Komplexität Christian Slupina 1. Institut für Theoretische Physik Datum: 12.Juli 2011 Inhalt Gedankenexperiment: Die Turingmaschine Standard-Turingmaschinen
MehrAuffrischung Einige (wenige) Grundlagen der Theoretischen Informatik
Logik, Berechenbarkeit und Komplexität Sommersemester 2008 Fachhochschule Wiesbaden Prof. Dr. Steffen Reith Auffrischung Einige (wenige) Grundlagen der Theoretischen Informatik 1 Turingmaschinen - Ein
MehrFormale Sprachen und endliche Automaten
Formale Sprachen und endliche Automaten Formale Sprachen Definition: 1 (Alphabet) Ein Alphabet Σ ist eine endliche, nichtleere Menge von Zeichen oder Symbolen. Ein Wort über dem Alphabet Σ ist eine endliche
MehrEinführung in die Theoretische Informatik
Technische Universität München Fakultät für Informatik Prof. Tobias Nipkow, Ph.D. Dr. Werner Meixner, Dr. Alexander Krauss Sommersemester 2010 Lösungsblatt 11 15. Juli 2010 Einführung in die Theoretische
Mehr2.5 Halteproblem und Unentscheidbarkeit
38 25 Halteproblem und Unentscheidbarkeit Der Berechenbarkeitsbegriff ist auf Funktionen zugeschnitten Wir wollen nun einen entsprechenden Begriff für Mengen einführen Definition 255 Eine Menge A Σ heißt
MehrTheoretische Informatik I
heoretische Informatik I Einheit 2 Endliche Automaten & Reguläre Sprachen. Deterministische endliche Automaten 2. Nichtdeterministische Automaten 3. Reguläre Ausdrücke 4. Grammatiken 5. Eigenschaften regulärer
MehrAlgorithmen mit konstantem Platzbedarf: Die Klasse REG
Algorithmen mit konstantem Platzbedarf: Die Klasse REG Sommerakademie Rot an der Rot AG 1 Wieviel Platz brauchen Algorithmen wirklich? Daniel Alm Institut für Numerische Simulation Universität Bonn August
MehrEinführung in die Theoretische Informatik
Technische Universität München Fakultät für Informatik Prof. Tobias Nipkow, Ph.D. Sascha Böhme, Lars Noschinski Sommersemester 2011 Lösungsblatt 8 18. Juli 2011 Einführung in die Theoretische Informatik
MehrFormale Sprachen und Automaten
Turingmaschinen Formale Sprachen und Automaten Das Konzept der Turingmaschine wurde von dem Englischen Mathematiker Alan M. Turing (1912-1954) ersonnen. Turingmaschinen, Typ-0- und Typ-1-Grammatiken Der
MehrAusarbeitung zum Thema Turing Maschine bei Prof. Dr. Detlef Wotschke Veranstaltung: Beschreibungskomplexität (Proseminar)
Ausarbeitung zum Thema Turing Maschine bei Prof. Dr. Detlef Wotschke Veranstaltung: Beschreibungskomplexität (Proseminar) ThorstenTimmer, SS 2005 18. April 2005 1 2 INHALTSVERZEICHNIS Inhaltsverzeichnis
Mehr11. Übungsblatt. x y(top(push(x, y)) = y)
Logik, Berechenbarkeit und Komplexität Sommersemester 2012 Hochschule RheinMain Prof. Dr. Steffen Reith 11. Übungsblatt 1. Ein Keller (engl. stack) ist eine bekannte Datenstruktur. Sei die Signatur S =
Mehr8. Turingmaschinen und kontextsensitive Sprachen
8. Turingmaschinen und kontextsensitive Sprachen Turingmaschinen (TM) von A. Turing vorgeschlagen, um den Begriff der Berechenbarkeit formal zu präzisieren. Intuitiv: statt des Stacks bei Kellerautomaten
MehrTheoretische Grundlagen der Informatik
Theoretische Grundlagen der Informatik Vorlesung am 20. November 2014 INSTITUT FÜR THEORETISCHE 0 KIT 20.11.2014 Universität des Dorothea Landes Baden-Württemberg Wagner - Theoretische und Grundlagen der
MehrTHEORETISCHE INFORMATIK UND LOGIK
THEORETISCHE INFORMATIK UND LOGIK 4. Vorlesung: Das Halteproblem und Reduktionen Markus Krötzsch Lehrstuhl Wissensbasierte Systeme TU Dresden, 19. April 2017 Ankündigung Wegen großer Nachfrage wird eine
MehrGrundlagen der Theoretischen Informatik
Grundlagen der Theoretischen Informatik Turingmaschinen und rekursiv aufzählbare Sprachen (II) 2.07.2015 Viorica Sofronie-Stokkermans e-mail: sofronie@uni-koblenz.de 1 Übersicht 1. Motivation 2. Terminologie
MehrGTI. Hannes Diener. 6. Juni - 13. Juni. ENC B-0123, diener@math.uni-siegen.de
GTI Hannes Diener ENC B-0123, diener@math.uni-siegen.de 6. Juni - 13. Juni 1 / 49 Die Turingmaschine war das erste (bzw. zweite) formale Modell der Berechenbarkeit. Sie wurden bereits 1936 (also lange
MehrFormale Methoden 1. Gerhard Jäger 9. Januar Uni Bielefeld, WS 2007/2008 1/23
1/23 Formale Methoden 1 Gerhard Jäger Gerhard.Jaeger@uni-bielefeld.de Uni Bielefeld, WS 2007/2008 9. Januar 2008 2/23 Automaten (informell) gedachte Maschine/abstraktes Modell einer Maschine verhält sich
MehrAutomatentheorie und formale Sprachen
Automatentheorie und formale Sprachen VL 8 Chomsky-Grammatiken Kathrin Hoffmann 23. Mai 2012 Hoffmann (HAW Hamburg) Automatentheorie und formale Sprachen 23.5. 2012 250 Wortproblem Wortproblem ist das
MehrGrundlagen der Theoretischen Informatik / Einführung in die Theoretische Informatik I
Vorlesung Grundlagen der Theoretischen Informatik / Einführung in die Theoretische Informatik I Bernhard Beckert Institut für Informatik Sommersemester 2007 B. Beckert Grundlagen d. Theoretischen Informatik:
MehrBerechenbarkeit und Komplexität
Berechenbarkeit und Komplexität Vorlesung SS 2013 1. Einführung I. Berechenbarkeitsbegriff, typische Fragen: wann ist eine Funktion berechenbar? wie lässt sich der intuitive Berechenbarkeitsbegriff formal
MehrKapitel 2 Das Modell der endlichen Automaten
Kapitel 2 Das Modell der endlichen Automaten Wenn man ein Berechnungsmodell beschreiben will, muss man folgende Fragen beantworten (siehe auch das Modul Geschichte der Informatik und Begriffsbildung in
Mehr11.3 Eindimensionale Turingmaschinen
11.3 Eindimensionale Turingmaschinen 156 11.3 Eindimensionale Turingmaschinen Turing ging vom schriftlichen Rechnen aus, also vom Beschreiben eines Papiers mit einem Stift. Wollen wir etwas aufschreiben,
MehrLOOP-Programme: Syntaktische Komponenten
LOOP-Programme: Syntaktische Komponenten LOOP-Programme bestehen aus folgenden Zeichen (syntaktischen Komponenten): Variablen: x 0 x 1 x 2... Konstanten: 0 1 2... Operationssymbole: + Trennsymbole: ; :=
MehrEinführung in die Theoretische Informatik
Technische Universität München Fakultät für Informatik Prof. Tobias Nipkow, Ph.D. Dr. Werner Meixner, Dr. Alexander Krauss Sommersemester 2010 Lösungsblatt 9 2. Juli 2010 Einführung in die Theoretische
Mehr7 Endliche Automaten. Reimund Albers Papierfalten Kapitel 7 Endliche Automaten 103
Reimund Albers Papierfalten Kapitel 7 Endliche Automaten 103 7 Endliche Automaten Ein erstes Beispiel Ganz im Sinn der vorangegangenen Kapitel machen wir wieder Anleihen in einem wohl etablierten Gebiet.
MehrInduktive Definition
Rechenregeln A B = B A A (B C) = (A B) C A (B C) = (A B) C A (B C) = A B A C (B C) A = B A C A {ε} A = A A {ε} = A (A {ε}) = A (A ) = A A A = A + A A = A + A + {ε} = A Beispiel. Real-Zahlen = {0,..., 9}
MehrGrundbegriffe der Informatik Tutorium 10
Grundbegriffe der Informatik Tutorium 10 Tutorium Nr. 32 Philipp Oppermann 17. Januar 2014 KARLSRUHER INSTITUT FÜR TECHNOLOGIE KIT Universität des Landes Baden-Württemberg und nationales Forschungszentrum
MehrEntscheidungsprobleme
Entscheidungsprobleme übliche Formulierung gegeben: Eingabe x aus einer Grundmenge U Frage: Hat x eine bestimmte Eigenschaft P? Beispiel: gegeben: Frage: n N Ist n eine Primzahl? Formalisierung: Grundmenge
MehrTHIA - Übungsblatt 2.
THIA - Übungsblatt 2. Aufgabe 12 (Eine einfache Sprache). Endliche Ziffernfolgen, die mit einer 0 beginnen, auf die mindestens eine weitere Ziffer folgt, wobei nur die Ziffern 0,..., 7 vorkommen, sollen
MehrTheoretische Grundlagen der Informatik. Vorlesung am 02. November INSTITUT FÜR THEORETISCHE INFORMATIK
Theoretische Grundlagen der Informatik Vorlesung am 2. November 27 2..27 Dorothea Wagner - Theoretische Grundlagen der Informatik KIT Die Forschungsuniversität in der Vorlesung am 2. November 27 Helmholtz-Gemeinschaft
MehrKontextsensitive und Typ 0 Sprachen Slide 2. Die Turingmaschine
Kontextsensitive und Typ 0 Sprachen Slide 2 Die Turingmaschine DTM = Deterministische Turingmaschine NTM = Nichtdeterministische Turingmaschine TM = DTM oder NTM Intuitiv gilt: DTM = (DFA + dynamischer
MehrUnentscheidbarkeitssätze der Logik
Unentscheidbarkeitssätze der Logik Elmar Eder () Unentscheidbarkeitssätze der Logik 1 / 30 Die Zahlentheorie ist nicht formalisierbar Satz (Kurt Gödel) Zu jedem korrekten formalen System der Zahlentheorie
MehrFORMALE SYSTEME. 8. Vorlesung: Minimale Automaten. TU Dresden, 6. November Markus Krötzsch Lehrstuhl Wissensbasierte Systeme
FORMALE SYSTEME 8. Vorlesung: Minimale Automaten Markus Krötzsch Lehrstuhl Wissensbasierte Systeme TU Dresden, 6. November 2017 Rückblick Markus Krötzsch, 6. November 2017 Formale Systeme Folie 2 von 26
Mehr2. Übungsblatt 6.0 VU Theoretische Informatik und Logik
2. Übungsblatt 6.0 VU Theoretische Informatik und Logik 25. September 2013 Aufgabe 1 Geben Sie jeweils eine kontextfreie Grammatik an, welche die folgenden Sprachen erzeugt, sowie einen Ableitungsbaum
MehrGrundlagen der Theoretischen Informatik
Grundlagen der Theoretischen Informatik Turingmaschinen und rekursiv aufzählbare Sprachen (V) 15.07.2015 Viorica Sofronie-Stokkermans e-mail: sofronie@uni-koblenz.de 1 Übersicht 1. Motivation 2. Terminologie
MehrEva Lugstein Michaela Peterhansl Sophie Wirnsberger Cornelia Zenz
Eva Lugstein Michaela Peterhansl Sophie Wirnsberger Cornelia Zenz Alan Turing: Biographie Turingmaschine Automatentheorie Idee Formale Definition Beispiele Bau und Implementierung Alan Mathison Turing
MehrTheoretische Grundlagen der Informatik. Vorlesung am 07. November INSTITUT FÜR THEORETISCHE INFORMATIK
Theoretische Grundlagen der Informatik 0 07.11.2017 Torsten Ueckerdt - Theoretische Grundlagen der Informatik KIT Die Forschungsuniversität in der Helmholtz-Gemeinschaft www.kit.edu Frage Frage: Ist der
Mehr1 Endliche Automaten mit Ausgabe
1.1 Autokorrektur und Smileys 9 Theorie bedeutet meist, dass die Bestandteile und Eigenschaften von Systemen auf das Elementare reduziert werden, um deren Prinzipien, Zusammenhänge, Möglichkeiten und Grenzen
MehrEndliche Automaten. Endliche Automaten 1 / 115
Endliche Automaten Endliche Automaten 1 / 115 Endliche Automaten Endliche Automaten erlauben eine Beschreibung von Handlungsabläufen: Wie ändert sich ein Systemzustand in Abhängigkeit von veränderten Umgebungsbedingungen?
Mehr