Substracting bounds from free variables.
authorCezary Kaliszyk <kaliszyk@in.tum.de>
Thu, 28 Jan 2010 10:52:10 +0100
changeset 979 a88e16b69d0f
parent 978 b44592adf235
child 980 9d35c6145dd2
Substracting bounds from free variables.
Quot/Nominal/Test.thy
--- a/Quot/Nominal/Test.thy	Thu Jan 28 10:26:36 2010 +0100
+++ b/Quot/Nominal/Test.thy	Thu Jan 28 10:52:10 2010 +0100
@@ -104,6 +104,21 @@
 fun is_atom ty = ty = "Test.name"
 *}
 
+ML {*
+fun fv_bds s bds set =
+  case bds of
+    [] => set
+  | B (s1, s2) :: tl => 
+      if s2 = s then 
+        fv_bds s tl (HOLogic.mk_binop @{const_name "HOL.minus_class.minus"} (set, HOLogic.mk_set @{typ name} [Free (s1, @{typ name})]))
+      else fv_bds s tl set
+  | BS (s1, s2) :: tl =>
+    (* TODO: This is just a copy *)
+      if s2 = s then 
+        fv_bds s tl (HOLogic.mk_binop @{const_name "HOL.minus_class.minus"} (set, HOLogic.mk_set @{typ name} [Free (s1, @{typ name})]))
+      else fv_bds s tl set
+*}
+
 (* TODO: After variant_frees, check that the new names correspond to the ones given by user
    so that 'bind' is matched with variables correctly *)
 ML {*
@@ -115,10 +130,10 @@
   val var_strs = map (Syntax.string_of_term lthy) vars;
   fun fv_var (t as Free (s, (ty as Type (tyS, _)))) =
     if is_atom tyS then HOLogic.mk_set ty [t] else
-    if (Long_Name.base_name tyS) mem dt_names then 
-      Free ("fv_" ^ (Long_Name.base_name tyS), Type ("fun", [dummyT, @{typ "name set"}])) $ t else
+    if (Long_Name.base_name tyS) mem dt_names then
+      fv_bds s bds (Free ("fv_" ^ (Long_Name.base_name tyS), Type ("fun", [dummyT, @{typ "name set"}])) $ t) else
     HOLogic.mk_set @{typ name} []
-  val fv_eq = 
+  val fv_eq =
     if null vars then HOLogic.mk_set @{typ name} []
     else foldr1 (HOLogic.mk_binop @{const_name union}) (map fv_var vars)
   val fv_eq_str = Syntax.string_of_term lthy (Syntax.check_term lthy fv_eq)