IntEx.thy
changeset 220 af951c8fb80a
parent 218 df05cd030d2f
child 222 37b29231265b
--- a/IntEx.thy	Wed Oct 28 15:25:36 2009 +0100
+++ b/IntEx.thy	Wed Oct 28 15:48:38 2009 +0100
@@ -45,9 +45,10 @@
 where
   "my_neg (x, y) = (y, x)"
 
-local_setup {*
-  old_make_const_def @{binding NEG} @{term "my_neg"} NoSyn @{typ "nat \<times> nat"} @{typ "my_int"} #> snd
-*}
+quotient_def (for my_int)
+  NEG::"my_int \<Rightarrow> my_int"
+where
+  "NEG \<equiv> my_neg"
 
 term NEG
 thm NEG_def
@@ -62,9 +63,10 @@
 where
   "my_mult (x, y) (u, v) = (x*u + y*v, x*v + y*u)"
 
-local_setup {*
-  old_make_const_def @{binding MULT} @{term "my_mult"} NoSyn @{typ "nat \<times> nat"} @{typ "my_int"} #> snd
-*}
+quotient_def (for my_int)
+  MULT::"my_int \<Rightarrow> my_int \<Rightarrow> my_int"
+where
+  "MULT \<equiv> my_mult"
 
 term MULT
 thm MULT_def
@@ -75,9 +77,10 @@
 where
   "my_le (x, y) (u, v) = (x+v \<le> u+y)"
 
-local_setup {*
-  old_make_const_def @{binding LE} @{term "my_le"} NoSyn @{typ "nat \<times> nat"} @{typ "my_int"} #> snd
-*}
+quotient_def (for my_int)
+  LE :: "my_int \<Rightarrow> my_int \<Rightarrow> bool"
+where
+  "LE \<equiv> my_le"
 
 term LE
 thm LE_def
@@ -90,7 +93,6 @@
 term LESS
 thm LESS_def
 
-
 definition
   ABS :: "my_int \<Rightarrow> my_int"
 where
@@ -148,12 +150,6 @@
  ML {* lift_thm_my_int @{context} @{thm plus_assoc_pre} *}
 
 
-
-
-
-
-
-
 text {* Below is the construction site code used if things do now work *}
 
 ML {* val t_a = atomize_thm @{thm plus_assoc_pre} *}