Professional Documents
Culture Documents
Pushdown Automata (PDA) : Reading: Chapter 6
Pushdown Automata (PDA) : Reading: Chapter 6
Pushdown Automata (PDA) : Reading: Chapter 6
Reading: Chapter 6
What is?
Q: : : : q0: Z0: F:
states of the -NFA input alphabet stack symbols transition function start state Initial stack top s symbol mbol Final/accepting states
: Q x x => Q x
old state
Stack top
input symb.
a
Y=?
i) ii) iii)
Example
Let Lwwr = {wwR | w is in (0+1)*} CFG for Lwwr : S==> 0S0 | 1S1 | PDA for Lwwr : P := ( Q,, , ,q0,Z0,F ) = ( {q0, q1, q2},{0,1},{0,1,Z0},,q0,Z0,{q2})
q0
(q0,0, Z0)={(q0,0Z0)} (q0,1, Z0)={(q0,1Z0)} (q0,0, 0 0)={(q 0) {(q0,00)} 00)} (q0,0, 1)={(q0,01)} (q0,1, 0)={(q0,10)} (q0,1, 1)={(q0,11)} (q0, , 0)={(q1, 0)} (q0, , 1)={(q1, 1)} (q0, , Z0) )={(q {(q1, Z0)} (q1,0, 0)={(q1, )} (q1,1, 1)={(q1, )} (q1, , Z0)={(q2, Z0)}
3. 4. 5. 6.
Grow the stack by pushing new symbols on top of old ( (w-part) t) Switch to popping mode (boundary between w and wR) Shrink the stack by popping matching symbols y (w ( R-part) p ) Enter acceptance state
6
7. 8. 9 9.
10. 11.
12.
Current state
qi
qj
Next state
, Z0/Z0
q0
q1
, Z0/Z0
q2
G to acceptance Go
), ( / ), ( / , Z0 / Z0
q1
, Z0 / Z0
q2
(, ( / ( ( (, Z0 / ( Z0
Go to acceptance (by G (b fi final l state) ) when you see the stack bottom symbo
q0
q1
10
q - current state w - remainder of the input (i.e., unconsumed part) y - current stack contents as a string from top to bottom of f stack t k
If (q,a, X)={(p, A)} is a transition, then the following are also true: (q, a, X ) |--- (p,,A) (q, ( aw, XB ) | |--- (p,w,AB) ( )
|--- sign is called a turnstile notation and represents one move |---* sign represents a sequence of moves
11
Theorem 1: If for a PDA, (q, x, A) |---* (p, y, B), then for any string w * and d *, * it i is also l t true th that: t
Theorem 2: If for a PDA, (q, x w, , A) ) |---* | (p, y w, , B), ), then it is also true that:
13
There are two types of PDAs that one can design: those that accept by final state or by empty stack
Acceptance by
For a PDA P, the language accepted by P, d denoted t db by L(P) by b final fi l state t t , is: i Checklist:
For a PDA P, the language accepted by P, denoted by N(P) by empty stack, is:
Checklist: Q) Does a PDA that accepts by empty stack need any final state specified in the design? - input exhausted?
start ,Z Z0/ Z0
q0
q1
,Z Z0/ Z0
q0
Theorem: The PDA for Lwwr accepts a string x by final state if and only if x is of the form wwR. Proof:
(if-part) (if part) If the string is of the form wwR then there exists a sequence of IDs that leads to a final state: (q0,wwR,Z0) |---* (q0,wR,wZ0) |---* (q1,wR,wZ0) |---* (q1, ,Z Z0) |--| * (q2, ,Z Z0) (only-if part)
Th Theorem:
(PN==> PF) For every PN, there exists a PF s.t. L(PF)=L(PN) (PF==> PN) For every PF, there exists a PN s.t. L(PF)=L(PN)
17
PN==> PF construction
Whenever PNs stack becomes empty, make PF go to a final state without consuming any addition symbol To detect empty stack in PN: PF pushes a new stack symbol X0 (not in of PN) initially before simultating PN
PN: q0
PF:
New start , X0 / X0
, X0/Z0X0
p0
, X0/ X0 , X0/
, X0/ X0 , X0/ X0
X0 18
pf
N U {X }, , p , X , {p }) PF = (QN U {p0,pf}, , P 0 F 0 0 f
p0
,X /Z X
0 0
q0
,X / X
0
pf
19
PF==> PN construction
Main idea:
Whenever PF reaches a final state, just make an -transition into a new end state, clear out the stack and accept Danger: What if PF design is such that it clears the stack midway without entering a final state? to address this, , add a new start symbol y X0 ( (not in of PF)
PN:
New start
, X0/Z0X0
p0 q0
, any/
pe
PF 20
21
?
CFG
22
reject
OUTP PUT
INPU UT
accept
Steps:
1.
2.
3.
Push the right hand side of the production onto the stack, with leftmost symbol at the stack top If stack top is the leftmost variable, then replace it by all its productions (each possible substitution will represent a distinct path taken by the non non-deterministic deterministic PDA) If stack top has a terminal symbol, and if it matches with the next symbol in the input string, then pop it
Formal construction of PDA Note: Initial stack symbol (S) from CFG same as the start variable
Before: A
i th in the grammar
After:
Before: a
After:
a pop
(q,a,a)= { (q, ) }
25
G = ( {S,A}, {0,1}, P, S) P:
(q, (q , S) = { (q (q, AS) AS), (q (q, )} (q, , A) = { (q,0A1), (q,A1), (q,01) } (q, 0, 0) = { (q, ) } (q, 1, 1) = { (q, ) } How will this new PDA work?
A S
0 A 1 S
A 1 S
0 1 1 S
1 1 S
1 S
=> 0011
27
Claim: A string is accepted by G iff it is accepted (by empty stack) by the PDA Proof:
(only-if part)
(if part)
28
1. 2. 3.
State is changed from q to p; Terminal a is consumed; Stack top symbol Z is popped and replaced with a sequence of k variables.
Action: Create a g grammar variable called [qZp] which includes the following production:
PN: 1. 2. 3. 4.
( {q0}, {b,e}, {Z0,Z1}, , q0, Z0 ) (q0,b,Z0) = { (q0,Z1Z0) } (q0,b,Z1) = { (q0,Z1Z1) } (q0, , ,Z0) = { (q0, ) } (q0,e,Z1) = { (q0, ) }
Let A=[q0Z0q0] Let B=[q0Z1q0] If you were to directly write a CFG: S => b S e S | 0. 1. 2. 3. 4. S => A A => b B A B => b B B B => e A =>
30
Derive CFG directly Similarly Two ways to build a PDA Construct Derive a CFG PDA f from CFG Design a PDA directly
(direct)
(indirect)
(direct)
31
Deterministic PDAs
32
q0
q1
, Z0/Z0
q2
A Accepts b by fi final l state To remove guessing, impose the user to insert c in the middle
33
q0
q1
q2
34
If (q,a,X) is non-empty for some a, then (q (q, ,X) X) must be empty empty.
35
Regular languages
D-PDA
non-deterministic PDA
36
Summary
1. 2.
PDA
IDs, Transition diagram