drop even more bound types in symbol declarations -- useful in particular for type system "Args true"
authorblanchet
Sun, 01 May 2011 18:37:25 +0200 (2011-05-01)
changeset 42575 ad700c4f2471
parent 42574 0864acec9f72
child 42576 a8a80a2a34be
drop even more bound types in symbol declarations -- useful in particular for type system "Args true"
src/HOL/Tools/Sledgehammer/sledgehammer_atp_translate.ML
--- a/src/HOL/Tools/Sledgehammer/sledgehammer_atp_translate.ML	Sun May 01 18:37:25 2011 +0200
+++ b/src/HOL/Tools/Sledgehammer/sledgehammer_atp_translate.ML	Sun May 01 18:37:25 2011 +0200
@@ -781,7 +781,7 @@
     n_ary_strip_type (n - 1) ran_T |>> cons dom_T
   | n_ary_strip_type _ _ = raise Fail "unexpected non-function"
 
-fun problem_line_for_sym_decl ctxt type_sys s n j
+fun problem_line_for_sym_decl ctxt type_sys need_bound_types s j
                               (s', T_args, T, pred_sym, ary) =
   if type_sys = Many_Typed then
     let val (arg_Ts, res_T) = n_ary_strip_type ary T in
@@ -796,7 +796,7 @@
         1 upto length arg_Ts |> map (`I o make_bound_var o string_of_int)
       val bound_tms =
         bound_names ~~ arg_Ts |> map (fn (name, T) => CombConst (name, T, []))
-      val bound_Ts = arg_Ts |> map (if n > 1 then SOME else K NONE)
+      val bound_Ts = arg_Ts |> map (if need_bound_types then SOME else K NONE)
       val freshener =
         case type_sys of Args _ => string_of_int j ^ "_" | _ => ""
     in
@@ -809,8 +809,18 @@
                NONE, NONE)
     end
 fun problem_lines_for_sym_decls ctxt type_sys (s, decls) =
-  let val n = length decls in
-    map2 (problem_line_for_sym_decl ctxt type_sys s n) (0 upto n - 1) decls
+  let
+    val n = length decls
+    fun result_type_of_decl (_, _, T, _, ary) = n_ary_strip_type ary T |> snd
+    val need_bound_types =
+      case decls of
+        decl :: (decls as _ :: _) =>
+        exists (curry (op <>) (result_type_of_decl decl)
+                o result_type_of_decl) decls
+      | _ => false
+  in
+    map2 (problem_line_for_sym_decl ctxt type_sys need_bound_types s)
+         (0 upto n - 1) decls
   end
 fun problem_lines_for_sym_decl_table ctxt type_sys sym_decl_tab =
   Symtab.fold_rev (append o problem_lines_for_sym_decls ctxt type_sys)