CS21 Decidability and Tractability

Slides:



Advertisements
Similar presentations
Lecture 3 Universal TM. Code of a DTM Consider a one-tape DTM M = (Q, Σ, Γ, δ, s). It can be encoded as follows: First, encode each state, each direction,
Advertisements

CS 461 – Nov. 9 Chomsky hierarchy of language classes –Review –Let’s find a language outside the TM world! –Hints: languages and TM are countable, but.
CSCI 4325 / 6339 Theory of Computation Zhixiang Chen Department of Computer Science University of Texas-Pan American.
1 COMP 382: Reasoning about algorithms Unit 9: Undecidability [Slides adapted from Amos Israeli’s]
The diagonalization method The halting problem is undecidable Decidability.
February 6, 2015CS21 Lecture 141 CS21 Decidability and Tractability Lecture 14 February 6, 2015.
1 Introduction to Computability Theory Lecture15: Reductions Prof. Amos Israeli.
1 Introduction to Computability Theory Lecture12: Reductions Prof. Amos Israeli.
The Halting Problem Sipser 4.2 (pages ). CS 311 Mount Holyoke College 2 Taking stock All languages Turing-recognizable Turing-decidable Context-free.
The Halting Problem Sipser 4.2 (pages ).
1 Introduction to Computability Theory Lecture13: Mapping Reductions Prof. Amos Israeli.
Prof. Busch - LSU1 Decidable Languages. Prof. Busch - LSU2 Recall that: A language is Turing-Acceptable if there is a Turing machine that accepts Also.
Courtesy Costas Busch - RPI1 A Universal Turing Machine.
Fall 2004COMP 3351 Recursively Enumerable and Recursive Languages.
FORMAL LANGUAGES, AUTOMATA AND COMPUTABILITY
Lecture 8 Recursively enumerable (r.e.) languages
1 Undecidability Andreas Klappenecker [based on slides by Prof. Welch]
Decidable and undecidable problems deciding regular languages and CFL’s Undecidable problems.
1 Uncountable Sets continued Theorem: Let be an infinite countable set. The powerset of is uncountable.
CHAPTER 4 Decidability Contents Decidable Languages
Automata & Formal Languages, Feodor F. Dragan, Kent State University 1 CHAPTER 5 Reducibility Contents Undecidable Problems from Language Theory.
Fall 2004COMP 3351 A Universal Turing Machine. Fall 2004COMP 3352 Turing Machines are “hardwired” they execute only one program A limitation of Turing.
January 28, 2015CS21 Lecture 101 CS21 Decidability and Tractability Lecture 10 January 28, 2015.
February 4, 2015CS21 Lecture 131 CS21 Decidability and Tractability Lecture 13 February 4, 2015.
1 Introduction to Computability Theory Lecture11: The Halting Problem Prof. Amos Israeli.
1 Reducibility. 2 Problem is reduced to problem If we can solve problem then we can solve problem.
February 18, 2015CS21 Lecture 181 CS21 Decidability and Tractability Lecture 18 February 18, 2015.
MA/CSSE 474 Theory of Computation More Reduction Examples Non-SD Reductions.
The Halting Problem – Undecidable Languages Lecture 31 Section 4.2 Wed, Oct 31, 2007.
1 Undecidability Reading: Chapter 8 & 9. 2 Decidability vs. Undecidability There are two types of TMs (based on halting): (Recursive) TMs that always.
1 1 CDT314 FABER Formal Languages, Automata and Models of Computation Lecture 15-1 Mälardalen University 2012.
MA/CSSE 474 Theory of Computation Enumerability Reduction.
A Universal Turing Machine
1 Turing’s Thesis. 2 Turing’s thesis: Any computation carried out by mechanical means can be performed by a Turing Machine (1930)
 2005 SDU Lecture13 Reducibility — A methodology for proving un- decidability.
1Computer Sciences Department. Book: INTRODUCTION TO THE THEORY OF COMPUTATION, SECOND EDITION, by: MICHAEL SIPSER Reference 3Computer Sciences Department.
CS 461 – Nov. 7 Decidability concepts –Countable = can number the elements  –Uncountable = numbering scheme impossible  –A TM undecidable –Language classes.
Lecture 21 Reducibility. Many-one reducibility For two sets A c Σ* and B c Γ*, A ≤ m B if there exists a Turing-computable function f: Σ* → Γ* such that.
Recursively Enumerable and Recursive Languages
Donghyun (David) Kim Department of Mathematics and Computer Science North Carolina Central University 1 Chapter 4 Decidability Some slides are in courtesy.
Decidability Decidable/Undecidable problems. Jaruloj Chongstitvatana Decidability2 Accepting: Definition Let T = (Q, , , , s) be a TM. T accepts.
1 A Universal Turing Machine. 2 Turing Machines are “hardwired” they execute only one program A limitation of Turing Machines: Real Computers are re-programmable.
February 1, 2016CS21 Lecture 121 CS21 Decidability and Tractability Lecture 12 February 1, 2016.
Decidability and Undecidability Proofs
The Acceptance Problem for TMs
CIS Automata and Formal Languages – Pei Wang
Recursively Enumerable and Recursive Languages
CSCI 2670 Introduction to Theory of Computing
Busch Complexity Lectures: Reductions
Lecture12 The Halting Problem
Reductions Costas Busch - LSU.
MCC 2093 Advanced Theoretical Computer Science
CS154, Lecture 11: Self Reference, Foundation of Mathematics
Summary.
Computability & Complexity I
Decidable Languages Costas Busch - LSU.
Decidability and Undecidability
CS21 Decidability and Tractability
CS21 Decidability and Tractability
MA/CSSE 474 Theory of Computation
CS21 Decidability and Tractability
Formal Languages, Automata and Models of Computation
CS21 Decidability and Tractability
CS21 Decidability and Tractability
Cpt S 317: Spring 2009 Reading: Chapter 8 & 9
Instructor: Aaron Roth
More Undecidable Problems
MA/CSSE 474 Theory of Computation
Intro to Theory of Computation
CIS Automata and Formal Languages – Pei Wang
Presentation transcript:

CS21 Decidability and Tractability Lecture 11 January 30, 2015 January 30, 2015 CS21 Lecture 11

Outline decidable, RE, co-RE languages the Halting Problem reductions many-one reductions January 30, 2015 CS21 Lecture 11

non-RE languages Theorem: there exist languages that are not Recursively Enumerable. Proof outline: the set of all TMs is countable the set of all languages is uncountable the function L:{TMs} →{languages} cannot be onto January 30, 2015 CS21 Lecture 11

non-RE languages Lemma: the set of all TMs is countable. Proof: each TM M can be described by a finite-length string <M> can enumerate these strings, and give the natural bijection with N January 30, 2015 CS21 Lecture 11

non-RE languages Lemma: the set of all languages is uncountable Proof: fix an enumeration of all strings s1, s2, s3, … (for example, lexicographic order) a language L is described by its characteristic vector L whose ith element is 0 if si is not in L and 1 if si is in L January 30, 2015 CS21 Lecture 11

non-RE languages suppose the set of all languages is countable list characteristic vectors of all languages according to the bijection f: n f(n) _ 1 0101010… 2 1010011… 3 1110001… 4 0100011… … January 30, 2015 CS21 Lecture 11

non-RE languages suppose the set of all languages is countable list characteristic vectors of all languages according to the bijection f: n f(n) _ 1 0101010… 2 1010011… 3 1110001… 4 0100011… … set x = 1101… where ith digit ≠ ith digit of f(i) x cannot be in the list! therefore, the language with characteristic vector x is not in the list January 30, 2015 CS21 Lecture 11

So far… {anbn : n ≥ 0 } some language decidable all languages regular languages context free languages RE {anbncn : n ≥ 0 } This language might be an esoteric, artificially constructed one. Do we care? We will show a natural undecidable L next. January 30, 2015 CS21 Lecture 11

HALT = { <M, x> : TM M halts on input x } The Halting Problem Definition of the “Halting Problem”: HALT = { <M, x> : TM M halts on input x } HALT is recursively enumerable. proof? Is HALT decidable? January 30, 2015 CS21 Lecture 11

The Halting Problem Theorem: HALT is not decidable (undecidable). Proof: Suppose TM H decides HALT Define new TM H’: on input <M> if H accepts <M, <M>> then loop if H rejects <M, <M>> then halt January 30, 2015 CS21 Lecture 11

The Halting Problem Proof: define new TM H’: on input <M> if H accepts <M, <M>> then loop if H rejects <M, <M>> then halt consider H’ on input <H’>: if it halts, then H rejects <H’, <H’>>, which implies it cannot halt if it loops, then H accepts <H’, <H’>> which implies it must halt contradiction. January 30, 2015 CS21 Lecture 11

The Halting Problem box (M, x): does M halt on x? inputs Y Turing Machines n Y The existence of H which tells us yes/no for each box allows us to construct a TM H’ that cannot be in the table. n n Y n H’ : n Y n Y Y n Y January 30, 2015 CS21 Lecture 11

So far… Can we exhibit a natural language that is non-RE? {anbn : n ≥ 0 } some language decidable all languages regular languages context free languages RE HALT {anbncn : n ≥ 0 } Can we exhibit a natural language that is non-RE? January 30, 2015 CS21 Lecture 11

RE and co-RE The complement of a RE language is called a co-RE language some language {anbn : n ≥ 0 } co-RE decidable all languages regular languages context free languages RE {anbncn : n ≥ 0 } HALT January 30, 2015 CS21 Lecture 11

RE and co-RE Theorem: a language L is decidable if and only if L is RE and L is co-RE. Proof: () we already know decidable implies RE if L is decidable, then complement of L is decidable by flipping accept/reject. so L is in co-RE. January 30, 2015 CS21 Lecture 11

RE and co-RE Theorem: a language L is decidable if and only if L is RE and L is co-RE. Proof: () we have TM M that recognizes L, and TM M’ recognizes complement of L. on input x, simulate M, M’ in parallel if M accepts, accept; if M’ accepts, reject. January 30, 2015 CS21 Lecture 11

A natural non-RE language Theorem: the complement of HALT is not recursively enumerable. Proof: we know that HALT is RE suppose complement of HALT is RE then HALT is co-RE implies HALT is decidable. Contradiction. January 30, 2015 CS21 Lecture 11

Main point: some problems have no algorithms, HALT in particular. Summary co-HALT some language {anbn : n ≥ 0 } co-RE decidable all languages regular languages context free languages RE {anbncn : n ≥ 0 } HALT Main point: some problems have no algorithms, HALT in particular. January 30, 2015 CS21 Lecture 11

Reductions Given a new problem NEW, want to determine if it is easy or hard right now, easy typically means decidable right now, hard typically means undecidable One option: prove from scratch that the problem is decidable, or prove from scratch that the problem is undecidable (dream up a diag. argument) January 30, 2015 CS21 Lecture 11

Reductions A better option: called a reduction to prove NEW is decidable, show how to transform it into a known decidable problem OLD so that solution to OLD can be used to solve NEW. to prove NEW is undecidable, show how to transform a known undecidable problem OLD into NEW so that solution to NEW can be used to solve OLD. called a reduction January 30, 2015 CS21 Lecture 11

Reductions Reductions are one of the most important and widely used techniques in theoretical Computer Science. especially for proving problems “hard” often difficult to do “from scratch” sometimes not known how to do from scratch reductions allow proof by giving an algorithm to perform the transformation January 30, 2015 CS21 Lecture 11

Example reduction Try to prove undecidable: ATM = {<M, w> : M accepts input w} We know this language is undecidable: HALT = {<M, w> : M halts on input w} Idea: suppose ATM is decidable show that we can use ATM to decide HALT conclude HALT is decidable. Contradiction. reduction January 30, 2015 CS21 Lecture 11

Example reduction How could we use procedure that decides ATM to decide HALT? given input to HALT: <M, w> Some things we can do: check if <M, w>  ATM construct another TM M’ and check if <M’, w>  ATM January 30, 2015 CS21 Lecture 11

Example reduction Deciding HALT using a procedure that decides ATM (“reducing HALT to ATM”). on input <M, w> check if <M, w>  ATM if yes, the M halts on w; ACCEPT if no, then M either rejects w or it loops on w construct M’ by swapping qaccept/qreject in M check if <M’, w>  ATM if yes, then M’ accepts w, so M rejects w; ACCEPT if no, then M neither accepts nor rejects w; REJECT January 30, 2015 CS21 Lecture 11

Example reduction Preceding reduction proved: Theorem: ATM is undecidable. Proof (recap): suppose ATM is decidable we showed how to use ATM to decide HALT conclude HALT is decidable. Contradiction. January 30, 2015 CS21 Lecture 11

ETM = {<M> : L(M) = Ø} Another example Try to prove undecidable: ETM = {<M> : L(M) = Ø} which problem should we reduce from? HALT = {<M, w> : M halts on input w} ATM = {<M, w> : M accepts input w} Some things we can do: check if <M>  ETM construct another TM M’ and check if <M’>  ETM January 30, 2015 CS21 Lecture 11

Another example We are given input <M, w> We want to use a procedure that decides ETM to decide if <M, w>  ATM Idea: check if <M>  ETM if not? helpful if could make M reject everything except possibly w. January 30, 2015 CS21 Lecture 11

Is this OK? finite # of states? Another example Is this OK? finite # of states? Construct TM M’: on input x, if x  w, then reject else simulate M on x, and accept if M does. on input <M, w> construct M’ from description of M check if M’ ETM if no, M must accept w; ACCEPT if yes, M cannot accept w; REJECT January 30, 2015 CS21 Lecture 11

Another example Preceding reduction proved: Theorem: ETM is undecidable. Proof (recap): suppose ETM is decidable we showed how to use ETM to decide ATM conclude ATM is decidable. Contradiction. January 30, 2015 CS21 Lecture 11

Definition of reduction Can you reduce co-HALT to HALT? We know that HALT is RE Does this show that co-HALT is RE? recall, we showed co-HALT is not RE our current notion of reduction cannot distinguish complements January 30, 2015 CS21 Lecture 11

Definition of reduction More refined notion of reduction: “many-one” reduction (commonly) “mapping” reduction (book) A B f yes yes reduction from language A to language B f no no January 30, 2015 CS21 Lecture 11

Definition of reduction A B f yes yes f no no function f should be computable Definition: f : Σ*→ Σ* is computable if there exists a TM Mf such that on every wΣ* Mf halts on w with f(w) written on its tape. January 30, 2015 CS21 Lecture 11

Definition of reduction Notation: “A many-one reduces to B” is written A ≤m B “yes maps to yes and no maps to no” means: w  A maps to f(w)  B & w  A maps to f(w)  B B is at least as “hard” as A more accurate: B at least as “expressive” as A January 30, 2015 CS21 Lecture 11