Theoretische Grundlagen der Informatik. Vorlesung am 16. November INSTITUT FÜR THEORETISCHE INFORMATIK

Ähnliche Dokumente
Theoretische Grundlagen der Informatik

Theoretische Grundlagen der Informatik

Theoretische Grundlagen der Informatik

Theoretische Grundlagen der Informatik

Proseminar Komplexitätstheorie P versus NP Wintersemester 2006/07. Nichtdeterministische Turingmaschinen und NP

Theoretische Grundlagen der Informatik

Theoretische Grundlagen der Informatik

Theoretische Grundlagen der Informatik

Entscheidungsprobleme

Theoretische Informatik 1

Musterlösung Informatik-III-Klausur

Übungsblatt 3. Vorlesung Theoretische Grundlagen der Informatik im WS 17/18

1 Einführung. 2 Typ-0- und Typ-1-Sprachen. 3 Berechnungsmodelle. 4 Unentscheidbarkeit. 5 Unentscheidbare Probleme. 6 Komplexitätstheorie

Teil III. Komplexitätstheorie

Klausur: Berechenbarkeit und Komplexität (Niedermeier/Chen/Froese/Sorge, Sommersemester 2016)

1 Einführung. 2 Typ-0- und Typ-1-Sprachen. 3 Berechnungsmodelle. 4 Unentscheidbarkeit. 5 Unentscheidbare Probleme. 6 Komplexitätstheorie

Laufzeit einer DTM, Klasse DTIME

Universelle Turingmaschinen

Theoretische Informatik. nichtdeterministische Turingmaschinen NDTM. Turingmaschinen. Rainer Schrader. 29. April 2009

Klausur zur Vorlesung Informatik III Wintersemester 2007/2008

2.5 Halteproblem und Unentscheidbarkeit

Präsenzübung Berechenbarkeit und Komplexität

abgeschlossen unter,,,, R,

Falls H die Eingabe verwirft, so wissen wir, dass M bei Eingabe w nicht hält. M hält im verwerfenden Haltezustand. Beweis:

THEORETISCHE INFORMATIK UND LOGIK

Entscheidungsprobleme

Beispiel: NTM. M = ({q 0,q 1,q 2 }, {0, 1}, {0, 1, #},δ, q 0, #, {q 2 }) q 2

Theoretische Grundlagen der Informatik

Die Klasse NP und die polynomielle Reduktion

12. Woche: Verifizierer, nicht-deterministische Turingmaschine, Klasse NP

Einführung in die Theoretische Informatik

11. Woche: Turingmaschinen und Komplexität Rekursive Aufzählbarkeit, Entscheidbarkeit Laufzeit, Klassen DTIME und P

Die Unentscheidbarkeit extensionaler Eigenschaften von Turingmaschinen: der Satz von Rice

Grundlagen der Theoretischen Informatik

Theoretische Grundlagen der Informatik

7. Übung TGI. Lorenz Hübschle-Schneider, Tobias Maier INSTITUT FÜR THEORETISCHE INFORMATIK, PROF. SANDERS. 1 Lorenz Hübschle-Schneider, Tobias Maier

Theoretische Grundlagen der Informatik

P, NP und NP -Vollständigkeit

Aufgabe Mögliche Punkte Erreichte Punkte a b c d Σ a b c d Σ x1 13

Polynomielle Verifizierer und NP

Wir haben eine Beziehung zwischen entscheidbar und rekursiv aufzählbar hergeleitet.

1. Klausur zur Vorlesung Informatik III Wintersemester 2003/2004. Mit Lösung!

Die Komplexitätsklassen P und NP

Einführung in die Theoretische Informatik

Theoretische Grundlagen der Informatik. Vorlesung am 02. November INSTITUT FÜR THEORETISCHE INFORMATIK

Zeitkomplexität (1) Proseminar Theoretische Informatik. Proseminar Theoretische Informatik: Lisa Dohrmann 1

Klausur SoSe Juli 2013

Theoretische Informatik. Exkurs: Komplexität von Optimierungsproblemen. Optimierungsprobleme. Optimierungsprobleme. Exkurs Optimierungsprobleme

Unentscheidbare Probleme: Diagonalisierung

Probleme aus NP und die polynomielle Reduktion

Theorie der Informatik

Hamiltonsche Graphen

Theoretische Informatik. Probabilistische Turingmaschinen PTM PTM. Rainer Schrader. 10. Juni 2009

Theoretische Grundlagen der Informatik. Vorlesung am 07. November INSTITUT FÜR THEORETISCHE INFORMATIK

Dank. Grundlagen der Theoretischen Informatik / Einführung in die Theoretische Informatik I. Beispiel einer nicht berechenbaren Funktion: Busy Beaver

Ausgewählte unentscheidbare Sprachen

Theoretische Grundlagen der Informatik

Hauptklausur zur Vorlesung Theoretische Grundlagen der Informatik Wintersemester 2011/2012

Theorie der Informatik

Turing: prinzipielle Berechenbarkeit Abschnitt 4.2. Turingmaschinen: DTM Abschnitt 4.2. DTM: Akzeptieren und Entscheiden Abschnitt 4.

Software Engineering Ergänzung zur Vorlesung

Kapitel 5. Entscheidbarkeit und Berechenbarkeit. 5.1 Entscheidbarkeit

Der Lese-Schreib-Kopf kann auch angehalten werden (H). Die Verarbeitung ist dann beendet.

Hier ist ein einfaches Turingprogramm. Außer dem Leerzeichen ist das Band nur mit. 1 belegt.

Turing Maschine. Thorsten Timmer. SS 2005 Proseminar Beschreibungskomplexität bei Prof. D. Wotschke. Turing Maschine SS 2005 p.

Übungsblatt 5. Vorlesung Theoretische Grundlagen der Informatik im WS 17/18

Einführung (1/3) Vorlesungen zur Komplexitätstheorie: Reduktion und Vollständigkeit (1) Vorlesungen zur Komplexitätstheorie.

Stefan Schmid TU Berlin & T-Labs, Berlin, Germany. Reduktionen in der Berechenbarkeitstheorie

Grundlagen der Theoretischen Informatik

Universität Karlsruhe Institut für Theoretische Informatik. Klausur: Informatik III

Wir müssen wissen, und wir werden wissen.

Klassische Informationstheorie: Berechenbarkeit und Komplexität

Einführung in Berechenbarkeit, Komplexität und Formale Sprachen

Theoretische Grundlagen der Informatik

Theoretische Informatik 1

Theoretische Informatik 1

PROBEKLAUSUR SoSe 2016

Lösungen zur Vorlesung Berechenbarkeit und Komplexität

Lösung zur Klausur. Grundlagen der Theoretischen Informatik im WiSe 2003/2004

Unentscheidbarkeitssätze der Logik

Einführung in Berechenbarkeit, Komplexität und Formale Sprachen

Übungsblatt 6. Vorlesung Theoretische Grundlagen der Informatik im WS 17/18

11.1 Kontextsensitive und allgemeine Grammatiken

Grundbegriffe der Informatik Tutorium 13

Deterministische und nichtdeterministische Turing-Maschinen, Typ1- und Typ0-Sprachen

Approximationsalgorithmen für NP-harte Optimierungsprobleme

Unentscheidbarkeit. Vorlesung Berechenbarkeit und Komplexität alias Theoretische Informatik: Komplexitätstheorie und effiziente Algorithmen

Approximationsalgorithmen für NP-harte Optimierungsprobleme

1 Einführung. 2 Typ-0- und Typ-1-Sprachen. 3 Berechnungsmodelle. 4 Unentscheidbarkeit. 5 Unentscheidbare Probleme. 6 Komplexitätstheorie

Unentscheidbarkeit von Problemen mittels Turingmaschinen

Rekursiv aufzählbare Sprachen

13. Woche: NP-Vollständigkeit Satz von Cook-Levin Anwendungen in der Kryptographie

Einführung in die Theoretische Informatik I/ Grundlagen der Theoretischen Informatik. SS 2007 Jun.-Prof. Dr. Bernhard Beckert Ulrich Koch

2. Klausur zur Vorlesung Theoretische Grundlagen der Informatik Wintersemester 2016/2017

Formale Methoden 2. Gaetano Geck Lehrstuhl I Logik in der Informatik WS 2015/2016

Grundlagen der Theoretischen Informatik

Fragen 1. Muss eine DTM ein Wort zu Ende gelesen haben, um es zu akzeptieren? a) Ja! b) Nein!

Formale Grundlagen der Informatik 1 Kapitel 23 NP-Vollständigkeit (Teil 2)

Kapitel: Die Chomsky Hierarchie. Die Chomsky Hierarchie 1 / 14

Formale Sprachen und endliche Automaten

Transkript:

Theoretische Grundlagen der Informatik 0 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik KIT Die Forschungsuniversität in der Helmholtz-Gemeinschaft www.kit.edu

KIT-Gedenkfeier für die bei einem Busunfall in Peru tödlich verunglückten Studentinnen und Studenten unserer Fakultät: Freitag, 17.11. 2017, 13:15 Uhr (bis ca. 13:45 Uhr) Trauerecke am Roten Platz (Platz hinter dem Studentenzentrum AKK, Geb. 30.81, Richtung Forum) 1 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Universelle Sprache Die universelle Sprache L u über {0, 1} ist definiert durch L u := {wv v L(T w )}. L u ist also die Menge aller Wörter wv für die T w bei der Eingabe v hält und v akzeptiert. Satz (Unentscheidbarkeit der Universellen Sprache): Die Sprache L u ist nicht entscheidbar. 2 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Universelle Sprache Satz (Unentscheidbarkeit der Universellen Sprache): Die Sprache L u := {wv v L(T w )} ist nicht entscheidbar. Beweis: Wir zeigen, dass L u eine Verallgemeinerung von L c d ist. Wir nehmen an, dass es eine TM gibt, die L u entscheidet. Dann zeigen wir, dass wir damit auch L c d entscheiden können. Wir gehen wie folgt vor: Berechne das i, für das w = w i. Betrachte die durch w i codierte Turing-Maschine M i. Wende die Turing-Maschine für L u auf M i w i an. Wäre L u entscheidbar, so auch L c d im Widerspruch zum letzten Korollar. 2 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Universelle Sprache Satz (Semi-Entscheidbarkeit der Universellen Sprache): Die Sprache L u := {wv v L(T w )} ist semi-entscheidbar. 3 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Universelle Sprache Satz (Semi-Entscheidbarkeit der Universellen Sprache): Die Sprache L u := {wv v L(T w )} ist semi-entscheidbar. Beweis: Wir benutzen die universelle Turing-Maschine, mit der Eingabe wv: Falls T w die Eingabe v akzeptiert, geschieht dies nach endlich vielen Schritten und die universelle Turing-Maschine akzeptiert wv. Falls T w die Eingabe v nicht akzeptiert, wird wv von der universellen Turing-Maschine ebenfalls nicht akzeptiert. Dies ist unabhängig davon, ob die Simulation stoppt oder nicht. 3 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Universelle Sprache Satz (Semi-Entscheidbarkeit der Universellen Sprache): Die Sprache L u := {wv v L(T w )} ist semi-entscheidbar. Beweis: Wir benutzen die universelle Turing-Maschine, mit der Eingabe wv: Falls T w die Eingabe v akzeptiert, geschieht dies nach endlich vielen Schritten und die universelle Turing-Maschine akzeptiert wv. Falls T w die Eingabe v nicht akzeptiert, wird wv von der universellen Turing-Maschine ebenfalls nicht akzeptiert. Dies ist unabhängig davon, ob die Simulation stoppt oder nicht. Bemerkung: Die Begriffe entscheidbar und semi-entscheidbar unterscheiden sich tatsächlich. 3 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Satz von Rice - Motivation Wir haben bisher gezeigt, dass wir kein Programm schreiben können, das für ein Turing-Maschinen-Programm M und eine Eingabe w entscheidet, ob M auf der Eingabe w hält. Wir werden im Folgenden sehen, dass wir aus einem Programm im Allgemeinen keine nicht-trivialen Eigenschaften der von dem Programm realisierten Funktion ableiten können. 4 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Satz von Rice Satz (Satz von Rice): Sei R die Menge der von Turing-Maschinen berechenbaren Funktionen und S eine nicht-triviale Teilmenge von R ( = S = R). Dann ist die Sprache L(S) := { M M berechnet eine Funktion aus S} nicht entscheidbar. 5 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Satz von Rice Satz (Satz von Rice): Sei R die Menge der von Turing-Maschinen berechenbaren Funktionen und S eine nicht-triviale Teilmenge von R ( = S = R). Dann ist die Sprache L(S) := { M M berechnet eine Funktion aus S} nicht entscheidbar. Beweisskizze: Zeige: H ε := { M M hält auf der Eingabe ε} ist unentscheidbar Zeige: H c ε ist unentscheidbar Führe den Widerspruchsbeweis für die Unentscheidbarkeit von L(S): Konstruiere TM für H c ε unter Benutzung von TM M für L(S) 5 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Bemerkungen zum Satz von Rice Der Satz von Rice hat weitreichende Konsequenzen: Es ist für Programme nicht entscheidbar, ob die durch sie definierte Sprache endlich, leer, unendlich oder ganz Σ ist. Wir haben hier nur die Unentscheidbarkeit von L d direkt bewiesen. Die anderen Beweise folgten dem folgenden Schema: Um zu zeigen, dass ein Problem A unentscheidbar ist, zeigen wir, wie man mit einem Entscheidungsverfahren für A ein bekanntermaßen unentscheidbares Problem B entscheiden kann. Dies liefert den gewünschten Widerspruch. 6 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Das Post sche Korrespondenzproblem Post sches Korrespondenzproblems Gegeben ist endliche Folge von Wortpaaren K = ((x 1, y 1 ),..., (x n, y n )) über einem endlichen Alphabet Σ. Es gilt x i = ε und y i = ε. Gefragt ist, ob es eine endliche Folge von Indizes i 1,..., i k {1,..., n} gibt, so dass x i1... x ik = y i1... y ik gilt. Beispiele K = ((1, 111), (10111, 10), (10, 0)) hat die Lösung (2, 1, 1, 3), denn es gilt: x 2 x 1 x 1 x 3 = 101111110 = y 2 y 1 y 1 y 3 K = ((10, 101), (011, 11), (101, 011)) hat keine Lösung K = ((001, 0), (01, 011), (01, 101), (10, 001)) hat eine Lösung der Länge 66. 7 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Das Post sche Korrespondenzproblem Satz (Unentscheidbarkeit des PKP): Das Post sche Korrespondezproblem ist nicht entscheidbar Beweis: Beweis über Nicht-Entscheidbarkeit des Halteproblems. 8 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Eigenschaften von (semi-)entscheibaren Sprachen Die entscheidbaren Sprachen sind abgeschlossen unter Komplementbildung, Schnitt und Vereinigung. Die semi-entscheidbaren Sprachen sind abgeschlossen unter Schnitt und Vereinigung, aber nicht unter Komplementbildung. Satz: Sei L Σ und L c = Σ \ L. Dann gilt L entscheidbar gdw. L c entscheidbar. L und L c semi-entscheidbar gdw. L entscheidbar. Beweis: Übung und Tutorien. 9 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Kapitel Komplexitätstheorie 10 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Komplexitätstheorie Fragestellung bisher: Ist eine Sprache L entscheidbar oder nicht? Ist eine Funktion berechenbar oder nicht? Benutzung von deterministischen Turing-Maschinen. In diesem Kapitel: Wie effizient kann ein Problem gelöst werden? Betrachtung von nichtdeterministischen Turing-Maschinen. Frage (P vs. NP): Gibt es einen wesentlichen Effizienzgewinn beim Übergang von der deterministischen Turing-Maschine zur nichtdeterministischen Turing-Maschine? 11 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Wie sieht ein Problem aus? Beispiel: Traveling Salesman Problem (TSP) Gegeben sei ein vollständiger Graph G = (V, E, c), d.h. V := {1,..., n} E := {{u, v} u, v V, u = v} c : E Z +. Wir betrachten folgende Problemvarianten Optimierungsproblem: Gesucht ist eine Tour (Rundreise), die alle Elemente aus V enthält und minimale Gesamtlänge unter allen solchen Touren hat. Optimalwertproblem: Gesucht ist die Länge einer minimalen Tour. Entscheidungsproblem: Gegeben sei zusätzlich auch ein Parameter k Z +. Die Frage ist nun: Gibt es eine Tour, deren Länge höchstens k ist? 12 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Wie sieht ein Problem aus? Wir betrachten folgende Problemvarianten Optimierungsproblem: Gesucht ist eine Tour (Rundreise), die alle Elemente aus V enthält und minimale Gesamtlänge unter allen solchen Touren hat. Optimalwertproblem: Gesucht ist die Länge einer minimalen Tour. Entscheidungsproblem: Gegeben sei zusätzlich auch ein Parameter k Z +. Die Frage ist nun: Gibt es eine Tour, deren Länge höchstens k ist? Bemerkung: Mit einer Lösung des Optimierungsproblems kann man leicht auch das Optimalwertproblem und das Entscheidungsproblem lösen. Mit einer Lösung des Optimalwertproblems kann man leicht auch das Entscheidungsproblem lösen. 12 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Definition: Problem Ein Problem Π ist gegeben durch: eine allgemeine Beschreibung aller vorkommenden Parameter; eine genaue Beschreibung der Eigenschaften, die die Lösung haben soll. Ein Problembeispiel I (Instanz) von Π erhalten wir, indem wir die Parameter von Π festlegen. 13 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Definition: Kodierungsschema Wir interessieren uns für die Laufzeit von Algorithmen. Diese wird in der Größe des Problems gemessen. Die Größe eines Problems ist abhängig von der Beschreibung oder Kodierung der Problembeispiele Ein Kodierungsschema s ordnet jedem Problembeispiel eines Problems eine Zeichenkette oder Kodierung über einem Alphabet Σ zu. Die Inputlänge eines Problembeispiels ist die Anzahl des Symbole seiner Kodierung. 14 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Kodierungsschema Es gibt verschiedene Kodierungsschemata für ein bestimmtes Problem. Beispiel: Zahlen können dezimal, binär, unär, usw. kodiert werden. Die Inputlänge von 5127 beträgt dann 4 für dezimal, 13 für binär und 5127 für unär. Wir werden uns auf vernünftige Schemata festlegen: Die Kodierung eines Problembeispiels sollte keine überflüssigen Informationen enthalten. Zahlen sollen binär (oder k-är für k = 1) kodiert sein. 15 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Kodierungsschema Dies bedeutet, die Kodierungslänge einer ganzen Zahl n ist log k n + 1 + 1 =: n (eine 1 benötigt man für das Vorzeichen); einer rationalen Zahl r = p q ist r = p + q ; eines Vektors X = (x 1,..., x n ) ist X := n i=1 x i ; einer Matrix A Q m n ist A := m i=1 n j=1 aij. eines Graphen G = (V, E) kann zum Beispiel durch die Kodierung seiner Adjazenzmatrix, die eines gewichteten Graphen durch die Kodierung der Gewichtsmatrix beschrieben werden. 16 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Äquivalenz von Kodierungsschemata Zwei Kodierungsschemata s 1, s 2 heißen äquivalent bezüglich eines Problems Π, falls es Polynome p 1, p 2 gibt, so dass gilt: ( s 1 (I) = n s 2 (I) p 2 (n)) und ( s 2 (I) = m s 1 (I) p 1 (m)) für alle Problembeispiele I von Π. 17 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Entscheidungsprobleme Ein Entscheidungsproblem Π können wir als Klasse von Problembeispielen D Π auffassen. Eine Teilmenge dieser Klasse ist J Π D Π, die Klasse der Ja Beispiele, d.h. die Problembeispiele deren Antwort Ja ist. Der Rest der Klasse N Π D Π ist die Klasse der Nein Beispiele. 18 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Korrespondenz von Entscheidungsproblemen und Sprachen Ein Problem Π und ein Kodierungsschema s : D Π Σ zerlegen Σ in drei Klassen: Wörter aus Σ, die nicht Kodierung eines Beispiels aus D Π sind, Wörter aus Σ, die Kodierung eines Beispiels I N Π sind, Wörter aus Σ, die Kodierung eines Beispiels I J Π sind. Die dritte Klasse ist die Sprache, die zu Π im Kodierungsschema s korrespondiert. Die zu einem Problem Π und einem Kodierungsschema s zugehörige Sprache ist L[Π, s] := { x Σ } Σ ist das Alphabet zu s und x ist Kodierung eines Ja Beispiels I von Π unter s, d.h. I J Π 19 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Wir betrachten im folgenden deterministische Turing-Maschinen mit zwei Endzuständen q J, q N, wobei q J akzeptierender Endzustand ist. Dann wird die Sprache L M akzeptiert von der Turing-Maschine M, falls L M = {x Σ M akzeptiert x}. Eine deterministische Turing-Maschine M löst ein Entscheidungsproblem Π unter einem Kodierungsschema s, falls M bei jeder Eingabe über dem Eingabe-Alphabet in einem Endzustand endet und L M = L[Π, s] ist. 20 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Zeitkomplexität Für eine deterministische Turing-Maschine M, die für alle Eingaben über dem Eingabe-Alphabet Σ hält, ist die Zeitkomplexitätsfunktion T M : Z + Z + definiert durch T M (n) = max m es gibt eine Eingabe x Σ mit x = n, so dass die Berechnung von M bei Eingabe x m Berechnungsschritte (Übergänge) benötigt, bis ein Endzustand erreicht wird 21 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Klasse P Die Klasse Pist die Menge aller Sprachen L (Probleme), für die eine deterministische Turing-Maschine existiert, deren Zeitkomplexitätsfunktion polynomial ist, d.h. es existiert ein Polynom p mit T M (n) p(n). 22 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Schwierigkeit von Entscheidungs und Optimierungsproblem Satz: Falls es einen Algorithmus A gibt, der das Entscheidungsproblem des TSP in polynomialer Zeit löst, so gibt es auch einen Algorithmus, der das Optimierungsproblem in polynomialer Zeit löst. 23 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Schwierigkeit von Entscheidungs und Optimierungsproblem Satz: Falls es einen Algorithmus A gibt, der das Entscheidungsproblem des TSP in polynomialer Zeit löst, so gibt es auch einen Algorithmus, der das Optimierungsproblem in polynomialer Zeit löst. Beweis: Algorithmus, der das Optimierungsproblem löst. Input: G = (V, E), c ij = c({i, j}) für i, j V := {1,..., n}, Algorithmus A Output: d ij (1 i, ( j ) n), so dass alle bis auf n der d ij -Werte den Wert max c ij + 1 haben. Die restlichen n d ij -Werte haben i,j den Wert c ij und geben genau die Kanten einer optimalen Tour an. 23 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Algorithmus OPT-TOUR (als Beweis) 1/2 berechne m := max c ij; 1 i,j n setze L(ow) := 0 und H(igh) := n m; solange H L > 1 gilt, führe aus: ( 1 falls A n, c, 2 sonst setze L := setze H := ) (H + L) 1 (H + L) 2 1 (H + L) ; 2 = nein ist, + 1; ( binäre Suche ) falls A(n, c, L) = nein ist,setze OPT := H; sonst setze OPT := L; 24 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Algorithmus OPT-TOUR (als Beweis) 2/2 für i = 1... n führe aus für j = 1... n führe aus setze R := c ij ; c ij := m + 1; falls A(n, c, OPT ) = nein ist, setze c ij := R; setze d ij = c ij ; 25 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Bemerkungen zum Algorithmus Die Schleife der binären Suche bricht ab, und danach ist die Differenz H L gleich 1 oder 0, denn: Solange H L > 1, ändert sich bei jedem Schleifendurchlauf einer der Werte H, L: Für H L > 1 gilt, dass L = 12 (H + L) + 1 und H = 12 (H + L) ist. Die Differenz verkleinert sich also mit jedem Durchlauf Da H und L ganzzahlig sind, tritt der Fall H L 1 ein. Nach Abbruch der Schleife gilt H L 0: Eine Differenz zwischen H und L von 0 kann genau durch Erhöhen von L bei einer aktuellen Differenz von 2 bzw. 3 erreicht werden Eine Differenz zwischen H und L von 0 ist minimal (bei einer Differenz von weniger als 2 wird die Schleife nicht mehr betreten). 26 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Laufzeit des Algorithmus A(n, c, k) wird etwa log(n m) mal aufgerufen A(n, c, OPT ) wird etwa n 2 mal aufgerufen. Es finden also O(n 2 + log(nm)) Aufrufe von A statt. Die Inputlänge ist O(n 2 log(max c ij )). Da A polynomial ist, ist dies also auch OPT-TOUR. 27 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Nichtdeterministische Turingmaschine Bei der nichtdeterministischen Turing-Maschine wird die Übergangsfunktion δ zu einer Relation erweitert. Dies ermöglicht Wahlmöglichkeiten und ε Übergänge (vergleiche endliche Automaten). Wir betrachten ein äquivalentes Modell einer nichtdeterministischen Turing-Maschine (NTM), die auf einem Orakel basiert. Dies kommt der Intuition näher. 28 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Nichtdeterministische Turingmaschine... Schreibkopf Lese-/Schreibkopf... Orakel q endliche Kontrolle Nichtdeterministische Turingmaschinen (NTM) werden analog zur DTM durch das Oktupel (Q, Σ,, Γ, s, δ, q J, q N ) beschrieben. haben zusätzlich zu der endlichen Kontrolle mit dem Lese-/Schreibkopf ein Orakelmodul mit einem eigenen Schreibkopf. NTMs haben genau zwei Endzustände q J und q N, wobei q J der akzeptierende Endzustand ist. 29 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Nichtdeterministische Turingmaschine... Schreibkopf Lese-/Schreibkopf... Orakel q endliche Kontrolle Berechnung bei einer nichtdeterministischen Turing-Maschine 1. Stufe: Das Orakelmodul schreibt zunächst ein Trennzeichen in die Zelle direkt vor der Eingabe. Dann weist es seinen Schreibkopf an, Schritt für Schritt entweder ein Symbol zu schreiben und nach links zu gehen oder anzuhalten. Falls der Schreibkopf anhält, wird das Orakelmodul inaktiv, und die endliche Zustandskontrolle wird aktiv. 2. Stufe: Ab jetzt genau wie bei DTM. Das Orakelmodul und sein Schreibkopf sind nicht weiter beteiligt. 29 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Nichtdeterministische Turingmaschine... Schreibkopf Lese-/Schreibkopf... Orakel q endliche Kontrolle Eine nichtdeterministische Turing-Maschine M akzeptiert ein Wort x Σ genau dann, wenn es eine Berechnung gibt, die in q J endet. M akzeptiert die Sprache L Σ genau dann, wenn sie gerade die Wörter aus L akzeptiert. 29 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Übertragung auf Entscheidungsprobleme Π Die Eingabe ist ein Wort aus Σ, zum Beispiel eine Kodierung eines Problembeispiels I D Π. 1. Stufe: Es wird ein Orakel aus Γ berechnet, zum Beispiel ein Lösungsbeispiel für I, also ein Indikator, ob I J Π oder I N Π gilt. 2. Stufe: Hier wird nun dieser Lösungsvorschlag überprüft, d.h. es wird geprüft ob I J Π. Beispiel TSP 1. Stufe: Es wird zum Beispiel eine Permutation σ auf der Knotenmenge V vorgeschlagen. D.h. (σ(1),..., σ(n)), G = (V, E), c und k bilden die Eingabe. 2. Stufe: Es wird nun überprüft, ob σ(v ) eine Tour in G enthält, deren Länge bezüglich c nicht größer als k ist. 30 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Bemerkungen zur NTM Das Orakel kann ein beliebiges Wort aus Γ sein. Darum muss in der Überprüfungsphase (2.Stufe) zunächst geprüft werden, ob das Orakel ein zulässiges Lösungsbeispiel ist. Ist dies nicht der Fall, so kann die Berechnung zu diesem Zeitpunkt mit der Antwort Nein beendet werden. Jede NTM M hat zu einer gegebenen Eingabe x eine unendliche Anzahl möglicher Berechnungen, eine zu jedem Orakel aus Γ. Endet mindestens eine in q J, so wird x akzeptiert. 31 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Zeitkomplexität für NTM Die Zeit, die eine nichtdeterministische Turing-Maschine M benötigt, um ein Wort x L M zu akzeptieren, ist definiert als die minimale Anzahl von Schritten, die M in den Zustand q J überführt. Die Zeitkomplexitätsfunktion T M : Z + Z + einer nichtdeterministischen Turing-Maschine M ist definiert durch T M (n) := max {1} m es gibt ein x L M mit x = n, so dass die Zeit, die M benötigt, um x zu akzeptieren, m ist 32 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Zeitkomplexität für NTM Die Zeit, die eine nichtdeterministische Turing-Maschine M benötigt, um ein Wort x L M zu akzeptieren, ist definiert als die minimale Anzahl von Schritten, die M in den Zustand q J überführt. Die Zeitkomplexitätsfunktion T M : Z + Z + einer nichtdeterministischen Turing-Maschine M ist definiert durch T M (n) := max {1} m es gibt ein x L M mit x = n, so dass die Zeit, die M benötigt, um x zu akzeptieren, m ist Bemerkung 1 Zur Berechnung von T M (n) wird für jedes x L M mit x = n die kürzeste akzeptierende Berechnung betrachtet. Anschließend wir von diesen kürzesten die längste bestimmt. Somit ergibt sich eine worst case Abschätzung. 32 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Zeitkomplexität für NTM Die Zeit, die eine nichtdeterministische Turing-Maschine M benötigt, um ein Wort x L M zu akzeptieren, ist definiert als die minimale Anzahl von Schritten, die M in den Zustand q J überführt. Die Zeitkomplexitätsfunktion T M : Z + Z + einer nichtdeterministischen Turing-Maschine M ist definiert durch T M (n) := max {1} m es gibt ein x L M mit x = n, so dass die Zeit, die M benötigt, um x zu akzeptieren, m ist Bemerkung 2 Die Zeitkomplexität hängt nur von der Anzahl der Schritte ab, die bei einer akzeptierenden Berechnung auftreten. Hierbei umfasst die Anzahl der Schritte auch die Schritte der Orakelphase. Per Konvention ist T M (n) = 1, falls es keine Eingabe x der Länge n gibt, die von M akzeptiert wird. 32 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Klasse NP Die Klasse N P ist die Menge aller Sprachen L, für die es eine nichtdeterministische Turing-Maschine gibt, deren Zeitkomplexitätsfunktion polynomial beschränkt ist. (N P steht für nichtdeterministisch polynomial.) 33 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Klasse NP Die Klasse N P ist die Menge aller Sprachen L, für die es eine nichtdeterministische Turing-Maschine gibt, deren Zeitkomplexitätsfunktion polynomial beschränkt ist. (N P steht für nichtdeterministisch polynomial.) Bemerkungen Alle Sprachen in N P sind entscheidbar. Informell ausgedrückt: Π gehört zu N P, falls Π folgende Eigenschaft hat: Ist die Antwort bei Eingabe eines Beispiels I von Π Ja, dann kann die Korrektheit der Antwort in polynomialer Zeit überprüft werden. 33 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik

Die Klasse NP Die Klasse N P ist die Menge aller Sprachen L, für die es eine nichtdeterministische Turing-Maschine gibt, deren Zeitkomplexitätsfunktion polynomial beschränkt ist. (N P steht für nichtdeterministisch polynomial.) Beispiel: TSP N P: Denn zu gegebenem G = (V, E), c, k und einer festen Permutation σ auf V kann man in O( V log C), wobei C die größte vorkommende Zahl ist, überprüft werden, ob gilt. n 1 c({σ(i), σ(i + 1)}) + c({σ(n), σ(1)}) k i=1 33 16.11.2017 Dorothea Wagner - Theoretische Grundlagen der Informatik