annotate prepaper/src/whileLoopPSem.agda.replaced @ 0:3dba680da508

init-test
author soto
date Tue, 08 Dec 2020 19:06:49 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3dba680da508 init-test
soto
parents:
diff changeset
1 whileLoopPSem : {l : Level} {t : Set l} @$\rightarrow$@ (input : Envc ) @$\rightarrow$@ (vari input) + (varn input) @$\equiv$@ (c10 input)
3dba680da508 init-test
soto
parents:
diff changeset
2 @$\rightarrow$@ (next : (output : Envc ) @$\rightarrow$@ ((vari input) + (varn input) @$\equiv$@ (c10 input) ) implies ((vari output) + (varn output) @$\equiv$@ (c10 output)) @$\rightarrow$@ t)
3dba680da508 init-test
soto
parents:
diff changeset
3 @$\rightarrow$@ (exit : (output : Envc ) @$\rightarrow$@ ((vari input) + (varn input) @$\equiv$@ (c10 input) ) implies ((vari output @$\equiv$@ c10 output)) @$\rightarrow$@ t) @$\rightarrow$@ t
3dba680da508 init-test
soto
parents:
diff changeset
4 whileLoopPSem env s next exit with varn env | s
3dba680da508 init-test
soto
parents:
diff changeset
5 ... | zero | _ = exit env (proof (@$\lambda$@ z @$\rightarrow$@ z))
3dba680da508 init-test
soto
parents:
diff changeset
6 ... | (suc varn ) | refl = next ( record env { varn = varn ; vari = suc (vari env) } ) (proof @$\lambda$@ x @$\rightarrow$@ +-suc varn (vari env) )
3dba680da508 init-test
soto
parents:
diff changeset
7
3dba680da508 init-test
soto
parents:
diff changeset
8
3dba680da508 init-test
soto
parents:
diff changeset
9 loopPPSem : (input output : Envc ) @$\rightarrow$@ output @$\equiv$@ loopPP (varn input) input refl
3dba680da508 init-test
soto
parents:
diff changeset
10 @$\rightarrow$@ (vari input) + (varn input) @$\equiv$@ (c10 input) @$\rightarrow$@ ((vari input) + (varn input) @$\equiv$@ (c10 input) ) implies ((vari output @$\equiv$@ c10 output))
3dba680da508 init-test
soto
parents:
diff changeset
11 loopPPSem input output refl s2p = loopPPSemInduct (varn input) input refl refl s2p
3dba680da508 init-test
soto
parents:
diff changeset
12 where
3dba680da508 init-test
soto
parents:
diff changeset
13 lem : (n : @$\mathbb{N}$@) @$\rightarrow$@ (env : Envc) @$\rightarrow$@ n + suc (vari env) @$\equiv$@ suc (n + vari env)
3dba680da508 init-test
soto
parents:
diff changeset
14 lem n env = +-suc (n) (vari env)
3dba680da508 init-test
soto
parents:
diff changeset
15 loopPPSemInduct : (n : @$\mathbb{N}$@) @$\rightarrow$@ (current : Envc) @$\rightarrow$@ (eq : n @$\equiv$@ varn current) @$\rightarrow$@ (loopeq : output @$\equiv$@ loopPP n current eq)
3dba680da508 init-test
soto
parents:
diff changeset
16 @$\rightarrow$@ ((vari current) + (varn current) @$\equiv$@ (c10 current) ) @$\rightarrow$@ ((vari current) + (varn current) @$\equiv$@ (c10 current) ) implies ((vari output @$\equiv$@ c10 output))
3dba680da508 init-test
soto
parents:
diff changeset
17 loopPPSemInduct zero current refl loopeq refl rewrite loopeq = proof (@$\lambda$@ x @$\rightarrow$@ refl)
3dba680da508 init-test
soto
parents:
diff changeset
18 loopPPSemInduct (suc n) current refl loopeq refl rewrite (sym (lem n current)) =
3dba680da508 init-test
soto
parents:
diff changeset
19 whileLoopPSem current refl
3dba680da508 init-test
soto
parents:
diff changeset
20 (@$\lambda$@ output x @$\rightarrow$@ loopPPSemInduct n (record { c10 = n + suc (vari current) ; varn = n ; vari = suc (vari current) }) refl loopeq refl)
3dba680da508 init-test
soto
parents:
diff changeset
21 (@$\lambda$@ output x @$\rightarrow$@ loopPPSemInduct n (record { c10 = n + suc (vari current) ; varn = n ; vari = suc (vari current) }) refl loopeq refl)