mirror of
https://github.com/achlipala/frap.git
synced 2025-01-23 14:56:11 +00:00
Merge pull request #40 from samuelgruetter/hoare_triple_big_step_while
explain hoare_triple_big_step_while
This commit is contained in:
commit
75c04e1448
1 changed files with 4 additions and 2 deletions
|
@ -138,8 +138,10 @@ Inductive hoare_triple : assertion -> cmd -> assertion -> Prop :=
|
|||
-> hoare_triple P' c Q'.
|
||||
|
||||
(* Let's prove that the intuitive description given above really applies to this
|
||||
* predicate. First, a lemma, which is difficult to summarize intuitively!
|
||||
* More or less precisely this obligation shows up in the main proof below. *)
|
||||
* predicate. First, a helper lemma which we will need in the main proof below.
|
||||
* It says that if the loop body preserves the invariant, and executing the loop
|
||||
* terminates, then after executing the loop, the invariant still holds, and the
|
||||
* loop condition is false. *)
|
||||
Lemma hoare_triple_big_step_while: forall (I : assertion) b c,
|
||||
(forall h v h' v', exec h v c h' v'
|
||||
-> I h v
|
||||
|
|
Loading…
Reference in a new issue