| author | haftmann |
| Mon, 06 Nov 2006 16:28:31 +0100 | |
| changeset 21191 | c00161fbf990 |
| parent 21155 | 95142d816793 |
| child 21319 | cf814e36f788 |
| permissions | -rw-r--r-- |
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
1 |
(* ID: $Id$ |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
2 |
Author: Florian Haftmann, TU Muenchen |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
3 |
*) |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
4 |
|
| 20187 | 5 |
header {* Test and Examples for code generator *}
|
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
6 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
7 |
theory Codegenerator |
|
21155
95142d816793
added particular test for partially applied case constants
haftmann
parents:
21125
diff
changeset
|
8 |
imports Main Records |
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
9 |
begin |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
10 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
11 |
subsection {* booleans *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
12 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
13 |
definition |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
14 |
xor :: "bool \<Rightarrow> bool \<Rightarrow> bool" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
15 |
"xor p q = ((p | q) & \<not> (p & q))" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
16 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
17 |
subsection {* natural numbers *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
18 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
19 |
definition |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
20 |
n :: nat |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
21 |
"n = 42" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
22 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
23 |
subsection {* pairs *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
24 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
25 |
definition |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
26 |
swap :: "'a * 'b \<Rightarrow> 'b * 'a" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
27 |
"swap p = (let (x, y) = p in (y, x))" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
28 |
appl :: "('a \<Rightarrow> 'b) * 'a \<Rightarrow> 'b"
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
29 |
"appl p = (let (f, x) = p in f x)" |
| 21092 | 30 |
snd_three :: "'a * 'b * 'c => 'b" |
31 |
"snd_three a = id (\<lambda>(a, b, c). b) a" |
|
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
32 |
|
| 20936 | 33 |
lemma [code]: |
34 |
"swap (x, y) = (y, x)" |
|
35 |
unfolding swap_def Let_def by auto |
|
36 |
||
37 |
lemma [code]: |
|
38 |
"appl (f, x) = f x" |
|
39 |
unfolding appl_def Let_def by auto |
|
40 |
||
| 20187 | 41 |
subsection {* integers *}
|
42 |
||
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
43 |
definition |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
44 |
k :: "int" |
| 20351 | 45 |
"k = -42" |
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
46 |
|
| 20968 | 47 |
function |
48 |
fac :: "int => int" where |
|
49 |
"fac j = (if j <= 0 then 1 else j * (fac (j - 1)))" |
|
50 |
by pat_completeness auto |
|
51 |
termination by (auto_term "measure nat") |
|
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
52 |
|
| 20968 | 53 |
declare fac.simps [code] |
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
54 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
55 |
subsection {* sums *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
56 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
57 |
subsection {* options *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
58 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
59 |
subsection {* lists *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
60 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
61 |
definition |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
62 |
ps :: "nat list" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
63 |
"ps = [2, 3, 5, 7, 11]" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
64 |
qs :: "nat list" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
65 |
"qs == rev ps" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
66 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
67 |
subsection {* mutual datatypes *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
68 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
69 |
datatype mut1 = Tip | Top mut2 |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
70 |
and mut2 = Tip | Top mut1 |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
71 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
72 |
consts |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
73 |
mut1 :: "mut1 \<Rightarrow> mut1" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
74 |
mut2 :: "mut2 \<Rightarrow> mut2" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
75 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
76 |
primrec |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
77 |
"mut1 mut1.Tip = mut1.Tip" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
78 |
"mut1 (mut1.Top x) = mut1.Top (mut2 x)" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
79 |
"mut2 mut2.Tip = mut2.Tip" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
80 |
"mut2 (mut2.Top x) = mut2.Top (mut1 x)" |
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
81 |
|
| 20351 | 82 |
subsection {* records *}
|
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
83 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
84 |
subsection {* equalities *}
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
85 |
|
| 20702 | 86 |
subsection {* strings *}
|
87 |
||
88 |
definition |
|
89 |
"mystring = ''my home is my castle''" |
|
90 |
||
| 20968 | 91 |
subsection {* nested lets and such *}
|
92 |
||
93 |
definition |
|
94 |
"abs_let x = (let (y, z) = x in (\<lambda>u. case u of () \<Rightarrow> (y + y)))" |
|
95 |
||
96 |
definition |
|
97 |
"nested_let x = (let (y, z) = x in let w = y z in w * w)" |
|
98 |
||
99 |
definition |
|
100 |
"case_let x = (let (y, z) = x in case y of () => z)" |
|
101 |
||
|
21155
95142d816793
added particular test for partially applied case constants
haftmann
parents:
21125
diff
changeset
|
102 |
definition |
|
95142d816793
added particular test for partially applied case constants
haftmann
parents:
21125
diff
changeset
|
103 |
"base_case f = f list_case" |
|
95142d816793
added particular test for partially applied case constants
haftmann
parents:
21125
diff
changeset
|
104 |
|
| 20702 | 105 |
definition |
106 |
"apply_tower = (\<lambda>x. x (\<lambda>x. x (\<lambda>x. x)))" |
|
107 |
||
108 |
definition |
|
109 |
"keywords fun datatype class instance funa classa = |
|
110 |
Suc fun + datatype * class mod instance - funa - classa" |
|
111 |
||
112 |
hide (open) const keywords |
|
113 |
||
114 |
definition |
|
115 |
"shadow keywords = keywords @ [Codegenerator.keywords 0 0 0 0 0 0]" |
|
116 |
||
|
20713
823967ef47f1
renamed 0 and 1 to HOL.zero and HOL.one respectivly; introduced corresponding syntactic classes
haftmann
parents:
20702
diff
changeset
|
117 |
code_gen |
|
823967ef47f1
renamed 0 and 1 to HOL.zero and HOL.one respectivly; introduced corresponding syntactic classes
haftmann
parents:
20702
diff
changeset
|
118 |
xor |
|
823967ef47f1
renamed 0 and 1 to HOL.zero and HOL.one respectivly; introduced corresponding syntactic classes
haftmann
parents:
20702
diff
changeset
|
119 |
code_gen |
|
823967ef47f1
renamed 0 and 1 to HOL.zero and HOL.one respectivly; introduced corresponding syntactic classes
haftmann
parents:
20702
diff
changeset
|
120 |
"0::nat" "1::nat" |
| 20702 | 121 |
code_gen |
| 21092 | 122 |
Pair fst snd Let split swap snd_three |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
123 |
code_gen |
| 20351 | 124 |
"op + :: nat \<Rightarrow> nat \<Rightarrow> nat" |
125 |
"op - :: nat \<Rightarrow> nat \<Rightarrow> nat" |
|
126 |
"op * :: nat \<Rightarrow> nat \<Rightarrow> nat" |
|
127 |
"op < :: nat \<Rightarrow> nat \<Rightarrow> bool" |
|
128 |
"op <= :: nat \<Rightarrow> nat \<Rightarrow> bool" |
|
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
129 |
code_gen |
| 20597 | 130 |
appl |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
131 |
code_gen |
| 20351 | 132 |
Inl Inr |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
133 |
code_gen |
| 20351 | 134 |
None Some |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
135 |
code_gen |
| 20351 | 136 |
hd tl "op @" ps qs |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
137 |
code_gen |
| 20351 | 138 |
mut1 mut2 |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
139 |
code_gen |
| 20351 | 140 |
remove1 |
141 |
null |
|
142 |
replicate |
|
143 |
rotate1 |
|
144 |
rotate |
|
145 |
splice |
|
| 20597 | 146 |
code_gen |
147 |
remdups |
|
148 |
"distinct" |
|
|
21155
95142d816793
added particular test for partially applied case constants
haftmann
parents:
21125
diff
changeset
|
149 |
filter |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
150 |
code_gen |
| 20351 | 151 |
foo1 foo3 |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20383
diff
changeset
|
152 |
code_gen |
| 20936 | 153 |
mystring |
154 |
code_gen |
|
|
21155
95142d816793
added particular test for partially applied case constants
haftmann
parents:
21125
diff
changeset
|
155 |
apply_tower Codegenerator.keywords shadow base_case |
| 20968 | 156 |
code_gen |
157 |
abs_let nested_let case_let |
|
| 20936 | 158 |
code_gen "0::int" "1::int" |
159 |
(SML) (Haskell) |
|
160 |
code_gen n |
|
161 |
(SML) (Haskell) |
|
162 |
code_gen fac |
|
163 |
(SML) (Haskell) |
|
164 |
code_gen |
|
165 |
k |
|
166 |
"op + :: int \<Rightarrow> int \<Rightarrow> int" |
|
167 |
"op - :: int \<Rightarrow> int \<Rightarrow> int" |
|
168 |
"op * :: int \<Rightarrow> int \<Rightarrow> int" |
|
169 |
"op < :: int \<Rightarrow> int \<Rightarrow> bool" |
|
170 |
"op <= :: int \<Rightarrow> int \<Rightarrow> bool" |
|
171 |
fac |
|
172 |
"op div :: int \<Rightarrow> int \<Rightarrow> int" |
|
173 |
"op mod :: int \<Rightarrow> int \<Rightarrow> int" |
|
174 |
(SML) (Haskell) |
|
175 |
code_gen |
|
|
21046
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
176 |
"Code_Generator.eq :: bool \<Rightarrow> bool \<Rightarrow> bool" |
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
177 |
"Code_Generator.eq :: nat \<Rightarrow> nat \<Rightarrow> bool" |
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
178 |
"Code_Generator.eq :: int \<Rightarrow> int \<Rightarrow> bool" |
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
179 |
"Code_Generator.eq :: ('a\<Colon>eq) * ('b\<Colon>eq) \<Rightarrow> 'a * 'b \<Rightarrow> bool"
|
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
180 |
"Code_Generator.eq :: ('a\<Colon>eq) + ('b\<Colon>eq) \<Rightarrow> 'a + 'b \<Rightarrow> bool"
|
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
181 |
"Code_Generator.eq :: ('a\<Colon>eq) option \<Rightarrow> 'a option \<Rightarrow> bool"
|
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
182 |
"Code_Generator.eq :: ('a\<Colon>eq) list \<Rightarrow> 'a list \<Rightarrow> bool"
|
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
183 |
"Code_Generator.eq :: mut1 \<Rightarrow> mut1 \<Rightarrow> bool" |
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
184 |
"Code_Generator.eq :: mut2 \<Rightarrow> mut2 \<Rightarrow> bool" |
|
fe1db2f991a7
moved HOL code generator setup to Code_Generator
haftmann
parents:
20968
diff
changeset
|
185 |
"Code_Generator.eq :: ('a\<Colon>eq) point_scheme \<Rightarrow> 'a point_scheme \<Rightarrow> bool"
|
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
186 |
|
| 21125 | 187 |
code_gen (SML *) |
| 21080 | 188 |
code_gen (Haskell -) |
|
19281
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
189 |
|
|
b411f25fff25
added example for operational classes and code generator
haftmann
parents:
diff
changeset
|
190 |
end |