Understanding Pushdown Automata and Language Acceptance

 
PUSHDOWN
AUTOMATA
 
-Mrs.Harini S
Assistant Professor,
Dept. of ISE,BMSCE
 
Acceptance of a Language by PDA
 
There are two cases wherein a string w is accepted by a
PDA:
Get the final state from the start state
Get an empty stack from the start state
 
 
Acceptance of a Language by PDA
 
G
e
t
 
t
h
e
 
f
i
n
a
l
 
s
t
a
t
e
 
f
r
o
m
 
t
h
e
 
s
t
a
r
t
 
s
t
a
t
e
  Let M=(
Q, ∑, Γ, δ, q0, Z, F) 
be a PDA. The language L(M) accepted
by a final state is defined as
 
L(M)={w | (q
0
,w,Z
0
) |-* (p,
  ε, α
) }
For some 
α
Γ
* , p € F and w € 
*.
N
o
t
e
:
 
w
h
e
n
 
a
l
l
 
t
h
e
 
s
y
m
b
o
l
s
 
i
n
 
s
t
r
i
n
g
 
w
 
h
a
v
e
 
b
e
e
n
 
r
e
a
d
 
a
n
d
 
w
h
e
n
 
t
h
e
m
a
c
h
i
n
e
 
i
s
 
i
n
 
t
h
e
 
f
i
n
a
l
 
s
t
a
t
e
,
 
t
h
e
 
f
i
n
a
l
 
c
o
n
t
e
n
t
s
 
o
f
 
t
h
e
 
s
t
a
c
k
 
a
r
e
i
r
r
e
l
e
v
a
n
t
G
e
t
 
a
n
 
e
m
p
t
y
 
s
t
a
c
k
 
f
r
o
m
 
t
h
e
 
s
t
a
r
t
 
s
t
a
t
e
 
 
 
 
L
(
M
)
=
{
w
 
|
 
(
q
0
,
w
,
Z
0
)
 
|
-
*
 
(
p
,
 
 
ε
,
 
 
ε
)
 
}
 
 
F
o
r
 
s
o
m
e
 
q
0
,
 
p
 
 
Q
 
a
n
d
 
w
 
 
*
.
It means when the string w is accepted by an empty stack, the final
state is irrelevant, the input should be completely read and the stack
should be empty.
 
Example : wCw
R
 
 
Example : wCw
R
 
Show whether the string aabCbaa is accepted by the PDA or not.
 
(q
0
, aabCbaa, Z
0
) |- (q
0
, abCbaa, aZ
0
)
  
 |- (q
0
, bCbaa, aaZ
0
)
  
 |- (q
0
, Cbaa, baaZ
0
)
  
 |- (q
1
, baa, baaZ
0
)
  
 |- (q
1
, aa, aaZ
0
)
  
 |- (q
1
, a, aZ
0
)
  
 |- (q
1
, Ɛ, Ɛ)
 
In this method, finally stack should not contain anything including Z0.
Note that q1 is not a final state and there is no final state.
 
Deterministic and Non-deterministic PDA
 
Let M=(
Q, ∑, Γ, δ, q0, Z, F) 
be a PDA. The PDA is
deterministic if
1. 
δ
 (
q
, a ,Z) has only one element
2. If 
δ
 (
q
, Ɛ ,Z) is not empty, then 
δ
 (
q
, a, Z) should be empty.
Both the conditions should be satisfied for a DPDA.
 
Let’s check all our PDAs that we have designed are Deterministic or
non-deterministic.
 
Deterministic and Non-deterministic PDA
 
Is 
L ={wCw
R
 | w € (a+b)*} deterministic??
 
Deterministic and Non-deterministic PDA
 
Transitions are:
δ
 (
q
0
, a ,Z
0
) = (q
0
, aZ
0
)
δ
 (
q
0
, a ,a) = (q
0
, aa)
δ
 (
q
0
, b ,a) = (q
1
, Ɛ)
δ
 (
q
1
, b ,a) = (q
1
, Ɛ)
δ
 (
q
1
, Ɛ, Z
0
) = (q
2
, Z
0
)
 
 
 
 
 
Deterministic and Non-deterministic PDA
 
Transitions:
δ
 (
q
0
, a ,Z
0
) = (q
0
, aZ
0
)
δ
 (
q
0
, b ,Z
0
) = (q
0
, bZ
0
)
δ
 (
q
0
, a ,a) = (q
0
, aa)
δ
 (
q
0
, b ,b) = (q
0
, bb)
δ
 (
q
0
, a ,b) = (q
0
, Ɛ)
δ
 (
q
0
, b ,a) = (q
0
, Ɛ)
δ
 (
q
0
, Ɛ, Z
0
) = (q
1
, Z
0
)
 
 
Deterministic and Non-deterministic PDA
Slide Note
Embed
Share

Pushdown Automata (PDA) provide a theoretical framework for recognizing context-free languages. In PDA, the acceptance of a language depends on reaching a final state or having an empty stack. This concept is illustrated through examples and the distinction between deterministic and non-deterministic PDAs is explored. Explore PDA transitions and determine if a given language is deterministic.


Uploaded on Jul 16, 2024 | 1 Views


Download Presentation

Please find below an Image/Link to download the presentation.

The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author. Download presentation by click this link. If you encounter any issues during the download, it is possible that the publisher has removed the file from their server.

E N D

Presentation Transcript


  1. PUSHDOWN AUTOMATA -Mrs.Harini S Assistant Professor, Dept. of ISE,BMSCE

  2. Acceptance of a Language by PDA There are two cases wherein a string w is accepted by a PDA: Get the final state from the start state Get an empty stack from the start state

  3. Acceptance of a Language by PDA Get the final state from the start state Let M=(Q, , , , q0, Z, F) be a PDA. The language L(M) accepted by a final state is defined as L(M)={w | (q0,w,Z0) |-* (p, , ) } For some * , p F and w *. Note: when all the symbols in string w have been read and when the machine is in the final state, the final contents of the stack are irrelevant Get an empty stack from the start state L(M)={w | (q0,w,Z0) |-* (p, , ) } For some q0, p Q and w *. It means when the string w is accepted by an empty stack, the final state is irrelevant, the input should be completely read and the stack should be empty.

  4. Example : wCwR

  5. Example : wCwR Show whether the string aabCbaa is accepted by the PDA or not. (q0, aabCbaa, Z0) |- (q0, abCbaa, aZ0) |- (q0, bCbaa, aaZ0) |- (q0, Cbaa, baaZ0) |- (q1, baa, baaZ0) |- (q1, aa, aaZ0) |- (q1, a, aZ0) |- (q1, , ) In this method, finally stack should not contain anything including Z0. Note that q1 is not a final state and there is no final state.

  6. Deterministic and Non-deterministic PDA Let M=(Q, , , , q0, Z, F) be a PDA. The PDA is deterministic if 1. (q, a ,Z) has only one element 2. If (q, ,Z) is not empty, then (q, a, Z) should be empty. Both the conditions should be satisfied for a DPDA. Let s check all our PDAs that we have designed are Deterministic or non-deterministic.

  7. Deterministic and Non-deterministic PDA Is L ={wCwR| w (a+b)*} deterministic??

  8. Deterministic and Non-deterministic PDA Transitions are: (q0, a ,Z0) = (q0, aZ0) (q0, a ,a) = (q0, aa) (q0, b ,a) = (q1, ) (q1, b ,a) = (q1, ) (q1, , Z0) = (q2, Z0)

  9. Deterministic and Non-deterministic PDA Transitions: (q0, a ,Z0) = (q0, aZ0) (q0, b ,Z0) = (q0, bZ0) (q0, a ,a) = (q0, aa) (q0, b ,b) = (q0, bb) (q0, a ,b) = (q0, ) (q0, b ,a) = (q0, ) (q0, , Z0) = (q1, Z0)

  10. Deterministic and Non-deterministic PDA

Related


More Related Content

giItT1WQy@!-/#giItT1WQy@!-/#