Formal Reasoning About Programs
Find a file
2016-03-04 16:14:41 -05:00
.gitignore Ignore .coq-native 2016-02-22 10:36:30 -05:00
_CoqProject Add Imp, recapping OperationalSemantics object language and semantics 2016-03-04 12:49:08 -05:00
AbstractInterpretation.v More on AbstractInterpretation example; need to do a proper abstraction into a new trsys 2016-03-04 16:14:41 -05:00
BasicSyntax.v Pass over BasicSyntax, adding template 2016-02-03 08:39:24 -05:00
BasicSyntax_template.v For Coq 8.5 compatibility, use [Admitted] instead of [admit] 2016-02-09 18:10:58 -05:00
Frap.v Fancier set simplification 2016-02-23 18:59:50 -05:00
frap_book.tex Extend tactic reference and update README 2016-02-28 14:55:27 -05:00
Imp.v Add Imp, recapping OperationalSemantics object language and semantics 2016-03-04 12:49:08 -05:00
index.html Incorporating a variety of changes and pull requests, after things got desync'd a bit 2016-02-09 20:21:19 -05:00
Interpreters.v Rename [map] to [fmap] 2016-02-09 09:07:37 -05:00
Interpreters_template.v For Coq 8.5 compatibility, use [Admitted] instead of [admit] 2016-02-09 18:10:58 -05:00
Invariant.v Add [parallel] to libary 2016-02-22 17:28:40 -05:00
Makefile New Makefile target: lib, to build just the library, not the lecture code 2016-02-14 22:07:29 -05:00
Map.v More on AbstractInterpretation example; need to do a proper abstraction into a new trsys 2016-03-04 16:14:41 -05:00
ModelCheck.v Tweak model-checking library support 2016-02-21 17:00:01 -05:00
ModelChecking.v Tweaked Ltac singletoner to display state space exploration in real time 2016-02-22 17:53:31 -05:00
ModelChecking_template.v ModelChecking_template 2016-02-22 09:45:53 -05:00
OperationalSemantics.v Add Imp, recapping OperationalSemantics object language and semantics 2016-03-04 12:49:08 -05:00
OperationalSemantics_template.v OperationalSemantics_template (really this time) 2016-02-29 09:29:55 -05:00
README.md Extend tactic reference and update README 2016-02-28 14:55:27 -05:00
Relations.v Start of BasicSyntax code 2015-12-31 15:44:34 -05:00
Sets.v Fixed to work in Coq 8.4, too 2016-02-18 17:51:58 -05:00
TransitionSystems.v Harmonize inductive-definition convention 2016-02-16 11:41:30 -05:00
TransitionSystems_template.v Harmonize inductive-definition convention 2016-02-16 11:41:30 -05:00
Var.v Interpreters: factorial example 2016-02-06 22:09:37 -05:00

Formal Reasoning About Programs

This is an in-progress, open-source book by Adam Chlipala simultaneously introducing the Coq proof assistant and techniques for proving correctness of programs. That is, the game is doing completely rigorous, machine-checked mathematical proofs, showing that programs meet their specifications.

Just run make here to build everything, including the book frap.pdf and the accompanying Coq source modules.

Code associated with the different chapters

  • Chapter 2: BasicSyntax.v
  • Chapter 3: Interpreters.v
  • Chapter 4: TransitionSystems.v
  • Chapter 5: ModelChecking.v
  • Chapter 6: OperationalSemantics.v