1Computer Sciences Department
Book: INTRODUCTION TO THE THEORY OF COMPUTATION, SECOND EDITION, by: MICHAEL SIPSER Reference 3Computer Sciences Department
D E C I D A B I L I T Y 4Computer Sciences Department
5 Objectives
investigate the power of algorithms to solve problems. explore the limits of algorithmic solvability. study this phenomenon “unsolvability”: the problem must be simplified or altered before you can find an algorithmic solution. The halting problem 6Computer Sciences Department
DECIDABLE LANGUAGES Languages that are decidable by algorithms. For example: present an algorithm that tests whether a string is a member of a context-free language (CFL). 7Computer Sciences Department
DECIDABLE PROBLEMS CONCERNING REGULAR LANGUAGES algorithms for testing: whether a finite automaton accepts a string, whether the language of a finite automaton is empty, and whether two finite automata are equivalent. 8Computer Sciences Department
DECIDABLE PROBLEMS CONCERNING REGULAR LANGUAGES (cont.) For example: the acceptance problem for DFAs of testing whether a particular deterministic finite automaton accepts a given string can be expressed as a language, A DFA. 9Computer Sciences Department
10Computer Sciences Department
PROOF 4.1 B is simply a list of its five components, Q, A,, qo, and F. When M receives its input, M first determines whether it properly represents a DFA B and a string w. If not, Al rejects. 11 ƍ Computer Sciences Department
PROOF 4.1 (cont) It keeps track of B's current state and B's current position in the input w by writing this information down on its tape. Initially, B's current state is qo and B's current input position is the leftmost symbol of w. The states and position are updated according to the specified transition function. When M finishes processing the last symbol of w, M accepts the input if B is in an accepting state; M rejects the input if B is in a nonaccepting state. 12 ƍ Computer Sciences Department
DECIDABLE PROBLEMS CONCERNING REGULAR LANGUAGES (cont.) 13Computer Sciences Department
NFA PROOF 14 THEOREM 1.39 Every nondeterministic finite automaton has an equivalent deterministic finite automaton. Computer Sciences Department
Regular expressions “REX” 15 PROOF Computer Sciences Department
Emptiness 16 PROOF Computer Sciences Department
THEOREM 4.5 The equivalence problem: EQ DFA is a decidable language. 17Computer Sciences Department
DECIDABLE PROBLEMS CONCERNING CONTEXT-FREE LANGUAGES Theorem 4.8 E CFG is a decidable language. Theorem 4.9 Every context-free language is decidable. 18Computer Sciences Department
19 Halt means the process will stop at the accept or the reject state There are two halt states: "accept halt" and "reject halt". Halt = Stop
THE HALTING PROBLEM 20 In computability theory, the halting problem is the problem of determining, from a description of an arbitrary computer program and an input, whether the program will finish running or continue to run forever. Alan Turing proved in 1936 that a general algorithm to solve the halting problem for all possible program-input pairs cannot exist. A key part of the proof was a mathematical definition of a computer and program, which became known as a Turing machine; the halting problem is undecidable over Turing machines. Computer Sciences Department
The halting problem is a decision problem about properties of computer programs on a fixed Turing-complete model of computation, i.e., all programs that can be written in some given programming language that is general enough to be equivalent to a Turing machine. The problem is to determine, given a program and an input to the program, whether the program will eventually halt when run with that input. Computer Sciences Department21 The halting problem is a decision problem
- For example, in pseudocode, the program while (true) continue -does not halt; rather, it goes on forever in an infinite loop. -On the other hand, the program print "Hello, world! print "Hello, world!” does halt. Computer Sciences Department22 Halt - example
Computer Sciences Department23 UNDECIDABILITY
A language is decidable if some TM decides it All computations of a decider TM must halt. Decidable languages are often called also recursive languages. A language is Turing-recognizable (or recursively enumerable) : if it is recognized by a TM. That is, all words in the language are accepted by the TM. On words not belonging to the language, the computation of the TM either rejects or goes on forever. Lemma: A language L is decidable if and only if L is decidable. Computer Sciences Department24 Terminology
Computer Sciences Department25 Universal Turing machines
TM recognizer - decider This theorem shows that recognizers are more powerful than deciders. 26Computer Sciences Department
TM “recognizer – decider” (cont.) this machine loops on input if M loops on w, which is why this machine does not decide A TM = halting problem. 27Computer Sciences Department
THE DIAGONALIZATION METHOD The proof of the undecidability of the halting problem uses a technique called diagonalization, discovered by mathematician Georg Cantor in If we have two infinite sets, how can we tell whether one is larger than the other or whether they are of the same size? DEFINITION one-to-one. 28Computer Sciences Department
EXAMPLE 1 (countable) Let N be the set of natural numbers {1, 2, 3,... } and let Ɛ be the set of even natural numbers {2,4,6,... }. The correspondence f mapping N to Ɛ is simply f(n) = 2n. pairing each member of N with its own member of Ɛ is possible, so we declare these two sets to be the same size. 29Computer Sciences Department
some languages are not decidable or even Turing recognizable, for the reason that there are uncountably many languages yet only countably many Turing machines. 30 EXAMPLE 2 (uncountable) Computer Sciences Department
A TURING-UNRECOGNIZABLE LANGUAGE 31Computer Sciences Department