forked from CakeML/cakeml
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathBatchedQueueScript.sml
More file actions
68 lines (50 loc) · 1.89 KB
/
BatchedQueueScript.sml
File metadata and controls
68 lines (50 loc) · 1.89 KB
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
(*
This is an example of applying the translator to the Batched Queue
algorithm from Chris Okasaki's book.
*)
open HolKernel Parse boolLib bossLib; val _ = new_theory "BatchedQueue";
open listTheory arithmeticTheory ml_translatorLib ListProgTheory;
val _ = translation_extends "ListProg";
(* implementation *)
Datatype:
queue = QUEUE ('a list) ('a list)
End
val empty_def = mlDefine `
empty = QUEUE [] []`;
val is_empty_def = mlDefine `
(is_empty (QUEUE [] xs) = T) /\
(is_empty _ = F)`;
val checkf_def = mlDefine `
(checkf (QUEUE [] xs) = QUEUE (REVERSE xs) []) /\
(checkf q = q)`;
val snoc_def = mlDefine `
snoc (QUEUE f r) x = checkf (QUEUE f (x::r))`;
val head_def = mlDefine `
head (QUEUE (x::f) r) = x`;
val tail_def = mlDefine `
tail (QUEUE (x::f) r) = checkf (QUEUE f r)`;
(* verification proof *)
val queue_inv_def = Define `
queue_inv q (QUEUE xs ys) <=>
(q = xs ++ REVERSE ys) /\ ((xs = []) ==> (ys = []))`;
val empty_thm = Q.prove(
`!xs. queue_inv xs empty = (xs = [])`,
EVAL_TAC THEN SIMP_TAC std_ss []);
val is_empty_thm = Q.prove(
`!q xs. queue_inv xs q ==> (is_empty q = (xs = []))`,
Cases THEN Cases_on `l` THEN EVAL_TAC THEN SRW_TAC [] [REV_DEF]);
val snoc_thm = Q.prove(
`!q xs x. queue_inv xs q ==> queue_inv (xs ++ [x]) (snoc q x)`,
Cases THEN Cases_on `l` THEN FULL_SIMP_TAC (srw_ss())
[queue_inv_def,snoc_def,REVERSE_DEF,checkf_def,APPEND]);
val head_thm = Q.prove(
`!q x xs. queue_inv (x::xs) q ==> (head q = x)`,
Cases THEN Cases_on `l` THEN FULL_SIMP_TAC (srw_ss())
[queue_inv_def,head_def,REVERSE_DEF,checkf_def,APPEND]
THEN REPEAT STRIP_TAC THEN FULL_SIMP_TAC (srw_ss()) []);
val tail_thm = Q.prove(
`!q x xs. queue_inv (x::xs) q ==> queue_inv xs (tail q)`,
Cases THEN Cases_on `l` THEN EVAL_TAC THEN SRW_TAC [] []
THEN TRY (Cases_on `t`) THEN EVAL_TAC
THEN FULL_SIMP_TAC (srw_ss()) [REVERSE_DEF,REV_DEF]);
val _ = export_theory();