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