Lecture 1: Introduction
Introduction
Regular word languages
-
regular expressions: denotational
-
finite automata: operational
-
MSO: logic
-
finite moinoids: algebraic, reason about the infixes of the language
-
- aperiodic monoids ⇔ first order logic
-
regular tree expressions, finite algebra: not that easy to manipulate…
Definitions
Tree
- A ranked alphabet:
-
is a pair
where
notations:
for with arity ,
Rooted, ordered, labelled, finite trees
- as partial functions:
-
let
be a ranked alphabet. A partial function is a tree iff-
is finite an non-empty -
is prefixed-closed: -
labels are consistent with
: for some implies
-
notation:
- the subtree of
at is: -
, defined by
- A non-deterministic finite tree automaton (NFTA) is:
-
a tuple
where is a finite set of states is a finite ranked alphabet is a set of final states
- A run of
on a tree is: -
a tree in
where such that
A run
- The language of
is: -
Example:
Example:
-
, -
Bottom-up
- Inductive definition:
-
let
be a ranked alphabet s.t. is a tree- if
are trees and , then is a tree
Let
We set
A tree in
- A substitution:
-
is a function
with finite
It defines a function
thus
Example:
if
⇓
- A term
is linear: -
if every variable of
appears at most once in - A context:
-
is a term in
where occurs exactly once.
notation :
is an instance of .- a term in
with no variables is a ground term.
Example:
⇓
and
notations:
- A term rewriting system
over : -
is a set of pairs
with and , where
- iff
and a substitution s.t. and
Example:
1)
2)
Example 2: It doesn’t work there:
where
Bottom-up tree automata
Given a NFTA
for all and using for all
Proposition:
Example: when it comes to the previous example related to logical formulas:
Other view:
and
in that view:
- a NFTA is complete:
-
if
s.t.
NB: If
- a NFTA is deterministic:
-
if
s.t.
NB: If
NB: If
Closure properties
As for word automata, one can complete and determinize any NFTA.
Proposition: Given a NTFA
, we can construct an equivalent complete NTFA .
We send any missing transition to the sink:
Proposition: Given a NTFA
, we can construct an equivalent complete and deterministic TFA .
Closure properties
Boolean closure quite similar to the word case:
-
Union is disjoint union of tree automata
-
Complementation: determinize, then complement
-
Intersection: product automaton
Top-down tree automata
Given a NFTA
for all and using for all
Proposition:
Example:
If the language is
then
(chap. 1, 3, 8)
Leave a comment