annotate src/whileLoopPSemSound.agda @ 1:73127e0ab57c

(none)
author soto@cr.ie.u-ryukyu.ac.jp
date Tue, 08 Sep 2020 18:38:08 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
1 loopPPSem : (input output : Envc ) → output ≡ loopPP (varn input) input refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
2 → (whileTestStateP s2 input ) → (whileTestStateP s2 input ) implies (whileTestStateP sf output)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
3 loopPPSem input output refl s2p = loopPPSemInduct (varn input) input refl refl s2p
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
4 where
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
5 lem : (n : ℕ) → (env : Envc) → n + suc (vari env) ≡ suc (n + vari env)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
6 lem n env = +-suc (n) (vari env)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
7 loopPPSemInduct : (n : ℕ) → (current : Envc) → (eq : n ≡ varn current) → (loopeq : output ≡ loopPP n current eq)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
8 → (whileTestStateP s2 current ) → (whileTestStateP s2 current ) implies (whileTestStateP sf output)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
9 loopPPSemInduct zero current refl loopeq refl rewrite loopeq = proof (λ x → refl)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
10 loopPPSemInduct (suc n) current refl loopeq refl rewrite (sym (lem n current)) =
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
11 whileLoopPSem current refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
12 (λ output x → loopPPSemInduct n (record { c10 = n + suc (vari current) ; varn = n ; vari = suc (vari current) }) refl loopeq refl)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
13 (λ output x → loopPPSemInduct n (record { c10 = n + suc (vari current) ; varn = n ; vari = suc (vari current) }) refl loopeq refl)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
14
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
15
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
16 whileLoopPSemSound : {l : Level} → (input output : Envc )
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
17 → (varn input + vari input ≡ c10 input)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
18 → output ≡ loopPP (varn input) input refl
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
19 → (varn input + vari input ≡ c10 input) implies (vari output ≡ c10 output)
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
20 whileLoopPSemSound {l} input output pre eq = loopPPSem input output eq pre