Title: Languages and Finite Automata
1Formal Languages Non-Regular Languages Hinrich
Schütze IMS, Uni Stuttgart, WS 2006/07 Slides
based on RPI CSCI 2400 Thanks to Costas Busch
2Non-regular languages
Regular languages
3How can we prove that a language is not regular?
Problem this is not easy to prove
Solution the Pumping Lemma
4The Pigeonhole Principle
5pigeons
pigeonholes
6A pigeonhole must contain at least two pigeons
7pigeons
...........
pigeonholes
...........
8The Pigeonhole Principle
pigeons
pigeonholes
There is a pigeonhole with at least 2 pigeons
...........
9The Pigeonhole Principleand DFAs
10DFA with states
11In walks of strings
no state is repeated
12In walks of strings
a state is repeated
13If string has length
Then the transitions of string are more than the
states of the DFA
Thus, a state must be repeated
14In general, for any DFA String has
length number of states
A state must be repeated in the walk of
walk of
......
......
Repeated state
15In other words for a string
transitions are pigeons
states are pigeonholes
walk of
......
......
Repeated state
16The Pumping Lemma
17Take an infinite regular language
There exists a DFA that accepts
states
18Take string with
There is a walk with label
.........
walk
19If string has length
(number of states of DFA)
then, from the pigeonhole principle
a state is repeated in the walk
......
......
walk
20Let be the first state repeated in the walk
of
......
......
walk
21Write
......
......
22Observations
length
number of states of DFA
length
......
......
23The string is accepted
Observation
......
......
24The string is accepted
Observation
......
......
25The string is accepted
Observation
......
......
26The string is accepted
In General
......
......
27In General
Language accepted by the DFA
......
......
28The Pumping Lemma
- Given an infinite regular language
- for any string with length
29Applications ofthe Pumping Lemma
30Theorem
The language
is not regular
Proof
Use the Pumping Lemma
31Assume for contradiction that is a regular
language
Since is infinite we can apply the Pumping
Lemma
32Let be the integer in the Pumping Lemma
Pick a string such that
length
We pick
33Write
From the Pumping Lemma
it must be that length
Thus
34From the Pumping Lemma
Thus
35From the Pumping Lemma
Thus
36BUT
CONTRADICTION!!!
37Our assumption that is a regular language is not
true
Therefore
Conclusion
is not a regular language
38Non-regular languages
Regular languages