1461
|
1 |
(* Title: ZF/IMP/Com.ML
|
482
|
2 |
ID: $Id$
|
1461
|
3 |
Author: Heiko Loetzbeyer & Robert Sandner, TUM
|
482
|
4 |
Copyright 1994 TUM
|
|
5 |
*)
|
|
6 |
|
4091
|
7 |
val type_cs = claset() addSDs [evala.dom_subset RS subsetD,
|
2469
|
8 |
evalb.dom_subset RS subsetD,
|
|
9 |
evalc.dom_subset RS subsetD];
|
511
|
10 |
|
|
11 |
(********** type_intrs for evala **********)
|
|
12 |
|
|
13 |
val evala_type_intrs =
|
|
14 |
map (fn s => prove_goal Com.thy s (fn _ => [(fast_tac type_cs 1)]))
|
1420
|
15 |
["!!a.<a,sigma> -a-> n ==> a:aexp",
|
|
16 |
"!!a.<a,sigma> -a-> n ==> sigma:loc->nat",
|
511
|
17 |
"!!a.<a,sigma> -a-> n ==> n:nat"];
|
|
18 |
|
|
19 |
|
|
20 |
(********** type_intrs for evalb **********)
|
482
|
21 |
|
511
|
22 |
val evalb_type_intrs =
|
|
23 |
map (fn s => prove_goal Com.thy s (fn _ => [(fast_tac type_cs 1)]))
|
1420
|
24 |
["!!b.<b,sigma> -b-> w ==> b:bexp",
|
|
25 |
"!!b.<b,sigma> -b-> w ==> sigma:loc->nat",
|
511
|
26 |
"!!b.<b,sigma> -b-> w ==> w:bool"];
|
|
27 |
|
|
28 |
|
|
29 |
(********** type_intrs for evalb **********)
|
482
|
30 |
|
511
|
31 |
val evalc_type_intrs =
|
|
32 |
map (fn s => prove_goal Com.thy s (fn _ => [(fast_tac type_cs 1)]))
|
|
33 |
["!!c.<c,sigma> -c-> sigma' ==> c:com",
|
|
34 |
"!!c.<c,sigma> -c-> sigma' ==> sigma:loc->nat",
|
|
35 |
"!!c.<c,sigma> -c-> sigma' ==> sigma':loc->nat"];
|
|
36 |
|
|
37 |
|
|
38 |
val op_type_intrs = evala_type_intrs@evalb_type_intrs@evalc_type_intrs;
|
|
39 |
|
|
40 |
|
|
41 |
val aexp_elim_cases =
|
|
42 |
[
|
6141
|
43 |
evala.mk_cases "<N(n),sigma> -a-> i",
|
|
44 |
evala.mk_cases "<X(x),sigma> -a-> i",
|
|
45 |
evala.mk_cases "<Op1(f,e),sigma> -a-> i",
|
|
46 |
evala.mk_cases "<Op2(f,a1,a2),sigma> -a-> i"
|
511
|
47 |
];
|