NPDAs Accept ContextFree Languages - PowerPoint PPT Presentation

1 / 80
About This Presentation
Title:

NPDAs Accept ContextFree Languages

Description:

Introduce the new symbol to denote. the bottom of the stack. Fall 2003. Costas Busch - RPI ... if and only if. the NPDA goes from to. by reading string and. the ... – PowerPoint PPT presentation

Number of Views:91
Avg rating:3.0/5.0
Slides: 81
Provided by: costas
Category:

less

Transcript and Presenter's Notes

Title: NPDAs Accept ContextFree Languages


1
NPDAs Accept Context-Free Languages
2
Theorem
Context-Free Languages (Grammars)
Languages Accepted by NPDAs
3
Proof - Step 1
Context-Free Languages (Grammars)
Languages Accepted by NPDAs
Convert any context-free grammar to a NPDA
with
4
Proof - Step 2
Context-Free Languages (Grammars)
Languages Accepted by NPDAs
Convert any NPDA to a context-free
grammar with
5
Converting Context-Free Grammarsto NPDAs
Proof - step 1

6
We will convert any context-free grammar
to an NPDA automaton
Such that
Simulates leftmost derivations of
7
Leftmost derivation
Input processed
Stack contents
leftmost variable
Stack
Simulation of derivation
Input
8
Leftmost derivation
string of terminals
Stack
Simulation of derivation
Input
end of input is reached
9
An example grammar
What is the equivalent NPDA?
10
Grammar
NPDA
11
Grammar
A leftmost derivation
12
Derivation
Input
Time 0
Stack
13
Derivation
Input
Time 0
Stack
14
Derivation
Input
Time 1
Stack
15
Derivation
Input
Time 2
Stack
16
Derivation
Input
Time 3
Stack
17
Derivation
Input
Time 4
Stack
18
Derivation
Input
Time 5
Stack
19
Derivation
Input
Time 6
Stack
20
Derivation
Input
Time 7
Stack
21
Derivation
Input
Time 8
Stack
22
Derivation
Input
Time 9
Stack
accept
23
In general
Given any grammar
We can construct a NPDA
With
24
Constructing NPDA from grammar
For any production
For any terminal
25
Grammar generates string
if and only if
NPDA accepts
26
Therefore
For any context-free language there is a
NPDA that accepts the same language
Context-Free Languages (Grammars)
Languages Accepted by NPDAs
27
Converting NPDAstoContext-Free Grammars
Proof - step 2

28
For any NPDA
we will construct a context-free grammar
with
29
Intuition
The grammar simulates the machine
A derivation in Grammar
terminals
variables
Input processed
Stack contents
Current configuration in NPDA
30
Some Necessary Modifications
  • Modify (if necessary) the NPDA so that
  • 1) The stack is never empty
  • 2) It has a single final state
  • and empties the stack when it accepts a
    string
  • 3) Has transitions in a special form

31
  • Modify the NPDA so that
  • the stack is never empty

Stack
OK
OK
NOT OK
32
Introduce the new symbol to denote the
bottom of the stack
33
At the beginning push into the stack
Original NPDA
new initial state
original initial state
34
In transitions replace every instance of
with
Example
35
Convert all transitions so that
if the automaton attempts to pop or replace
it will halt
36
Convert transitions as follows
halting state
37
2) Modify the NPDA so that it empties the
stack and has a unique final state
Empty the stack
NPDA
Old final states
38
3) modify the NPDA so that transitions have
the following forms
OR
39
Convert
40
Convert
symbols
41
Convert
symbols
Convert recursively
42
Example of a NPDA in correct form
43
The Grammar Construction
In grammar
Stack symbol
Variables
states
Terminals Input symbols of NPDA
44
For each transition
We add production
45
For each transition
We add productions
For all possible states in the automaton
46
Stack bottom symbol
Start Variable
Start state
final state
47
Example
Grammar production
48
Example
Grammar productions
49
Example
Grammar production
50
Resulting Grammar
51
(No Transcript)
52
Derivation of string
53
In general
if and only if
the NPDA goes from to by reading string
and the stack doesnt change below and
then is removed from stack
54
Therefore
if and only if
is accepted by the NPDA
55
Therefore
For any NPDA there is a context-free grammar that
accepts the same language
Context-Free Languages (Grammars)
Languages Accepted by NPDAs
56
Deterministic PDADPDA

57
Deterministic PDA DPDA
Allowed transitions
(deterministic choices)
58
Allowed transitions
(deterministic choices)
59
Not allowed
(non deterministic choices)
60
DPDA example
61
The language
is deterministic context-free
62
Definition
A language is deterministic context-free if
there exists some DPDA that accepts it
63
Example of Non-DPDA (NPDA)
64
Not allowed in DPDAs
65
NPDAs Have More Power thanDPDAs

66
It holds that
Deterministic Context-Free Languages (DPDA)
Context-Free Languages NPDAs
Since every DPDA is also a NPDA
67
We will actually show
Deterministic Context-Free Languages (DPDA)
Context-Free Languages (NPDA)
68
The language is
We will show
  • is context-free
  • is not deterministic context-free

69
Language is context-free
70
Theorem
The language
is not deterministic context-free
(there is no DPDA that accepts )
71
Proof
Assume for contradiction that
is deterministic context free
Therefore
there is a DPDA that accepts
72
DPDA with
accepts
accepts
73
DPDA with
Such a path exists because of the determinism
74
Fact 1
The language is not
context-free
(we will prove this at a later class
using pumping lemma for context-free languages)
75
Fact 2
The language is not
context-free
(we can prove this using pumping lemma for
context-free languages)
76
We will construct a NPDA that accepts
which is a contradiction!
77
Replace with
Modify
78
The NPDA that accepts
Connect final states of with final states
of
79
Since is accepted by a
NPDA
it is context-free
Contradiction!
(since is not
context-free)
80
Therefore
Not deterministic context free
There is no DPDA that accepts
End of Proof
Write a Comment
User Comments (0)
About PowerShow.com