23
Introduction to Automata Theory Reading: Chapter 1 1 Reading: Chapter 1

Intro to Automata Theory

Embed Size (px)

Citation preview

Page 1: Intro to Automata Theory

Introduction to Automata Theory

Reading: Chapter 1

1

Reading: Chapter 1

Page 2: Intro to Automata Theory

What is Automata Theory?

� Study of abstract computing devices, or “machines”

� Automaton = an abstract computing deviceNote: A “device” need not even be a physical

2

� Note: A “device” need not even be a physical hardware!

� A fundamental question in computer science: � Find out what different models of machines can do

and cannot do

� The theory of computation

� Computability vs. Complexity

Page 3: Intro to Automata Theory

Alan Turing (1912-1954)

� Father of Modern Computer Science

� English mathematician

(A pioneer of automata theory)

3

� English mathematician

� Studied abstract machines called Turing machines even before real computers existed

� Heard of the Turing test?

Page 4: Intro to Automata Theory

Theory of Computation: A Historical Perspective

1930s • Alan Turing studies Turing machines• Decidability• Halting problem

4

1940-1950s • “Finite automata” machines studied• Noam Chomsky proposes the

“Chomsky Hierarchy” for formal languages

1969 Cook introduces “intractable” problemsor “NP-Hard” problems

1970- Modern computer science: compilers, computational & complexity theory evolve

Page 5: Intro to Automata Theory

Languages & Grammars

Or “words”

� Languages: “A language is a collection of sentences of finite length all constructed from a finite alphabet of symbols”

5Image source: Nowak et al. Nature, vol 417, 2002

symbols”

� Grammars: “A grammar can be regarded as a device that enumerates the sentences of a language” - nothing more, nothing less

� N. Chomsky, Information and Control, Vol 2, 1959

Page 6: Intro to Automata Theory

The Chomsky Hierachy• A containment hierarchy of classes of formal languages

6

Regular(DFA)

Context-free

(PDA)

Context-sensitive

(LBA)

Recursively-enumerable

(TM)

Page 7: Intro to Automata Theory

Finite Automata

� Some Applications� Software for designing and checking the behavior

of digital circuits

� Lexical analyzer of a typical compiler

7

� Lexical analyzer of a typical compiler

� Software for scanning large bodies of text (e.g., web pages) for pattern finding

� Software for verifying systems of all types that have a finite number of states (e.g., stock market transaction, communication/network protocol)

Page 8: Intro to Automata Theory

Finite Automata : Examples

� On/Off switchaction

state

8

� Modeling recognition of the word “then”

Start state Final stateTransition Intermediate state

Page 9: Intro to Automata Theory

The Central Concepts of Automata Theory

9

Page 10: Intro to Automata Theory

Alphabet

An alphabet is a finite, non-empty set of symbols

� We use the symbol ∑ (sigma) to denote an alphabet

10

alphabet

� Examples:� Binary: ∑ = {0,1}

� All lower case letters: ∑ = {a,b,c,..z}

� Alphanumeric: ∑ = {a-z, A-Z, 0-9}

� DNA molecule letters: ∑ = {a,c,g,t}

� …

Page 11: Intro to Automata Theory

Strings

A string or word is a finite sequence of symbols chosen from ∑

� Empty string is ε (or “epsilon”)

Length of a string w is |w|

11

� Length of a string w is |w|� = number of characters in the string

� Powers of an alphabet� ∑k = the set of all strings of length k

� ∑* = ∑0 U ∑1 U ∑2 U …

� ∑+ = ∑1 U ∑2 U ∑3 U …

� xy = concatentation of two strings x and y

Page 12: Intro to Automata Theory

Languages

L is a said to be a language over alphabet ∑, if L is a subset of strings in ∑*

� Examples:The language of all strings consisting of n 0’s

12

� The language of all strings consisting of n 0’s followed by n 1’s: {ε,01,0011,000111,…}

� The set of strings of with equal number of 0’s and 1’s: {ε, 01,10,0011,1100,0101,1010,1001,…}

� Ø = Empty language

� Let L = {ε}; Is L=Ø?no

Page 13: Intro to Automata Theory

The Membership Problem

Given a string w in ∑*and a language L over ∑, decide whether or not w is in L.

13

Example:

Let w = 100011

Q) Is w ∈ Language of equal number of 0s and 1s?

Page 14: Intro to Automata Theory

Structural expressions

� Grammars

� Regular expressions

� E.g., unix style to capture city names such

14

� E.g., unix style to capture city names such as “Palo Alto CA”:

� [A-Z][a-z]*([ ][A-Z][a-z]*)*[ ][A-Z][A-Z]

Start with a letter

A string of other letters (possiblyempty)

Other space delimited words(part of city name)

Should end w/ 2-letter state code

Page 15: Intro to Automata Theory

Formal Proofs

15

Page 16: Intro to Automata Theory

Deductive Proofs

From the hypothesis or the given statement, to

a conclusion statement (what we want to

prove)

16

� Logical progression by direct implications

� Theorem 1: If x≥4, then 2x≥x2.

� Theorem 2: If x is the sum of the squares of 4 positive integers, then 2x≥x2

hypothesis conclusion

Page 17: Intro to Automata Theory

Example: Deductive proof

Theorem: If x is the sum of the squares of four positive integers, then 2x≥x2

� Proof:Given: x = a2 + b2 + c2 + d2

17

1) Given: x = a2 + b2 + c2 + d2

2) Given: a≥1, b≥1, c≥1, d≥1

3) � a2≥1, b2≥1, c2≥1, d2≥1 (by 2)

4) � x ≥ 4 (by 1 & 3)

5) � 2x ≥ x2 (by 4 and previous theorem)

“implies” or “follows”

Page 18: Intro to Automata Theory

Quantifiers

� “For all” or “For every”� Universal proofs

� Notation=?

18

� “There exists”� Used in existential proofs

� Notation=?

� Other notation:� Implication is denoted by =>

� E.g., “IF A THEN B” can also be written as “A=>B”

Page 19: Intro to Automata Theory

Proving techniques

� By contradiction

� Start with a contradictory statement

� E.g., To prove (A and B => C or D), we could start with:

� A and B and not(C or D)

19

� A and B and not(C or D)

� … and show that could never happen

� By induction

� (3 steps) Basis, inductive hypothesis, inductive step

� By contrapositive statement

� If A then B == If not B then not A

Page 20: Intro to Automata Theory

Proving techniques…

� By counter-example

� Show an example that disproves the claim

� Note: There is no such thing called a

20

� Note: There is no such thing called a “proof by example”!

� So when asked to prove a claim, an example that satisfied that claim is not a proof

Page 21: Intro to Automata Theory

Different ways of saying the same thing

� “If H then C”:i. H implies C

ii. H => C

21

H => C

iii. C if H

iv. H only if C

v. Whenever H holds, C follows

Page 22: Intro to Automata Theory

“If-and-Only-If” statements

� “A if and only if B” (A <==> B)� (if part) if B then A ( <= )

� (only if part) A only if B ( => )(same as “if A then B”)

22

(same as “if A then B”)

� “If and only if” is abbreviated as “iff”� i.e., “A iff B”

� Example:� Theorem: Let x be a real number. Then floor of x =

ceiling of x if and only if x is an integer.

� Proofs for iff have two parts � One for the “if part” & another for the “only if part”

Page 23: Intro to Automata Theory

Summary

� Automata theory & a historical perspective

� Chomsky hierarchy

� Finite automata

� Alphabets, strings/words/sentences, languages

Membership problem

23

� Membership problem

� Proofs:

� Deductive, induction, contrapositive, contradiction, counterexample

� If and only if

� Read chapter 1 for more examples and exercises

� Gradiance homework 1