author | Cezary Kaliszyk <kaliszyk@in.tum.de> |
Wed, 17 Feb 2010 15:20:22 +0100 | |
changeset 1176 | 29c4a0cf9237 |
parent 1175 | 6a3be6ef348d |
child 1177 | 6f01720fe520 |
permissions | -rw-r--r-- |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
1 |
theory Fv |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
2 |
imports "Nominal2_Atoms" "Nominal2_Eqvt" "Nominal2_Supp" "Abs" |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
3 |
begin |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
4 |
|
1169
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
5 |
(* Bindings are given as a list which has a length being equal |
1172
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
6 |
to the length of the number of constructors. |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
7 |
|
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
8 |
Each element is a list whose length is equal to the number |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
9 |
of arguents. |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
10 |
|
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
11 |
Every element specifies bindings of this argument given as |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
12 |
a tuple: function, bound argument. |
1169
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
13 |
|
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
14 |
Eg: |
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
15 |
nominal_datatype |
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
16 |
|
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
17 |
C1 |
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
18 |
| C2 x y z bind x in z |
1172
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
19 |
| C3 x y z bind f x in z bind g y in z |
1169
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
20 |
|
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
21 |
yields: |
1172
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
22 |
[ |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
23 |
[], |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
24 |
[[], [], [(NONE, 0)]], |
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
25 |
[[], [], [(SOME (Const f), 0), (Some (Const g), 1)]]] |
1169
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
26 |
*) |
b9d02e0800e9
Description of intended bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1168
diff
changeset
|
27 |
|
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
28 |
ML {* |
1175 | 29 |
open Datatype_Aux; (* typ_of_dtyp, DtRec, ... *); |
30 |
fun mk_atom ty = Const (@{const_name atom}, ty --> @{typ atom}); |
|
31 |
val noatoms = @{term "{} :: atom set"}; |
|
32 |
fun mk_single_atom x = HOLogic.mk_set @{typ atom} [mk_atom (type_of x) $ x]; |
|
33 |
fun mk_union sets = |
|
34 |
fold (fn a => fn b => |
|
35 |
if a = noatoms then b else |
|
36 |
if b = noatoms then a else |
|
37 |
HOLogic.mk_binop @{const_name union} (a, b)) (rev sets) noatoms; |
|
38 |
fun mk_diff a b = |
|
39 |
if b = noatoms then a else |
|
40 |
if b = a then noatoms else |
|
41 |
HOLogic.mk_binop @{const_name minus} (a, b); |
|
42 |
*} |
|
43 |
||
44 |
atom_decl name |
|
45 |
||
1176
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
46 |
datatype rtrm1 = |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
47 |
rVr1 "name" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
48 |
| rAp1 "rtrm1" "rtrm1" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
49 |
| rLm1 "name" "rtrm1" --"name is bound in trm1" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
50 |
| rLt1 "bp" "rtrm1" "rtrm1" --"all variables in bp are bound in the 2nd trm1" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
51 |
and bp = |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
52 |
BUnit |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
53 |
| BVr "name" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
54 |
| BPr "bp" "bp" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
55 |
|
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
56 |
(* to be given by the user *) |
1175 | 57 |
|
1176
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
58 |
primrec |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
59 |
bv1 |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
60 |
where |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
61 |
"bv1 (BUnit) = {}" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
62 |
| "bv1 (BVr x) = {atom x}" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
63 |
| "bv1 (BPr bp1 bp2) = (bv1 bp1) \<union> (bv1 bp1)" |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
64 |
|
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
65 |
ML maps |
1175 | 66 |
ML {* |
1176
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
67 |
val {descr, ...} = Datatype.the_info @{theory} "Fv.rtrm1"; |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
68 |
val sorts = []; |
1176
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
69 |
val bindsall = [ |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
70 |
[[[]], [[], []], [[(NONE, 0)], [(NONE, 0)]], [[], [], [(SOME @{term bv1}, 0)]]], |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
71 |
[[], [[]], [[], []]] |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
72 |
]; |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
73 |
fun nth_dtyp i = typ_of_dtyp descr sorts (DtRec i); |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
74 |
val fv_names = Datatype_Prop.indexify_names (map (fn (i, _) => |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
75 |
"fv_" ^ name_of_typ (nth_dtyp i)) descr); |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
76 |
val fv_types = map (fn (i, _) => nth_dtyp i --> @{typ "atom set"}) descr; |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
77 |
val fv_frees = map Free (fv_names ~~ fv_types); |
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
78 |
fun fv_eq_constr i (cname, dts) bindcs = |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
79 |
let |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
80 |
val Ts = map (typ_of_dtyp descr sorts) dts; |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
81 |
val names = Name.variant_list ["pi"] (Datatype_Prop.make_tnames Ts); |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
82 |
val args = map Free (names ~~ Ts); |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
83 |
val c = Const (cname, Ts ---> (nth_dtyp i)); |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
84 |
val fv_c = Free (nth fv_names i, (nth_dtyp i) --> @{typ "atom set"}); |
1174 | 85 |
(* TODO we assume that all can be 'atomized' *) |
86 |
fun fv_bind (NONE, i) = mk_single_atom (nth args i) |
|
87 |
| fv_bind (SOME f, i) = f $ (nth args i); |
|
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
88 |
fun fv_arg ((dt, x), bindxs) = |
1172
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
89 |
let |
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
90 |
val arg = |
1175 | 91 |
if is_rec_type dt then nth fv_frees (body_index dt) $ x else |
1174 | 92 |
(* TODO: we just assume everything can be 'atomized' *) |
1175 | 93 |
HOLogic.mk_set @{typ atom} [mk_atom (type_of x) $ x] |
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
94 |
val sub = mk_union (map fv_bind bindxs) |
1172
9a609fefcf24
Simplified format of bindings.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1169
diff
changeset
|
95 |
in |
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
96 |
mk_diff arg sub |
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
97 |
end; |
1176
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
98 |
val _ = tracing ("d" ^ string_of_int (length dts)); |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
99 |
val _ = tracing (string_of_int (length args)); |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
100 |
val _ = tracing (string_of_int (length bindcs)); |
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
101 |
in |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
102 |
(Attrib.empty_binding, HOLogic.mk_Trueprop (HOLogic.mk_eq |
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
103 |
(fv_c $ list_comb (c, args), mk_union (map fv_arg (dts ~~ args ~~ bindcs))))) |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
104 |
end; |
1176
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
105 |
fun fv_eq (i, (_, _, constrs)) binds = map2 (fv_eq_constr i) constrs binds; |
29c4a0cf9237
Bindings adapted to multiple defined datatypes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1175
diff
changeset
|
106 |
val fv_eqs = flat (map2 fv_eq descr bindsall) |
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
107 |
*} |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
108 |
|
1173
9cb99a28b40e
Some optimizations and fixes.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1172
diff
changeset
|
109 |
|
1168
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
110 |
local_setup {* |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
111 |
snd o (Primrec.add_primrec |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
112 |
(map (fn s => (Binding.name s, NONE, NoSyn)) fv_names) fv_eqs) |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
113 |
*} |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
114 |
print_theorems |
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
115 |
|
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
116 |
|
5c1e16806901
Code for generating the fv function, no bindings yet.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
117 |
end |