mirror of
https://github.com/achlipala/frap.git
synced 2024-11-27 23:06:20 +00:00
Connecting: proved DeeplyEmbedded.hoare_triple_sound
This commit is contained in:
parent
625458d80e
commit
26abb7b8a0
1 changed files with 254 additions and 5 deletions
259
Connecting.v
259
Connecting.v
|
@ -503,12 +503,12 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
-> hoare_triple Q s2 R
|
-> hoare_triple Q s2 R
|
||||||
-> hoare_triple P (Seq s1 s2) R
|
-> hoare_triple P (Seq s1 s2) R
|
||||||
| HtIfThenElse : forall P e s1 s2 Q R,
|
| HtIfThenElse : forall P e s1 s2 Q R,
|
||||||
hoare_triple_exp P e Q
|
hoare_triple_exp P e (fun r V => Q r V * exists n, [| r = VScalar n |])%sep
|
||||||
-> hoare_triple (fun V => exists n, Q (VScalar n) V * [| n <> ^0 |])%sep s1 R
|
-> hoare_triple (fun V => exists n, Q (VScalar n) V * [| n <> ^0 |])%sep s1 R
|
||||||
-> hoare_triple (fun V => Q (VScalar (^0)) V)%sep s2 R
|
-> hoare_triple (fun V => Q (VScalar (^0)) V)%sep s2 R
|
||||||
-> hoare_triple P (IfThenElse e s1 s2) R
|
-> hoare_triple P (IfThenElse e s1 s2) R
|
||||||
| HtWhileLoop : forall I e s1 Q,
|
| HtWhileLoop : forall I e s1 Q,
|
||||||
hoare_triple_exp I e Q
|
hoare_triple_exp I e (fun r V => Q r V * exists n, [| r = VScalar n |])%sep
|
||||||
-> hoare_triple (fun V => exists n, Q (VScalar n) V * [| n <> ^0 |])%sep s1 I
|
-> hoare_triple (fun V => exists n, Q (VScalar n) V * [| n <> ^0 |])%sep s1 I
|
||||||
-> hoare_triple I (WhileLoop e s1) (Q (VScalar (^0)))
|
-> hoare_triple I (WhileLoop e s1) (Q (VScalar (^0)))
|
||||||
| HtConsequence : forall P s Q P' Q',
|
| HtConsequence : forall P s Q P' Q',
|
||||||
|
@ -863,7 +863,7 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
|
|
||||||
Lemma invert_IfThenElse : forall P e s1 s2 Q,
|
Lemma invert_IfThenElse : forall P e s1 s2 Q,
|
||||||
hoare_triple P (IfThenElse e s1 s2) Q
|
hoare_triple P (IfThenElse e s1 s2) Q
|
||||||
-> exists R, hoare_triple_exp P e R
|
-> exists R, hoare_triple_exp P e (fun r V => R r V * exists n, [| r = VScalar n |])%sep
|
||||||
/\ hoare_triple (fun V => exists n, R (VScalar n) V * [| n <> ^0 |])%sep s1 Q
|
/\ hoare_triple (fun V => exists n, R (VScalar n) V * [| n <> ^0 |])%sep s1 Q
|
||||||
/\ hoare_triple (fun V => R (VScalar (^0)) V)%sep s2 Q.
|
/\ hoare_triple (fun V => R (VScalar (^0)) V)%sep s2 Q.
|
||||||
Proof.
|
Proof.
|
||||||
|
@ -873,6 +873,7 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
eapply HtExpConsequence.
|
eapply HtExpConsequence.
|
||||||
eassumption.
|
eassumption.
|
||||||
assumption.
|
assumption.
|
||||||
|
simplify.
|
||||||
reflexivity.
|
reflexivity.
|
||||||
eapply HtStrengthen.
|
eapply HtStrengthen.
|
||||||
eassumption.
|
eassumption.
|
||||||
|
@ -882,6 +883,13 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
assumption.
|
assumption.
|
||||||
|
|
||||||
exists (fun r V => x r V * R V)%sep; propositional.
|
exists (fun r V => x r V * R V)%sep; propositional.
|
||||||
|
eapply HtExpConsequence.
|
||||||
|
eapply HtExpFrame.
|
||||||
|
eauto.
|
||||||
|
simplify.
|
||||||
|
reflexivity.
|
||||||
|
simplify.
|
||||||
|
cancel.
|
||||||
eauto.
|
eauto.
|
||||||
eapply HtWeaken.
|
eapply HtWeaken.
|
||||||
eapply HtFrame.
|
eapply HtFrame.
|
||||||
|
@ -903,7 +911,7 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
Lemma invert_WhileLoop : forall P e s1 Q,
|
Lemma invert_WhileLoop : forall P e s1 Q,
|
||||||
hoare_triple P (WhileLoop e s1) Q
|
hoare_triple P (WhileLoop e s1) Q
|
||||||
-> exists I R, (forall V, P V ===> I V)
|
-> exists I R, (forall V, P V ===> I V)
|
||||||
/\ hoare_triple_exp I e R
|
/\ hoare_triple_exp I e (fun r V => R r V * exists n, [| r = VScalar n |])%sep
|
||||||
/\ hoare_triple (fun V => exists n, R (VScalar n) V * [| n <> ^0 |])%sep s1 I
|
/\ hoare_triple (fun V => exists n, R (VScalar n) V * [| n <> ^0 |])%sep s1 I
|
||||||
/\ (forall V, R (VScalar (^0)) V ===> Q V).
|
/\ (forall V, R (VScalar (^0)) V ===> Q V).
|
||||||
Proof.
|
Proof.
|
||||||
|
@ -917,6 +925,13 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
|
|
||||||
exists (fun V => x V * R V)%sep, (fun r V => x0 r V * R V)%sep; propositional.
|
exists (fun V => x V * R V)%sep, (fun r V => x0 r V * R V)%sep; propositional.
|
||||||
rewrite H1; reflexivity.
|
rewrite H1; reflexivity.
|
||||||
|
eapply HtExpConsequence.
|
||||||
|
eapply HtExpFrame.
|
||||||
|
eauto.
|
||||||
|
simplify.
|
||||||
|
reflexivity.
|
||||||
|
simplify.
|
||||||
|
cancel.
|
||||||
eauto.
|
eauto.
|
||||||
eapply HtWeaken.
|
eapply HtWeaken.
|
||||||
eauto.
|
eauto.
|
||||||
|
@ -1055,6 +1070,11 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
unfold himp; propositional; subst.
|
unfold himp; propositional; subst.
|
||||||
eapply preservation_exp in H0; eauto.
|
eapply preservation_exp in H0; eauto.
|
||||||
exists n, H', $0; propositional; eauto.
|
exists n, H', $0; propositional; eauto.
|
||||||
|
invert H0; simp.
|
||||||
|
invert H7.
|
||||||
|
invert H6.
|
||||||
|
apply split_empty_fwd in H4; subst.
|
||||||
|
auto.
|
||||||
constructor; auto.
|
constructor; auto.
|
||||||
simplify; auto.
|
simplify; auto.
|
||||||
|
|
||||||
|
@ -1063,6 +1083,19 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
simplify.
|
simplify.
|
||||||
unfold himp; propositional; subst.
|
unfold himp; propositional; subst.
|
||||||
eapply preservation_exp in H0; eauto.
|
eapply preservation_exp in H0; eauto.
|
||||||
|
eapply HtExpConsequence.
|
||||||
|
eauto.
|
||||||
|
simplify.
|
||||||
|
instantiate (1 := fun V H'0 => H'0 = H' /\ V = V').
|
||||||
|
simplify.
|
||||||
|
reflexivity.
|
||||||
|
simplify.
|
||||||
|
unfold himp; simplify.
|
||||||
|
invert H3; simp.
|
||||||
|
invert H7.
|
||||||
|
invert H6.
|
||||||
|
apply split_empty_fwd in H4; subst.
|
||||||
|
auto.
|
||||||
simplify; auto.
|
simplify; auto.
|
||||||
|
|
||||||
apply invert_WhileLoop in H; first_order.
|
apply invert_WhileLoop in H; first_order.
|
||||||
|
@ -1072,6 +1105,11 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
unfold himp; propositional; subst.
|
unfold himp; propositional; subst.
|
||||||
eapply preservation_exp in H0; eauto.
|
eapply preservation_exp in H0; eauto.
|
||||||
exists n, H', $0; propositional; eauto.
|
exists n, H', $0; propositional; eauto.
|
||||||
|
invert H0; simp.
|
||||||
|
invert H8.
|
||||||
|
invert H7.
|
||||||
|
apply split_empty_fwd in H5; subst.
|
||||||
|
auto.
|
||||||
constructor; auto.
|
constructor; auto.
|
||||||
apply H; simplify; auto.
|
apply H; simplify; auto.
|
||||||
eapply HtStrengthen.
|
eapply HtStrengthen.
|
||||||
|
@ -1084,6 +1122,12 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
unfold himp; propositional; subst.
|
unfold himp; propositional; subst.
|
||||||
eapply preservation_exp in H0; eauto.
|
eapply preservation_exp in H0; eauto.
|
||||||
apply H3; auto.
|
apply H3; auto.
|
||||||
|
simplify.
|
||||||
|
invert H0; simp.
|
||||||
|
invert H7.
|
||||||
|
invert H6.
|
||||||
|
apply split_empty_fwd in H4; subst.
|
||||||
|
auto.
|
||||||
apply H; simplify; auto.
|
apply H; simplify; auto.
|
||||||
Qed.
|
Qed.
|
||||||
|
|
||||||
|
@ -1112,6 +1156,200 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
eapply preservation; eauto.
|
eapply preservation; eauto.
|
||||||
Qed.
|
Qed.
|
||||||
|
|
||||||
|
Lemma progress_exp : forall P e Q,
|
||||||
|
hoare_triple_exp P e Q
|
||||||
|
-> forall V H H1 H2, split H H1 H2
|
||||||
|
-> disjoint H1 H2
|
||||||
|
-> P V H1
|
||||||
|
-> exists v, eval H V e v.
|
||||||
|
Proof.
|
||||||
|
induct 1; simplify; eauto.
|
||||||
|
|
||||||
|
invert H4.
|
||||||
|
invert H5.
|
||||||
|
eauto.
|
||||||
|
|
||||||
|
invert H4.
|
||||||
|
invert H5.
|
||||||
|
eexists.
|
||||||
|
econstructor.
|
||||||
|
eauto.
|
||||||
|
|
||||||
|
invert H4.
|
||||||
|
invert H5; simp.
|
||||||
|
invert H6.
|
||||||
|
apply split_empty_fwd' in H4; subst.
|
||||||
|
invert H8.
|
||||||
|
invert H1; simp.
|
||||||
|
invert H6.
|
||||||
|
cases x1.
|
||||||
|
eexists.
|
||||||
|
econstructor.
|
||||||
|
eauto.
|
||||||
|
unfold heap1, split in *; subst.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify.
|
||||||
|
eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
eapply lookup_Some_dom; simplify.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify; eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
|
||||||
|
invert H4.
|
||||||
|
invert H5; simp.
|
||||||
|
invert H6.
|
||||||
|
apply split_empty_fwd' in H4; subst.
|
||||||
|
invert H8.
|
||||||
|
invert H1; simp.
|
||||||
|
invert H6.
|
||||||
|
cases x1.
|
||||||
|
eexists.
|
||||||
|
econstructor.
|
||||||
|
eauto.
|
||||||
|
unfold heap1, split in *; subst.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify.
|
||||||
|
eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
eapply lookup_Some_dom; simplify.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify; eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
|
||||||
|
invert H4.
|
||||||
|
invert H5.
|
||||||
|
eauto.
|
||||||
|
|
||||||
|
eapply IHhoare_triple_exp; eauto.
|
||||||
|
apply H0; auto.
|
||||||
|
|
||||||
|
invert H5; simp.
|
||||||
|
eapply IHhoare_triple_exp in H7; eauto.
|
||||||
|
Qed.
|
||||||
|
|
||||||
|
Lemma progress : forall P s Q,
|
||||||
|
hoare_triple P s Q
|
||||||
|
-> forall V H H1 H2, split H H1 H2
|
||||||
|
-> disjoint H1 H2
|
||||||
|
-> P V H1
|
||||||
|
-> s = Skip \/ (exists H' V' s', step (H, V, s) (H', V', s')).
|
||||||
|
Proof.
|
||||||
|
induct 1; simplify; eauto.
|
||||||
|
|
||||||
|
eapply (progress_exp _ _ _ H) in H5; eauto.
|
||||||
|
simp.
|
||||||
|
right; do 3 eexists.
|
||||||
|
econstructor.
|
||||||
|
eauto.
|
||||||
|
|
||||||
|
pose proof (progress_exp _ _ _ H _ _ _ _ H3 H4 H5) as Hprog.
|
||||||
|
invert Hprog.
|
||||||
|
assert (Hdropped : eval H1 V e x0).
|
||||||
|
eapply drop_cells; eauto.
|
||||||
|
unfold split in H3; subst.
|
||||||
|
simplify.
|
||||||
|
rewrite lookup_join1; auto.
|
||||||
|
eapply lookup_Some_dom; eauto.
|
||||||
|
pose proof (preservation_exp _ _ _ H _ _ _ H5 Hdropped) as Hpres.
|
||||||
|
simplify.
|
||||||
|
invert Hpres.
|
||||||
|
invert H7; simp.
|
||||||
|
invert H9.
|
||||||
|
apply split_empty_fwd' in H8; subst.
|
||||||
|
invert H11.
|
||||||
|
invert H1.
|
||||||
|
invert H8; simp.
|
||||||
|
invert H9.
|
||||||
|
right; do 3 eexists.
|
||||||
|
econstructor.
|
||||||
|
eauto.
|
||||||
|
eauto.
|
||||||
|
unfold heap1, split in *; subst.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify.
|
||||||
|
eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
eapply lookup_Some_dom; simplify.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify; eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
|
||||||
|
pose proof (progress_exp _ _ _ H _ _ _ _ H3 H4 H5) as Hprog.
|
||||||
|
invert Hprog.
|
||||||
|
assert (Hdropped : eval H1 V e x0).
|
||||||
|
eapply drop_cells; eauto.
|
||||||
|
unfold split in H3; subst.
|
||||||
|
simplify.
|
||||||
|
rewrite lookup_join1; auto.
|
||||||
|
eapply lookup_Some_dom; eauto.
|
||||||
|
pose proof (preservation_exp _ _ _ H _ _ _ H5 Hdropped) as Hpres.
|
||||||
|
simplify.
|
||||||
|
invert Hpres.
|
||||||
|
invert H7; simp.
|
||||||
|
invert H9.
|
||||||
|
apply split_empty_fwd' in H8; subst.
|
||||||
|
invert H11.
|
||||||
|
invert H1.
|
||||||
|
invert H8; simp.
|
||||||
|
invert H9.
|
||||||
|
right; do 3 eexists.
|
||||||
|
econstructor.
|
||||||
|
eauto.
|
||||||
|
eauto.
|
||||||
|
unfold heap1, split in *; subst.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify.
|
||||||
|
eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
eapply lookup_Some_dom; simplify.
|
||||||
|
rewrite lookup_join1.
|
||||||
|
simplify; eauto.
|
||||||
|
eapply lookup_Some_dom; simplify; sets.
|
||||||
|
|
||||||
|
specialize (IHhoare_triple1 _ _ _ _ H4 H5 H6); simp; eauto 6.
|
||||||
|
|
||||||
|
pose proof (progress_exp _ _ _ H _ _ _ _ H5 H6 H7) as Hprog.
|
||||||
|
invert Hprog.
|
||||||
|
assert (Hdropped : eval H3 V e x).
|
||||||
|
eapply drop_cells; eauto.
|
||||||
|
unfold split in H5; subst.
|
||||||
|
simplify.
|
||||||
|
rewrite lookup_join1; auto.
|
||||||
|
eapply lookup_Some_dom; eauto.
|
||||||
|
pose proof (preservation_exp _ _ _ H _ _ _ H7 Hdropped) as Hpres.
|
||||||
|
simplify.
|
||||||
|
invert Hpres; simp.
|
||||||
|
invert H13.
|
||||||
|
invert H12.
|
||||||
|
cases (weq x2 (^0)); subst; eauto 10.
|
||||||
|
|
||||||
|
pose proof (progress_exp _ _ _ H _ _ _ _ H4 H5 H6) as Hprog.
|
||||||
|
invert Hprog.
|
||||||
|
assert (Hdropped : eval H2 V e x).
|
||||||
|
eapply drop_cells; eauto.
|
||||||
|
unfold split in H4; subst.
|
||||||
|
simplify.
|
||||||
|
rewrite lookup_join1; auto.
|
||||||
|
eapply lookup_Some_dom; eauto.
|
||||||
|
pose proof (preservation_exp _ _ _ H _ _ _ H6 Hdropped) as Hpres.
|
||||||
|
simplify.
|
||||||
|
invert Hpres; simp.
|
||||||
|
invert H12.
|
||||||
|
invert H11.
|
||||||
|
cases (weq x2 (^0)); subst; eauto 10.
|
||||||
|
|
||||||
|
apply H0 in H7.
|
||||||
|
eapply IHhoare_triple in H7; eauto.
|
||||||
|
|
||||||
|
invert H6; simp.
|
||||||
|
eapply IHhoare_triple in H8; eauto.
|
||||||
|
Qed.
|
||||||
|
|
||||||
Theorem hoare_triple_sound : forall P s Q,
|
Theorem hoare_triple_sound : forall P s Q,
|
||||||
hoare_triple P s Q
|
hoare_triple P s Q
|
||||||
-> forall H V, P V H
|
-> forall H V, P V H
|
||||||
|
@ -1123,6 +1361,17 @@ Module DeeplyEmbedded(Import BW : BIT_WIDTH).
|
||||||
eapply invariant_weaken.
|
eapply invariant_weaken.
|
||||||
eapply hoare_triple_sound'; eauto.
|
eapply hoare_triple_sound'; eauto.
|
||||||
simplify.
|
simplify.
|
||||||
Admitted.
|
|
||||||
|
cases s0.
|
||||||
|
cases p.
|
||||||
|
simplify.
|
||||||
|
pose proof (progress _ _ _ H2 v h h $0) as Hprog; simplify.
|
||||||
|
cases Hprog; eauto.
|
||||||
|
subst.
|
||||||
|
eapply invert_Skip in H2.
|
||||||
|
left; propositional.
|
||||||
|
apply H2; auto.
|
||||||
|
first_order.
|
||||||
|
Qed.
|
||||||
|
|
||||||
End DeeplyEmbedded.
|
End DeeplyEmbedded.
|
||||||
|
|
Loading…
Reference in a new issue