6.822 Formal Reasoning About Programs
Surveys techniques for rigorous mathematical reasoning about correctness of software, emphasizing commonalities across approaches. Introduces interactive computer theorem proving with the Coq proof assistant, which is used for all assignments, providing immediate feedback on soundness of logical arguments. Covers common program-proof techniques, including operational semantics, model checking, abstract interpretation, type systems, program logics, and their applications to functional, imperative, and concurrent programs. Develops a common conceptual framework based on invariants, abstraction, and modularity applied to state and labeled transition systems.
6.822 will be offered this semester (Spring 2018). It is instructed by A. Chlipala.
Lecture occurs 2:30 PM to 4:00 PM on Mondays and Wednesdays in 32-155.
This class counts for a total of 12 credits.
You can find more information at the MIT 6.822, Spring 2018 site.
© Copyright 2015 Yasyf Mohamedali