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 |