author | Cezary Kaliszyk <kaliszyk@in.tum.de> |
Sun, 06 Dec 2009 06:41:52 +0100 | |
changeset 574 | 06e54c862a39 |
parent 305 | d7b60303adb8 |
permissions | -rw-r--r-- |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
1 |
theory QuotTest |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
2 |
imports QuotMain |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
3 |
begin |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
4 |
|
254
77ff9624cfd6
fixed the problem with types in map
Christian Urban <urbanc@in.tum.de>
parents:
230
diff
changeset
|
5 |
|
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
6 |
section {* various tests for quotient types*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
7 |
datatype trm = |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
8 |
var "nat" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
9 |
| app "trm" "trm" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
10 |
| lam "nat" "trm" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
11 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
12 |
axiomatization |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
13 |
RR :: "trm \<Rightarrow> trm \<Rightarrow> bool" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
14 |
where |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
15 |
r_eq: "EQUIV RR" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
16 |
|
185
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
17 |
print_quotients |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
18 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
19 |
quotient qtrm = trm / "RR" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
20 |
apply(rule r_eq) |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
21 |
done |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
22 |
|
185
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
23 |
print_quotients |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
24 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
25 |
typ qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
26 |
term Rep_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
27 |
term REP_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
28 |
term Abs_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
29 |
term ABS_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
30 |
thm QUOT_TYPE_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
31 |
thm QUOTIENT_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
32 |
thm REP_qtrm_def |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
33 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
34 |
(* Test interpretation *) |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
35 |
thm QUOT_TYPE_I_qtrm.thm11 |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
36 |
thm QUOT_TYPE.thm11 |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
37 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
38 |
print_theorems |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
39 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
40 |
thm Rep_qtrm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
41 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
42 |
text {* another test *} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
43 |
datatype 'a trm' = |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
44 |
var' "'a" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
45 |
| app' "'a trm'" "'a trm'" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
46 |
| lam' "'a" "'a trm'" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
47 |
|
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
48 |
consts R' :: "'a trm' \<Rightarrow> 'a trm' \<Rightarrow> bool" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
49 |
axioms r_eq': "EQUIV R'" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
50 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
51 |
quotient qtrm' = "'a trm'" / "R'" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
52 |
apply(rule r_eq') |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
53 |
done |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
54 |
|
185
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
55 |
print_quotients |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
56 |
print_theorems |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
57 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
58 |
term ABS_qtrm' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
59 |
term REP_qtrm' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
60 |
thm QUOT_TYPE_qtrm' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
61 |
thm QUOTIENT_qtrm' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
62 |
thm Rep_qtrm' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
63 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
64 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
65 |
text {* a test with lists of terms *} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
66 |
datatype t = |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
67 |
vr "string" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
68 |
| ap "t list" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
69 |
| lm "string" "t" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
70 |
|
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
71 |
consts Rt :: "t \<Rightarrow> t \<Rightarrow> bool" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
72 |
axioms t_eq: "EQUIV Rt" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
73 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
74 |
quotient qt = "t" / "Rt" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
75 |
by (rule t_eq) |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
76 |
|
185
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
77 |
print_quotients |
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
78 |
|
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
79 |
ML {* |
230
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
80 |
get_fun repF [(@{typ qt}, @{typ qt})] @{context} @{typ "((((qt \<Rightarrow> qt) \<Rightarrow> qt) \<Rightarrow> qt) list) * nat"} |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
81 |
|> Syntax.string_of_term @{context} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
82 |
|> writeln |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
83 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
84 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
85 |
ML {* |
230
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
86 |
get_fun absF [(@{typ qt}, @{typ t})] @{context} @{typ "qt * nat"} |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
87 |
|> Syntax.string_of_term @{context} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
88 |
|> writeln |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
89 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
90 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
91 |
ML {* |
230
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
92 |
get_fun absF [(@{typ qt}, @{typ t})] @{context} @{typ "(qt \<Rightarrow> qt) \<Rightarrow> qt"} |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
93 |
|> Syntax.pretty_term @{context} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
94 |
|> Pretty.string_of |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
95 |
|> writeln |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
96 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
97 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
98 |
(* A test whether get_fun works properly |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
99 |
consts bla :: "(t \<Rightarrow> t) \<Rightarrow> t" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
100 |
local_setup {* |
305
d7b60303adb8
Removed 'Toplevel.program' for polyml 5.3
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
290
diff
changeset
|
101 |
make_const_def @{binding bla'} @{term "bla"} NoSyn @{typ "t"} @{typ "qt"} lthy |> snd |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
102 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
103 |
*) |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
104 |
|
284
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
105 |
consts Rl :: "'a list \<Rightarrow> 'a list \<Rightarrow> bool" |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
106 |
axioms Rl_eq: "EQUIV Rl" |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
107 |
|
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
108 |
quotient ql = "'a list" / "Rl" |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
109 |
by (rule Rl_eq) |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
110 |
|
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
111 |
ML {* val al = snd (dest_Free (term_of @{cpat "f :: ?'a list"})) *} |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
112 |
ML {* val aq = snd (dest_Free (term_of @{cpat "f :: ?'a ql"})) *} |
285
8ebdef196fd5
Infrastructure for polymorphic types
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
284
diff
changeset
|
113 |
ML {* val ttt = snd (dest_Free (term_of @{cpat "f :: ?'a ql \<Rightarrow> ?'a ql"})) *} |
284
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
114 |
|
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
115 |
ML {* |
285
8ebdef196fd5
Infrastructure for polymorphic types
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
284
diff
changeset
|
116 |
fst (get_fun absF [(aq, al)] @{context} ttt) |
8ebdef196fd5
Infrastructure for polymorphic types
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
284
diff
changeset
|
117 |
|> cterm_of @{theory} |
284
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
118 |
*} |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
119 |
|
285
8ebdef196fd5
Infrastructure for polymorphic types
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
284
diff
changeset
|
120 |
ML {* val ttt2 = snd (dest_Free (term_of @{cpat "f :: nat ql \<Rightarrow> bool ql \<Rightarrow> 'a ql"})) *} |
284
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
121 |
|
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
122 |
ML {* |
285
8ebdef196fd5
Infrastructure for polymorphic types
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
284
diff
changeset
|
123 |
fst (get_fun absF [(aq, al), (@{typ "nat ql"}, @{typ "nat list"}), (@{typ "bool ql"}, @{typ "bool list"})] @{context} ttt2) |
8ebdef196fd5
Infrastructure for polymorphic types
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
284
diff
changeset
|
124 |
|> cterm_of @{theory} |
284
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
125 |
*} |
78bc4d9d7975
Two new tests for get_fun. Second one fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
254
diff
changeset
|
126 |
|
230
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
127 |
quotient_def (for qt) |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
128 |
VR ::"string \<Rightarrow> qt" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
129 |
where |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
130 |
"VR \<equiv> vr" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
131 |
|
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
132 |
quotient_def (for qt) |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
133 |
AP ::"qt list \<Rightarrow> qt" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
134 |
where |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
135 |
"AP \<equiv> ap" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
136 |
|
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
137 |
quotient_def (for qt) |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
138 |
LM ::"string \<Rightarrow> qt \<Rightarrow> qt" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
139 |
where |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
140 |
"LM \<equiv> lm" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
141 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
142 |
term vr |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
143 |
term ap |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
144 |
term lm |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
145 |
thm VR_def AP_def LM_def |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
146 |
term LM |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
147 |
term VR |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
148 |
term AP |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
149 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
150 |
text {* a test with functions *} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
151 |
datatype 'a t' = |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
152 |
vr' "string" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
153 |
| ap' "('a t') * ('a t')" |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
154 |
| lm' "'a" "string \<Rightarrow> ('a t')" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
155 |
|
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
156 |
consts Rt' :: "('a t') \<Rightarrow> ('a t') \<Rightarrow> bool" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
157 |
axioms t_eq': "EQUIV Rt'" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
158 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
159 |
quotient qt' = "'a t'" / "Rt'" |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
160 |
apply(rule t_eq') |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
161 |
done |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
162 |
|
185
929bc55efff7
added code for declaring map-functions
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
163 |
print_quotients |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
164 |
print_theorems |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
165 |
|
230
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
166 |
|
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
167 |
quotient_def (for "'a qt'") |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
168 |
VR' ::"string \<Rightarrow> 'a qt" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
169 |
where |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
170 |
"VR' \<equiv> vr'" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
171 |
|
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
172 |
quotient_def (for "'a qt'") |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
173 |
AP' ::"('a qt') * ('a qt') \<Rightarrow> 'a qt" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
174 |
where |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
175 |
"AP' \<equiv> ap'" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
176 |
|
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
177 |
quotient_def (for "'a qt'") |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
178 |
LM' ::"'a \<Rightarrow> string \<Rightarrow> 'a qt'" |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
179 |
where |
84a356e3d38b
ported all constant definitions to new scheme
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
180 |
"LM' \<equiv> lm'" |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
181 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
182 |
term vr' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
183 |
term ap' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
184 |
term ap' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
185 |
thm VR'_def AP'_def LM'_def |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
186 |
term LM' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
187 |
term VR' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
188 |
term AP' |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
189 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
190 |
text {* Tests of regularise *} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
191 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
192 |
cterm_of @{theory} (regularise @{term "\<lambda>x :: int. x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
193 |
cterm_of @{theory} (regularise @{term "\<lambda>x :: trm. x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
194 |
cterm_of @{theory} (regularise @{term "\<forall>x :: trm. P x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
195 |
cterm_of @{theory} (regularise @{term "\<exists>x :: trm. P x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
196 |
cterm_of @{theory} (regularise @{term "All (P :: trm \<Rightarrow> bool)"} @{typ "trm"} @{term "RR"} @{context}); |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
197 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
198 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
199 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
200 |
cterm_of @{theory} (regularise @{term "\<exists>(y::trm). P (\<lambda>(x::trm). y)"} @{typ "trm"} |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
201 |
@{term "RR"} @{context}); |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
202 |
cterm_of @{theory} (my_reg @{term "RR"} @{term "\<exists>(y::trm). P (\<lambda>(x::trm). y)"}) |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
203 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
204 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
205 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
206 |
cterm_of @{theory} (regularise @{term "\<lambda>x::trm. x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
207 |
cterm_of @{theory} (my_reg @{term "RR"} @{term "\<lambda>x::trm. x"}) |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
208 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
209 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
210 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
211 |
cterm_of @{theory} (regularise @{term "\<forall>(x::trm) (y::trm). P x y"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
212 |
cterm_of @{theory} (my_reg @{term "RR"} @{term "\<forall>(x::trm) (y::trm). P x y"}) |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
213 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
214 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
215 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
216 |
cterm_of @{theory} (regularise @{term "\<forall>x::trm. P x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
217 |
cterm_of @{theory} (my_reg @{term "RR"} @{term "\<forall>x::trm. P x"}) |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
218 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
219 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
220 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
221 |
cterm_of @{theory} (regularise @{term "\<exists>x::trm. P x"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
222 |
cterm_of @{theory} (my_reg @{term "RR"} @{term "\<exists>x::trm. P x"}) |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
223 |
*} |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
224 |
|
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
225 |
(* my version is not eta-expanded, but that should be OK *) |
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
226 |
ML {* |
177
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
227 |
cterm_of @{theory} (regularise @{term "All (P::trm \<Rightarrow> bool)"} @{typ "trm"} @{term "RR"} @{context}); |
bdfe4388955d
changed encoding from utf8 to ISO8 (needed to work with xemacs)
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
228 |
cterm_of @{theory} (my_reg @{term "RR"} @{term "All (P::trm \<Rightarrow> bool)"}) |
163
3da18bf6886c
Split Finite Set example into separate file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
229 |
*} |