data:image/s3,"s3://crabby-images/0ebbe/0ebbe8c6ec3221e876b425327384ef86b3b16c7a" alt="" |
|
data:image/s3,"s3://crabby-images/dc97b/dc97bfea0eeac3a3e4451a40ee947f2507bffded" alt="" |
|
Automata and Formal Languages 2020/21
|
|
data:image/s3,"s3://crabby-images/d175d/d175d4d378d564028f6c21e1fb3c676c616eb777" alt="" |
|
data:image/s3,"s3://crabby-images/14f92/14f92fcc55699aa1066331bb230cdafe4e9e9c59" alt="" |
This lecture requires basic knowledge in automata theory, e.g., obtained during the course 'Einführung in die theoretische Informatik'. A detailed description of the contents can be found in the lecture notes. Here is an outline:
Automata on finite words
- Automata classes and conversions
- Regular expressions, deterministic and nondetermistic automata
- Conversion algorithms
- Minimization and reduction
- Minimizing DFAs
- Reducing NFAs
- Boolean operations and tests
- Implementation on DFAs
- Membership, complement, union, intersection, emptiness, universality, inclusion, equality.
- Implementation on NFAs
- Membership, complement, union, intersection, emptiness, universality, inclusion, equality.
- Operations on relations
- Projection, join, post, pre.
- Operations on finite universes: decision diagrams.
- Automata and logic
- Applications: pattern-matching, verification, Presburger arithmetic
Automata on infinite words
- Automata classes and conversions
- Omega-regular expressions
- Büchi, Streett, and Rabin automata
- Boolean operations
- Union and intersection
- Complement
- Emptiness check
- Applications: verification using temporal logic