Differences between revisions 1 and 16 (spanning 15 versions)
Revision 1 as of 2017-04-17 11:20:01
Size: 40
Editor: rupak
Comment:
Revision 16 as of 2017-04-17 11:59:49
Size: 11815
Editor: rupak
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
Advanced Automata Theory (Summer 2017) #acl rupak,neider,burcu,akschmuck:read,write,delete,revert,admin All:read
= Course: Advanced Automata Theory =
'''Summer 2017'''

 * '''Instructor''':
  . [[http://www.mpi-sws.org/~rupak/|Rupak Majumdar]] ( rupak@mpi-sws.org ) Room 414, Building 26 (MPI-SWS)

  . [[http://www.mpi-sws.org/~neider/|Daniel Neider]] ( neider@mpi-sws.org ) Room 315, Building 26 (MPI-SWS)

 * '''Teaching assistants''':
  . [[http://www.mpi-sws.org/~burcu/|Dr. Burcu Ozkan]] ( burcu@mpi-sws.org )

  . [[http://www.mpi-sws.org/~akschmuck/|Dr. Anne-Kathrin Schmuck]] ( akschmuck@mpi-sws.org )

 * '''Lectures''':
  . Tuesdays 08:15-09:45 48-210 and Wednesdays 13:45-15:15 46-280

 * '''Tutorial''': Tuesday 10:00-11:30

 * '''Office hours''': By appointment

 * '''Mailing list''': TBD

== Introduction ==
 * '''Syllabus and contents.'''

We shall study automata on finite/infinite words and trees and their relationship to logic and computer-aided verification of systems.

 * '''Intended Audience.'''

Computer science or math students with background in logic and theory of computation. (Familiarity with basic algorithms, logic, and theory of computation will be assumed). Talk to the instructor if you are not sure if you have the background. We shall try to keep the class self-contained, please attend the initial lecture for background material.

Further, I expect you (1) have "mathematical maturity" (e.g., you should be comfortable with proofs and abstract reasoning); (2) are interested in the material; and (3) are willing to spend time outside of class in order to better understand the material presented in lectures.

 * '''Grading'''

Grading will be based on a written, open-notes, final exam. Open notes means that you are free to bring your notes to the exam. However, you may not use internet access on any device during an exam.

In order to appear for the exam, you have to turn in homework problems (to be assigned approximately biweekly), write up lecture notes for two lectures, and present a result to the class.

 * '''Text book'''

The following text books cover most of the material:

 a. '''Michael Sipser''', ''Introduction to the theory of computation'', MIT Press b. '''Graedel, Thomas, Wilke''', '' [[https://link.springer.com/book/10.1007/3-540-36387-4|Automata, Logics, and Infinite Games]]'', Springer

In addition, we shall provide lecture notes, surveys, or research papers for topics not covered in these books.

 * '''Homework:'''

Homework exercises will be handed out approximately every two weeks (weekday TBA). Your answers must be handed in until the day specified in the homework, at the beginning of the lecture.

 * '''Teamwork and Academic Honesty''':

Students may collaborate on homework assignments, but each student needs to individually write up a solution set and be prepared to present it in class on the due date. The work you submit in this course must be the result of your individual effort. You may discuss homework problems and general proof strategies or algorithms with other students in the course, but you must not collaborate in the detailed development or actual writing of problem sets. This implies that one student should never have in his or her possession a copy of all or part of another student's homework. It is your responsibility to protect your work from unauthorized access. In writing up your homework you are allowed to use any book, paper, or published material. However, you are not allowed to ask others for specific solutions, either in person or by using electronic forums such as newsgroups. Of course, during the administration of exams any form of cooperation or help is forbidden. Academic dishonesty has no place in a university; it wastes our time and yours, and it is unfair to the majority of students. Any dishonest behavior will be severely penalized and may lead to failure in the course.

== Announcements ==
 * The first lecture is on April 18, 2017.

== Schedule ==
This schedule is preliminary and subject to change.
||# ||<4% style="&quot; &amp; quot; &amp; amp; quot; &amp; amp; amp; quot;font-weight:bold; &amp; amp; amp; quot; ;text-align:center&amp; amp; quot; &amp; quot; &quot; ">Date ||<30% style="&quot; &amp; quot; &amp; amp; quot; &amp; amp; amp; quot;font-weight:bold; &amp; amp; amp; quot; ;text-align:center&amp; amp; quot; &amp; quot; &quot; ">Course topic / lecture ||<20% style="&quot; &amp; quot; &amp; amp; quot; &amp; amp; amp; quot;font-weight:bold; &amp; amp; amp; quot; &amp; amp; quot; &amp; quot; &quot; ">Homework ||<35% style="&quot; &amp; quot; &amp; amp; quot; &amp; amp; amp; quot;font-weight:bold; &amp; amp; amp; quot; &amp; amp; quot; &amp; quot; &quot; ">Additional Materials (lecture notes/papers) || ||
||L1 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">April 23 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Introduction to formal verification || || || ||
|| ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">April 25 || || || || ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #F5FAFA&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">L2 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">April 28 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Preliminaries: graph algorithms, automata theory ||[[attachment:hw1.pdf|Homework 1.]] Need not be turned in. ||[[attachment:Lecture2.pdf|Lecture notes]] || ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #F5FAFA&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">L3 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">April 30 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Preliminaries: propositional logic || ||[[attachment:Lecture3.pdf|Lecture notes]]<<BR>>[[http://ipsc.ksp.sk/2013/real/problems/l.html|Problem L (Labyrinth).]] [[https://github.com/fniksic/labyrinth|Solution]].<<BR>>[[http://try.ocamlpro.com|Try OCaml]], [[http://ocaml.org/learn/|Learn OCaml]], [[https://realworldocaml.org|Real World OCaml]] || ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #C1DAD6&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">T1 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 2 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Solutions to Homework 1. || || || ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #F5FAFA&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">L4 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 5 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">The invariant verification problem. Enumerative invariant verification. Depth first search. Spin. || ||Notes from an unpublished text book by Rajeev Alur and Tom Henzinger: <<BR>> [[attachment:CavBook-1.pdf|The Reactive modules modeling language.]]<<BR>>[[attachment:CavBook-2.pdf|Invariant verification.]]<<BR>>[[http://spinroot.com/|SPIN]] web page. || ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #F5FAFA&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">L5 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 7 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Peterson's protocol. Heuristics for enumerative invariant verification. Symbolic invariant verification. Symbolic reachability. || ||[[attachment:CavBook-3.pdf|Alur and Henzinger. Symbolic graph representation.]] ||[[http://www.mpi-sws.org/seminars/vrs/2014-05-07_vrs.mpg|MPG (660 MB)]] ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #C1DAD6&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">T2 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 9 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Q & A || || || ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #F5FAFA&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">L6 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 12 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Symbolic model checking with SAT || ||[[attachment:Sharad Malik MOD Chapter.pdf|Malik and Weissenbacher. Boolean satisfiability solvers: Techniques and extensions.]]<<BR>>[[attachment:NieOT-JACM-06.pdf|Nieuwenhuis, Oliveras, and Tinelli. Solving SAT and SAT modulo theories: From an abstract Davis-Putnam-Logemann-Loveland procedure to DPLL(T).]] ||[[http://www.mpi-sws.org/seminars/vrs/2014-05-12_vrs.mpg|MPG (678 MB)]] ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #F5FAFA&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">L7 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 14 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Implementing a SAT Solver. BDDs. ||[[attachment:hw2.pdf|Homework 2.]] Due May 28, 2014. || ||[[http://www.mpi-sws.org/seminars/vrs/2014-05-14_vrs.mp4|MP4 (529 MB)]] ||
||<rowstyle="&quot; &amp; quot; &amp; amp; quot; #C1DAD6&amp; amp; amp; quot&amp; amp; quot; ; &amp; amp; amp; quot&amp; amp; quot&amp; quot; ; &amp; amp; quot&amp; quot&quot; ;&amp;quot&quot"style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">T3 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">May 16 ||<style="&quot; &amp; quot; &amp; amp; quot;text-align:center&amp; amp; quot; &amp; quot; &quot;">Q & A || || || ||

Course: Advanced Automata Theory

Summer 2017

Introduction

  • Syllabus and contents.

We shall study automata on finite/infinite words and trees and their relationship to logic and computer-aided verification of systems.

  • Intended Audience.

Computer science or math students with background in logic and theory of computation. (Familiarity with basic algorithms, logic, and theory of computation will be assumed). Talk to the instructor if you are not sure if you have the background. We shall try to keep the class self-contained, please attend the initial lecture for background material.

Further, I expect you (1) have "mathematical maturity" (e.g., you should be comfortable with proofs and abstract reasoning); (2) are interested in the material; and (3) are willing to spend time outside of class in order to better understand the material presented in lectures.

  • Grading

Grading will be based on a written, open-notes, final exam. Open notes means that you are free to bring your notes to the exam. However, you may not use internet access on any device during an exam.

In order to appear for the exam, you have to turn in homework problems (to be assigned approximately biweekly), write up lecture notes for two lectures, and present a result to the class.

  • Text book

The following text books cover most of the material:

  1. Michael Sipser, Introduction to the theory of computation, MIT Press b. Graedel, Thomas, Wilke, Automata, Logics, and Infinite Games, Springer

In addition, we shall provide lecture notes, surveys, or research papers for topics not covered in these books.

  • Homework:

Homework exercises will be handed out approximately every two weeks (weekday TBA). Your answers must be handed in until the day specified in the homework, at the beginning of the lecture.

  • Teamwork and Academic Honesty:

Students may collaborate on homework assignments, but each student needs to individually write up a solution set and be prepared to present it in class on the due date. The work you submit in this course must be the result of your individual effort. You may discuss homework problems and general proof strategies or algorithms with other students in the course, but you must not collaborate in the detailed development or actual writing of problem sets. This implies that one student should never have in his or her possession a copy of all or part of another student's homework. It is your responsibility to protect your work from unauthorized access. In writing up your homework you are allowed to use any book, paper, or published material. However, you are not allowed to ask others for specific solutions, either in person or by using electronic forums such as newsgroups. Of course, during the administration of exams any form of cooperation or help is forbidden. Academic dishonesty has no place in a university; it wastes our time and yours, and it is unfair to the majority of students. Any dishonest behavior will be severely penalized and may lead to failure in the course.

Announcements

  • The first lecture is on April 18, 2017.

Schedule

This schedule is preliminary and subject to change.

#

Date

Course topic / lecture

Homework

Additional Materials (lecture notes/papers)

L1

April 23

Introduction to formal verification

April 25

L2

April 28

Preliminaries: graph algorithms, automata theory

Homework 1. Need not be turned in.

Lecture notes

L3

April 30

Preliminaries: propositional logic

Lecture notes
Problem L (Labyrinth). Solution.
Try OCaml, Learn OCaml, Real World OCaml

T1

May 2

Solutions to Homework 1.

L4

May 5

The invariant verification problem. Enumerative invariant verification. Depth first search. Spin.

Notes from an unpublished text book by Rajeev Alur and Tom Henzinger:
The Reactive modules modeling language.
Invariant verification.
SPIN web page.

L5

May 7

Peterson's protocol. Heuristics for enumerative invariant verification. Symbolic invariant verification. Symbolic reachability.

Alur and Henzinger. Symbolic graph representation.

MPG (660 MB)

T2

May 9

Q & A

L6

May 12

Symbolic model checking with SAT

Malik and Weissenbacher. Boolean satisfiability solvers: Techniques and extensions.
Nieuwenhuis, Oliveras, and Tinelli. Solving SAT and SAT modulo theories: From an abstract Davis-Putnam-Logemann-Loveland procedure to DPLL(T).

MPG (678 MB)

L7

May 14

Implementing a SAT Solver. BDDs.

Homework 2. Due May 28, 2014.

MP4 (529 MB)

T3

May 16

Q & A

Courses/AdvancedAutomataTheory-SS2017 (last edited 2018-03-29 06:38:49 by neider)