| Date |
Topics |
Readings |
Assignments |
| Sept 3 |
Introduction & Propositional logic. |
Bradley/Manna Ch 1 |
|
| Sept 8 |
SAT solving: DPLL and resolution. |
|
|
| Sept 10 |
SAT solving: CDCL -- web demo. |
Marques-Silva, Lynce, Malik: SAT handbook, Chapter 4 |
|
| Sept 15 |
Finite transition systems | and Binary Decision Diagrams.
|
PS1 due |
| Sept 17 |
Binary decision diagrams. |
Bryant: Graph-Based Algorithms for Boolean Function Manipulation |
|
| Sept 22 |
First-order logic. |
Bradley/Manna Ch 2 |
PS2 due |
| Sept 24 |
First-order theories. |
Bradley/Manna Ch 3 |
|
| Sept 29 |
SMT solving. |
De Moura, Bjørner: Satisfiability Modulo Theories: Introduction and Applications |
PS3 due |
| Oct 1 |
SMT solving. |
Barrett, Sebastiani, Seisha, Tinelli: SAT handbook, Chapter 26 |
|
| Oct 6 |
Midterm review. |
|
PS4 due |
| Oct 8 |
Midterm exam. |
|
|
| Oct 13,15 |
Fall break |
| |
| Oct 20 |
Programs, operational semantics, and partial correctness. |
Bradley/Manna Ch 4-6 Hoare: An axiomatic basis for computer programming
|
|
| Oct 22 |
Termination and total correctness. |
|
|
| Oct 27 |
Semi-automated verification. |
Bradley/Manna Ch 12 |
Project outline due |
| Oct 29 |
Invariant inference I: control flow, Floyd's logic, and Houdini |
|
|
| Nov 3 |
Invariant inference II: data flow analysis |
|
PS5 due |
| Nov 5 |
Abstract interpretation. |
|
|
| Nov 10 |
Algebraic program analysis. |
Kincaid, Reps, Cyphert: Algebraic program analysis |
PS6 due |
| Nov 12 |
Software model checking I. |
Jhala, Majumdar: Software Model Checking |
|
| Nov 17 |
Software model checking II. |
|
|
| Nov 19 |
Quantifiers and synthesis. |
| |
| Nov 24 |
Temporal logic. |
|
|
| Nov 26 |
Thanksgiving break |
|
|
| Dec 1 |
Project presentations |
| |
| Dec 3 |
Project presentations |
| |
| Dec 12 |
Dean's date |
|
Project report due |