first attempt to solve evaluation bootstrap problem
authorhaftmann
Sun, 22 Feb 2009 10:22:30 +0100
changeset 30050 916a8427f65a
parent 30049 05354c653d3a
child 30051 a416ed407f82
first attempt to solve evaluation bootstrap problem
src/Tools/code/code_wellsorted.ML
--- a/src/Tools/code/code_wellsorted.ML	Sun Feb 22 10:22:29 2009 +0100
+++ b/src/Tools/code/code_wellsorted.ML	Sun Feb 22 10:22:30 2009 +0100
@@ -83,6 +83,11 @@
 
 datatype styp = Tyco of string * styp list | Var of var;
 
+val empty_vardeps : ((string * styp list) list * class list) Vargraph.T
+    * (const list * ((string * sort) list * (thm * bool) list) Symtab.table) =
+  (Vargraph.empty, ([], Symtab.empty));
+  (*FIXME: user table with proto equations as assertor for functions,
+    add dummy to styp which allows to process consts of terms directly*)
 
 (* computing instantiations *)
 
@@ -270,19 +275,37 @@
    of SOME (tyscm, _) => (tyscm, gr)
     | NONE => add_eqs thy (proj_sort, algebra) eqntab vardeps c gr;
 
-fun extend_arities_eqngr thy cs (arities, eqngr) =
+fun extend_arities_eqngr thy cs insts (arities, eqngr) =
   let
-    val (vardeps, (_, eqntab)) = fold (assert thy arities eqngr o Fun)
-      cs (Vargraph.empty, ([], Symtab.empty));
+    val (vardeps, (_, eqntab)) = empty_vardeps
+      |> fold (assert thy arities eqngr o Fun) cs
+      |> fold (assert thy arities eqngr o Inst) insts;
     val arities' = add_arities thy vardeps arities;
     val algebra = build_algebra thy arities';
     val proj_sort = complete_proper_sort thy #> Sorts.minimize_sort algebra;
-    val (_, eqngr') = fold_map (ensure_eqs thy (proj_sort, algebra) eqntab vardeps) cs eqngr;
+    fun complete_inst_params (class, tyco) =
+      inst_params thy tyco (Sorts.complete_sort algebra [class]);
+    val cs' = maps complete_inst_params insts @ cs; (*FIXME*)
+    val (_, eqngr') =
+      fold_map (ensure_eqs thy (proj_sort, algebra) eqntab vardeps) cs' eqngr;
   in ((proj_sort, algebra), (arities', eqngr')) end;
 
 
 (** retrieval interfaces **)
 
+fun instance_dicts_of thy (proj_sort, algebra) (T, sort) = (*FIXME vs. consts_dicts_of *)
+  let
+    fun class_relation (x, _) _ = x;
+    fun type_constructor tyco xs class =
+      (class, tyco) :: (maps o maps) fst xs;
+    fun type_variable (TFree (_, sort)) = map (pair []) (proj_sort sort);
+  in
+    flat (Sorts.of_sort_derivation (Syntax.pp_global thy) algebra
+      { class_relation = class_relation, type_constructor = type_constructor,
+        type_variable = type_variable } (T, proj_sort sort)
+       handle Sorts.CLASS_ERROR _ => [] (*permissive!*))
+  end;
+
 fun proto_eval thy cterm_of evaluator_lift evaluator proto_ct arities_eqngr =
   let
     val ct = cterm_of proto_ct;
@@ -294,7 +317,7 @@
     val ct' = Thm.rhs_of thm;
     val t' = Thm.term_of ct';
     val consts = map fst (consts_of t');
-    val (algebra', arities_eqngr') = extend_arities_eqngr thy consts arities_eqngr;
+    val (algebra', arities_eqngr') = extend_arities_eqngr thy consts [] arities_eqngr;
     val (t'', evaluator_eqngr) = evaluator t';
     val consts' = consts_of t'';
     val const_matches = fold (fn (c, ty) =>
@@ -302,8 +325,8 @@
     val typ_matches = maps (fn (tys, c) =>
       tys ~~ map snd (fst (fst (Graph.get_node (snd arities_eqngr') c))))
       const_matches;
-    val dicts = maps (dicts_of thy algebra') typ_matches;
-    val (algebra'', arities_eqngr'') = extend_arities_eqngr thy dicts arities_eqngr';
+    val insts = maps (instance_dicts_of thy algebra') typ_matches;
+    val (algebra'', arities_eqngr'') = extend_arities_eqngr thy [] insts arities_eqngr';
   in (evaluator_lift (evaluator_eqngr algebra'') thm (snd arities_eqngr''), arities_eqngr'') end;
 
 fun proto_eval_conv thy =
@@ -332,15 +355,18 @@
     let
       val del_cs = ((Graph.all_preds eqngr
         o filter (can (Graph.get_node eqngr))) cs);
-      val del_arities =
-        map_filter (AxClass.inst_of_param thy) del_cs;
+      val del_arities = del_cs
+        |> map_filter (AxClass.inst_of_param thy)
+        |> maps (fn (c, tyco) =>
+             (map (rpair tyco) o Sign.complete_sort thy o the_list
+               o AxClass.class_of_param thy) c);
       val arities' = fold (AList.delete (op =)) del_arities arities;
       val eqngr' = Graph.del_nodes del_cs eqngr;
     in (arities', eqngr') end;
 );
 
-fun make thy = apsnd snd
-  o Wellsorted.change_yield thy o extend_arities_eqngr thy;
+fun make thy cs = apsnd snd
+  (Wellsorted.change_yield thy (extend_arities_eqngr thy cs []));
 
 fun eval_conv thy f =
   fst o Wellsorted.change_yield thy o proto_eval_conv thy f;