The tyREL function.
authorCezary Kaliszyk <kaliszyk@in.tum.de>
Mon, 12 Oct 2009 15:47:27 +0200
changeset 76 1a0b771051c7
parent 75 5fe163543bb8
child 77 cb74afa437d7
The tyREL function.
QuotMain.thy
--- a/QuotMain.thy	Mon Oct 12 14:30:50 2009 +0200
+++ b/QuotMain.thy	Mon Oct 12 15:47:27 2009 +0200
@@ -300,21 +300,35 @@
   |> writeln
 *}
 
-(*
+ML {* op --> *}
+ML {* op ---> *}
+term FUN_REL
+term LIST_REL
+
+ML {* @{const_name "op ="} *}
 ML {*
 fun tyRel ty rty rel lthy =
-  if ty = rty 
-  then rel
+  if ty = rty then rel
   else (case ty of
-         Type (s, tys) => 
+          Type (s, tys) =>
+            let
+              val tys_rel = map (fn ty => ty --> ty --> @{typ bool}) tys;
+              val ty_out = ty --> ty --> @{typ bool};
+              val tys_out = tys_rel ---> ty_out;
+            in
             (case (lookup (ProofContext.theory_of lthy) s) of
-               SOME (info) => list_comb (Const (#relfun info, ?????), map (tyRel ???) tys)
-               NONE  => (op =):: tys
+               SOME (info) => list_comb (Const (#relfun info, tys_out), map (fn ty => tyRel ty rty rel lthy) tys)
+             | NONE  => Const (@{const_name "op ="}, ty --> ty --> @{typ bool})
             )
-        | _ => (op =):: ty)
+            end
+        | _ => Const (@{const_name "op ="}, ty --> ty --> @{typ bool}))
 *}
 
 ML {*
+  cterm_of @{theory} (tyRel @{typ "trm \<Rightarrow> bool"} @{typ "trm"} @{term "RR"} @{context})
+*}
+
+(* ML {*
 
 fun regularise trm \<Rightarrow> new_trm 
   (case trm of