Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Reading: Chapter 2
The machine can exist in only one state at any given time
{Q, , q0,F, }
3
Input: a word w in *
Question: Is w acceptable by the DFA?
Steps:
Compute the next state from the current state, given the
current input symbol in w and the transition function
Regular Languages
Regular
(DFA)
Contextfree
(PDA)
Contextsensitive
(LBA)
Recursivelyenumerable
(TM)
Example #1
start
q0
0,1
0
0
q1
= {0,1}
start state = q0
q2
Accepting
state
states
Q = {q0,q1,q2}
F = {q2}
Transition table
symbols
0
q0
q1
q0
q1
q1
q2
*q2
q2
q2
8
Example #2
Clamping Logic:
State Design:
q0 : start state (initially off), also means the most recent input
was not a 1
q1: has never seen 11 but the most recent input was a 1
q2: has seen 11 at least once
9
Example #3
10
Extension of transitions () to
Paths ()
(q,wa) = ((q,w), a)
(q0,wa) = ?
11
Language of a DFA
A DFA A accepts string w if there is a path
from q0 to an accepting (or final) state
that is labeled by w
Non-deterministic Finite
Automata (NFA)
is of course non-deterministic
1
1
qj
qk
13
Non-deterministic Finite
Automata (NFA)
{Q, , q0,F, }
14
Input: a word w in *
Question: Is w acceptable by the NFA?
Steps:
Determine all possible next states from all current states, given
the current input symbol in w and the transition function
15
0,1
0,1
q0
q1
= {0,1}
start state = q0
q2
Final
state
F = {q2}
Transition table
symbols
states
start
Q = {q0,q1,q2}
q0
{q0,q1}
{q0}
q1
{q2}
*q2
{q2}
{q2}
16
Note: Omitting to explicitly show error states is just a matter of design convenience
(one that is generally followed for NFAs), and
i.e., this feature should not be confused with the notion of non-determinism.
q1
q2
q3
q4
q5
Any symbol
q1
q2
q3
q4
q5
Example #2
Induction:
19
Language of an NFA
20
21
22
But, DFAs and NFAs are equivalent in their power to capture langauges !!
1.
DFA
All transitions are
deterministic
2.
3.
4.
5.
1.
2.
3.
4.
5.
Should be
true for
any L
Proof:
1.
If part:
2.
Idea: Represent:
each subset of NFA_states a single DFA_state
Subset construction
25
Let N = {QN,,N,q0,FN}
Goal: Build D={QD,,D,{q0},FD} s.t.
L(D)=L(N)
Construction:
1.
2.
3.
p inU
s (p,a)
D(S,a) =
N
26
NFA:
DFA:
0,1
q0
q1
0
[q0]
q0
{q0,q1}
{q0}
q1
{q2}
*q2
[q0,q1]
1
0
[q0,q2]
q2
[q0]
[q0,q1]
[q0]
[q0]
{q0,q1}
{q0}
[q0,q1]
[q0,q1]
[q0,q2]
[q1]
{q2}
*[q0,q2]
[q0,q1]
[q0]
*[q2]
[q0,q1]
{q0,q1}
{q0,q2}
*[q0,q2]
{q0,q1}
{q0}
*[q1,q2]
{q2}
*[q0,q1,q2]
{q0,q1}
{q0,q2}
0.
Determine transitions
Retain only those states
reachable from {q0}
27
NFA:
DFA:
0,1
q0
q1
0
[q0]
q0
{q0,q1}
q1
*q2
1
0
[q0,q2]
q2
[q0,q1]
{q0}
[q0]
[q0,q1]
[q0]
{q2}
[q0,q1]
[q0,q1]
[q0,q2]
*[q0,q2]
[q0,q1]
[q0]
Main Idea:
Introduce states as you go
(on a need basis)
28
Let w = xa
D({q0},xa) D( N(q0,x}, a ) N(q0,w}
29
Applications
Text indexing
inverted indexing
For each unique word in the database, store all
locations that contain it using an NFA or a DFA
Example: Google querying
31
32
FA with -Transitions
Example of an -NFA
L = {w | w is empty, or if non-empty will end in 01}
0,1
start
q0
q1
q2
q0
E
*q0
{q0,q0}
q0
{q0,q1}
{q0}
{q0}
q1
{q2}
{q1}
*q2
{q2}
ECLOSE(q0)
ECLOSE(q0)
ECLOSE(q1)
ECLOSE(q2)
-closure of a state q,
Example of an -NFA
L = {w | w is empty, or if non-empty will end in 01}
0,1
start
q0
q1
q2
q0
q0
q0
q0
1
q0
0
1
E
*q0
{q0,q0}
q0
{q0,q1}
{q0}
{q0}
q1
{q2}
{q1}
*q2
{q2}
ECLOSE(q0)
q1
1
q2
ECLOSE(q0)
35
Example of another
-NFA
Simulate for
w=101:
?
0,1
q0
start
q1
1
1
q2
q3
q0
E
*q0
{q0,q0,q3}
q0
{q0,q1}
{q0}
{q0,q3}
q1
{q2}
{q1}
*q2
{q2}
q3
{q2}
{q3}
36
Implication:
Eliminating -transitions
Let E = {QE,,E,q0,FE} be an -NFA
Goal: To build DFA D={QD,,D,{qD},FD} s.t.
L(D)=L(E)
Construction:
1.
2.
3.
4.
Let R=
Ur inRE(p,a)
// go to destination states
start
q0
q1
q2
q0
E
*q0
{q0,q0}
q0
{q0,q1}
{q0}
{q0}
q1
{q2}
{q1}
*q2
{q2}
*{q0,q0}
39
0,1
start
q0
q1
q2
0
start
q0
ECLOSE
E
*q0
{q0,q0}
q0
{q0,q1}
{q0}
{q0}
q1
{q2}
{q1}
*q2
{q2}
{q0, q0}
{q0,q1}
0
1
{q0,q2}
1
1
q0
union
D
*{q0,q0}
{q0,q1}
{q0}
{q0,q1}
{q0,q1}
{q0,q2}
{q0}
{q0,q1}
{q0}
*{q0,q2}
{q0,q1}
{q0}
40
Summary
DFA
Definition
Transition diagrams & tables
Regular language
NFA
Definition
Transition diagrams & tables
DFA vs. NFA
NFA to DFA conversion using subset construction
Equivalency of DFA & NFA
Removal of redundant states and including dead states
-transitions in NFA
Pigeon hole principles
Text searching applications
41