-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathconv_eval.stt
147 lines (119 loc) · 3.75 KB
/
conv_eval.stt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
Bool : U
= (B : U) → B → B → B
true : Bool
= λ B t f. t
and : Bool → Bool → Bool
= λ a b B t f. a B (b B t f) f
Nat : U
= (n : U) → (n → n) → n → n
add : Nat → Nat → Nat
= λ a b n s z. a n s (b n s z)
mul : Nat → Nat → Nat
= λ a b n s. a n (b n s)
suc : Nat → Nat
= λ a n s z. s (a n s z)
Eq : {A : U} → A → A → U
= λ {A} x y. (P : A → U) → P x → P y
refl : {A : U}{x : A} → Eq {A} x x
= λ P px. px
n2 : Nat = λ N s z. s (s z)
n3 : Nat = λ N s z. s (s (s z))
n4 : Nat = λ N s z. s (s (s (s z)))
n5 : Nat = λ N s z. s (s (s (s (s z))))
n10 = mul n2 n5
n10b = mul n5 n2
n15 = add n10 n5
n15b = add n10b n5
n18 = add n15 n3
n18b = add n15b n3
n19 = add n15 n4
n19b = add n15b n4
n20 = mul n2 n10
n20b = mul n2 n10b
n21 = suc n20
n21b = suc n20b
n22 = suc n21
n22b = suc n21b
n23 = suc n22
n23b = suc n22b
n100 = mul n10 n10
n100b = mul n10b n10b
n10k = mul n100 n100
n10kb = mul n100b n100b
n100k = mul n10k n10
n100kb = mul n10kb n10b
n1M = mul n10k n100
n1Mb = mul n10kb n100b
n5M = mul n1M n5
n5Mb = mul n1Mb n5
n10M = mul n5M n2
n10Mb = mul n5Mb n2
Tree : U = (T : U) → (T → T → T) → T → T
leaf : Tree = λ T n l. l
node : Tree → Tree → Tree = λ t1 t2 T n l. n (t1 T n l) (t2 T n l)
fullTree : Nat → Tree
= λ n. n Tree (λ t. node t t) leaf
-- full tree with given trees at bottom level
fullTreeWithLeaf : Tree → Nat → Tree
= λ bottom n. n Tree (λ t. node t t) bottom
forceTree : Tree → Bool
= λ t. t Bool and true
t15 = fullTree n15
t15b = fullTree n15b
t18 = fullTree n18
t18b = fullTree n18b
t19 = fullTree n19
t19b = fullTree n19b
t20 = fullTree n20
t20b = fullTree n20b
t21 = fullTree n21
t21b = fullTree n21b
t22 = fullTree n22
t22b = fullTree n22b
t23 = fullTree n23
t23b = fullTree n23b
-- Warmup
--------------------------------------------------------------------------------
warmup : Eq n10M n10Mb = refl
-- Nat conversion
--------------------------------------------------------------------------------
convn1M [elabtime]: Eq n1M n1Mb = refl
convn5M [elabtime]: Eq n5M n5Mb = refl
convn10M [elabtime]: Eq n10M n10Mb = refl
-- Full tree conversion
--------------------------------------------------------------------------------
convt15 [elabtime] : Eq t15 t15b = refl
convt18 [elabtime] : Eq t18 t18b = refl
convt19 [elabtime] : Eq t19 t19b = refl
convt20 [elabtime] : Eq t20 t20b = refl
convt21 [elabtime] : Eq t21 t21b = refl
convt22 [elabtime] : Eq t22 t22b = refl
convt23 [elabtime] : Eq t23 t23b = refl
-- Full meta-containing tree conversion
--------------------------------------------------------------------------------
convmt15 [elabtime] : Eq t15b (fullTreeWithLeaf _ n15 ) = refl
convmt18 [elabtime] : Eq t18b (fullTreeWithLeaf _ n18 ) = refl
convmt19 [elabtime] : Eq t19b (fullTreeWithLeaf _ n19 ) = refl
convmt20 [elabtime] : Eq t20b (fullTreeWithLeaf _ n20 ) = refl
convmt21 [elabtime] : Eq t21b (fullTreeWithLeaf _ n21 ) = refl
convmt22 [elabtime] : Eq t22b (fullTreeWithLeaf _ n22 ) = refl
convmt23 [elabtime] : Eq t23b (fullTreeWithLeaf _ n23 ) = refl
-- Full tree forcing
--------------------------------------------------------------------------------
forcet15 [nftime] = forceTree t15
forcet18 [nftime] = forceTree t18
forcet19 [nftime] = forceTree t19
forcet20 [nftime] = forceTree t20
forcet21 [nftime] = forceTree t21
forcet22 [nftime] = forceTree t22
forcet23 [nftime] = forceTree t23
nft15 [nftime] = t15
nft18 [nftime] = t18
nft19 [nftime] = t19
nft20 [nftime] = t20
nft21 [nftime] = t21
nft22 [nftime] = t22
nft23 [nftime] = t23
-- Approximate conversion
--------------------------------------------------------------------------------
-- approxConvt22 [elabtime] : Eq t23 t23 = refl