Automata & Formal Languages, Feodor F. Dragan, Kent State University 1 CHAPTER 3 The Church-Turing Thesis Contents Turing Machines definitions, examples,

Slides:



Advertisements
Similar presentations
Turing Machines Memory = an infinitely long tape Persistent storage A read/write tape head that can move around the tape Initially, the tape contains only.
Advertisements

Introduction to Computability Theory
CS 345: Chapter 9 Algorithmic Universality and Its Robustness
Variants of Turing machines
THE CHURCH-TURING T H E S I S “ TURING MACHINES” Pages COMPUTABILITY THEORY.
C O N T E X T - F R E E LANGUAGES ( use a grammar to describe a language) 1.
Foundations of (Theoretical) Computer Science Chapter 3 Lecture Notes (Section 3.2: Variants of Turing Machines) David Martin With.
Turing Machines (At last!). Designing Universal Computational Devices Was Not The Only Contribution from Alan Turing… Enter the year 1940: The world is.
CSC 3130: Automata theory and formal languages Andrej Bogdanov The Chinese University of Hong Kong Variants.
Applied Computer Science II Chapter 3 : Turing Machines Prof. Dr. Luc De Raedt Institut für Informatik Albert-Ludwigs Universität Freiburg Germany.
Algorithms Sipser 3.3 (pages ). CS 311 Mount Holyoke College 2 Computability Hilbert's Tenth Problem: Find “a process according to which it can.
1 Introduction to Computability Theory Lecture11: Variants of Turing Machines Prof. Amos Israeli.
Turing Machines New capabilities: –infinite tape –can read OR write to tape –read/write head can move left and right q0q0 input tape.
CS5371 Theory of Computation Lecture 11: Computability Theory II (TM Variants, Church-Turing Thesis)
CS 310 – Fall 2006 Pacific University CS310 Turing Machines Section 3.1 November 6, 2006.
Lecture 5 Turing Machines
Computation Theory Introduction to Turing Machine.
CHAPTER 3 The Church-Turing Thesis
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.
CS5371 Theory of Computation Lecture 10: Computability Theory I (Turing Machine)
CS5371 Theory of Computation Lecture 8: Automata Theory VI (PDA, PDA = CFG)
Prof. Busch - LSU1 Turing Machines. Prof. Busch - LSU2 The Language Hierarchy Regular Languages Context-Free Languages ? ?
AUTOMATA THEORY VIII.
Turing Machines A more powerful computation model than a PDA ?
Complexity and Computability Theory I Lecture #13 Instructor: Rina Zviel-Girshin Lea Epstein Yael Moses.
Turing Machines Chapter Plan Turing Machines(TMs) – Alan Turing Church-Turing Thesis – Definitions Computation Configuration Recognizable vs. Decidable.
CSE202: Introduction to Formal Languages and Automata Theory Chapter 9 The Turing Machine These class notes are based on material from our textbook, An.
CSCI 2670 Introduction to Theory of Computing September 28, 2005.
 Computability Theory Turing Machines Professor MSc. Ivan A. Escobar
Pushdown Automata (PDAs)
Introduction to CS Theory Lecture 15 –Turing Machines Piotr Faliszewski
Turing Machines Chapter 17. Languages and Machines SD D Context-Free Languages Regular Languages reg exps FSMs cfgs PDAs unrestricted grammars Turing.
THE CHURCH-TURING T H E S I S “ TURING MACHINES” Part 1 – Pages COMPUTABILITY THEORY.
The Church-Turing Thesis Chapter 3 Giorgi Japaridze Theory of Computability.
1Computer Sciences Department. Book: INTRODUCTION TO THE THEORY OF COMPUTATION, SECOND EDITION, by: MICHAEL SIPSER Reference 3Computer Sciences Department.
Automata & Formal Languages, Feodor F. Dragan, Kent State University 1 CHAPTER 3 The Church-Turing Thesis Contents Turing Machines definitions, examples,
1Computer Sciences Department. Book: INTRODUCTION TO THE THEORY OF COMPUTATION, SECOND EDITION, by: MICHAEL SIPSER Reference 3Computer Sciences Department.
1Computer Sciences Department. Book: INTRODUCTION TO THE THEORY OF COMPUTATION, SECOND EDITION, by: MICHAEL SIPSER Reference 3Computer Sciences Department.
TM Design Macro Language D and SD MA/CSSE 474 Theory of Computation.
Donghyun (David) Kim Department of Mathematics and Computer Science North Carolina Central University 1 Chapter 3 Church-Turing Thesis Some slides are.
CS 208: Computing Theory Assoc. Prof. Dr. Brahim Hnich
Formal Models of Computation
Lecture 9  2010 SDU Lecture9: Turing Machine.  2010 SDU 2 Historical Note Proposed by Alan Turing in 1936 in: On Computable Numbers, with an application.
CS 3240: Languages and Computation
CSCI 2670 Introduction to Theory of Computing October 7, 2004.
1 Turing Machines and Equivalent Models Section 13.1 Turing Machines.
Overview of the theory of computation Episode 3 0 Turing machines The traditional concepts of computability, decidability and recursive enumerability.
1 Turing Machines - Chap 8 Turing Machines Recursive and Recursively Enumerable Languages.
1 Turing Machines. 2 The Language Hierarchy Regular Languages Context-Free Languages ? ?
1 Introduction to Turing Machines
1 CD5560 FABER Formal Languages, Automata and Models of Computation Lecture 12 Mälardalen University 2007.
Chapter 9 Turing Machines What would happen if we change the stack in Pushdown Automata into some other storage device? Truing Machines, which maintains.
Turing Machines CS 130 Theory of Computation HMU Textbook: Chap 8.
CSCI 2670 Introduction to Theory of Computing September 29, 2005.
FORMAL LANGUAGES, AUTOMATA, AND COMPUTABILITY * Read chapter 4 of the book for next time * Lecture9x.ppt.
Theory of Computation Automata Theory Dr. Ayman Srour.
Modeling Arithmetic, Computation, and Languages Mathematical Structures for Computer Science Chapter 8 Copyright © 2006 W.H. Freeman & Co.MSCS SlidesTuring.
Turing Machines.
CS21 Decidability and Tractability
Pumping Lemma Revisited
CSE 105 theory of computation
Chapter 3: The CHURCH-Turing thesis
فصل سوم The Church-Turing Thesis
CS21 Decidability and Tractability
Decidability and Tractability
CSE 105 theory of computation
Intro to Theory of Computation
CSE 105 theory of computation
Presentation transcript:

Automata & Formal Languages, Feodor F. Dragan, Kent State University 1 CHAPTER 3 The Church-Turing Thesis Contents Turing Machines definitions, examples, Turing-recognizable and Turing-decidable languages Variants of Turing Machine Multitape Turing machines, non-deterministic Turing Machines, Enumerators, equivalence with other models The definition of Algorithm Hilbert’s problems, terminology for describing Turing machines

Automata & Formal Languages, Feodor F. Dragan, Kent State University 2 Turing Machines (intro) So far in our development of theory of computation we have presented several models for computing devices Finite automata are good models for devices that have a small amount of memory. Pushdown automata are good models for devices that have an unlimited memory that is usable only in the last in, first out manner of a stack. We have shown that some very simple tasks are beyond the capabilities of these models. Now we will consider a much more powerful model, first proposed by Alan Turing in 1936, called the Turing Machine (TM). It is similar to a finite automaton but with an unlimited and unrestricted memory. TM is much more accurate model of a general purpose computer. It can do everything that a real computer can do. But a TM also cannot solve certain problems. There are problems that are beyond the theoretical limits of computation.

Automata & Formal Languages, Feodor F. Dragan, Kent State University 3 Turing Machines (informal) The Turing machine model uses an infinite tape as its unlimited memory. It has a head that can read and write symbols and move around on the tape. Initially the tape contains only the input string and is blank everywhere else. If TM needs to store information, it may write this info on the tape. To read the information that it has written, TM can move its head back over it. The machine continues computing until it produces an output. The output accept and reject are obtained by entering designated accepting and rejecting states. If it does not enter an accepting or a rejecting state, it will go on forever, never halting. aabb control infinite tape Schematic of a Turing Machine: The differences between finite automata and Turing machines. A TM can both write on the tape and read from it. The read-write head can move both to the left and to the right. The tape is infinite. The special states for rejecting and accepting take immediate effect. … read-write head

Automata & Formal Languages, Feodor F. Dragan, Kent State University 4 Example We want to design a TM M1 which accepts if its input is a member of B Informal description how the TM works on input string s. Scan the input to be sure that it contains a single # symbol. If not, reject. Zig-zag across the tape to corresponding positions on either side of the # symbol to check on whether these positions contain the same symbol. If they do not, reject. Cross off symbols as they are checked to keep track of which symbols correspond. When all symbols to the left of the # have been crossed off, check for any remaining symbols to the right of the #. If any symbols remain, reject; otherwise, accept. accept M1 on input #011000

Automata & Formal Languages, Feodor F. Dragan, Kent State University 5 A Turing machine (TM) is specified by a 7-tuple, where is a finite set of states, is a finite input alphabet not containing, is a finite tape alphabet, such that is the transition function, is the start state, is the accept state, and is the reject state, where The heart of the definition of a TM is the transition function because it tells us how the machine gets from one step to the next. means that when the machine is in a certain state q and head is over a tape square containing a symbol a, the machine writes the symbol b replacing the a, and goes to state r. The third component is either L or R and indicates whether the head moves to the left or right after writing. Formal Definition of TMs

Automata & Formal Languages, Feodor F. Dragan, Kent State University 6 How does a TM compute? Initially TM receives its input on the leftmost n squares of the tape, and the rest of the tape is blank. The head starts on the leftmost square of the tape. Note that does not contain the blank symbol, so the first blank symbol appearing on the tape marks the end of the input. Once TM starts, the computation proceeds according to the rules described by the transition function. If TM ever tries to move its head to the left off the left-hand end of the tape, the head stays in the same place for that move, even though the transition function indicates L. The computation continues until it enters either accept state or reject state at which point it halts. If neither occurs, TM goes on forever. aabb control …

Automata & Formal Languages, Feodor F. Dragan, Kent State University 7 Acceptance of Strings and the Language of TM A configuration C of the TM q7 … q70010 For a state q and two strings u and v over the tape alphabet we write uqv for the configuration where the current state is q, the current tape contents is uv, and the current head location is the first symbol of v. Let We say that configuration Note that and that and we can handle this as before.

Automata & Formal Languages, Feodor F. Dragan, Kent State University 8 Acceptance of Strings and the Language of TM (cont.) The start configuration of TM on input w is In an accepting configuration the state is In an rejecting configuration the state is A Turing machine TM accepts input w if a sequence of configurations exists where is the start configuration of TM on input w, each yields and is an accepting configuration. Halting configurations If L is a set of strings that TM accepts, we say that L is the language of TM and write L=L(TM). We say TM recognizes L or TM accepts L. A language is Turing-recognizable if some TM recognizes it. For a TM three outcomes are possible on an input: it may accept, reject or loop. Deciders are TMs that always make a decision to accept or reject the input. A language is Turing-decidable or simply decidable if it is accepted by a decider.

Automata & Formal Languages, Feodor F. Dragan, Kent State University 9 Example 1. A TM M2 which decides the language Higher-level description. 1.Sweep left to right across the tape, crossing off every other 0. 2.If in stage 1 the tape contained a single 0, accept. 3.If in stage 1 the tape contained more than a single 0 and the number of 0’s was odd, reject. 4.Return the head to the left-hand end of the tape. 5.Go to stage 1.” Run M2 on input 0000 and 000 M2=“On input string w: Formal description. Start state q1 q5 q2 q3 q4

Automata & Formal Languages, Feodor F. Dragan, Kent State University 10 Example 2. A TM M1 which decides the language For higher-level description see slide #4. Formal description. q1 q3q5q7q9 q11 q12 q14 q2q4q6q8 q10 q13

Automata & Formal Languages, Feodor F. Dragan, Kent State University 11 Example 3: Home reading: read p. 134 where a TM is described which does some elementary arithmetic. It decides the language Higher-level description: 1.Place a mark on top of the leftmost tape symbol. If that symbol was blank, accept. If it was a #, continue with the next stage. Otherwise, reject. 2.Scan right to the next # and place a second mark on top of it. If no # is encountered before a blank symbol, only was present, so accept. 3.By zig-zagging, compare the two strings to the right of the marked #s. If they are equal, reject. 4.Move the rightmost of the two marks to the next # symbol to the right. If no # symbol is encountered before a blank symbol, move the leftmost mark to the next # to its right and the rightmost mark to the # after that. If no # is available for the rightmost mark, all the strings have been compared, so accept. 5.Go to stage 3.” M4=“On input w: Example 4: A TM solving the element uniqueness problem. It is given a list of strings over {0,1} separated by #s and its job is to accept if all strings are different. The language is TM M4 works by comparing with through, then by comparing with through, and so on. (In the actual implementation, the machine has two different symbols, # and #, in its tape alphabet)..

Automata & Formal Languages, Feodor F. Dragan, Kent State University 12 Homework Problems: 3.1, 3.2 (page 147 of the textbook) 3.5, 3.8(a) (page 148 of the textbook). Read pp.144,145,146,147 to understand what “implementation-level” is.