src/ZF/Tools/typechk.ML
author wenzelm
Wed, 19 Aug 2015 16:21:10 +0200
changeset 60975 5f3d6e16ea78
parent 60774 6c28d8ed2488
child 61268 abe08fb15a12
permissions -rw-r--r--
avoid ambiguities on native Windows, such as / vs. /cygdrive/c/cygwin;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
     1
(*  Title:      ZF/Tools/typechk.ML
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
     2
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
     3
    Copyright   1999  University of Cambridge
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
     4
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
     5
Automated type checking (cf. CTT).
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
     6
*)
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
     7
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
     8
signature TYPE_CHECK =
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
     9
sig
21506
b2a673894ce5 prefer Proof.context over Context.generic;
wenzelm
parents: 20193
diff changeset
    10
  val print_tcset: Proof.context -> unit
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    11
  val TC_add: attribute
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    12
  val TC_del: attribute
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    13
  val typecheck_tac: Proof.context -> tactic
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    14
  val type_solver_tac: Proof.context -> thm list -> int -> tactic
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    15
  val type_solver: solver
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    16
end;
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    17
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    18
structure TypeCheck: TYPE_CHECK =
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    19
struct
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    20
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    21
(* datatype tcset *)
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    22
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    23
datatype tcset = TC of
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    24
 {rules: thm list,     (*the type-checking rules*)
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    25
  net: thm Net.net};   (*discrimination net of the same rules*)
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    26
42439
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    27
fun add_rule ctxt th (tcs as TC {rules, net}) =
22360
26ead7ed4f4b moved eq_thm etc. to structure Thm in Pure/more_thm.ML;
wenzelm
parents: 21506
diff changeset
    28
  if member Thm.eq_thm_prop rules th then
42439
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    29
    (warning ("Ignoring duplicate type-checking rule\n" ^ Display.string_of_thm ctxt th); tcs)
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    30
  else
42439
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    31
    TC {rules = th :: rules, net = Net.insert_term (K false) (Thm.concl_of th, th) net};
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    32
42439
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    33
fun del_rule ctxt th (tcs as TC {rules, net}) =
22360
26ead7ed4f4b moved eq_thm etc. to structure Thm in Pure/more_thm.ML;
wenzelm
parents: 21506
diff changeset
    34
  if member Thm.eq_thm_prop rules th then
26ead7ed4f4b moved eq_thm etc. to structure Thm in Pure/more_thm.ML;
wenzelm
parents: 21506
diff changeset
    35
    TC {net = Net.delete_term Thm.eq_thm_prop (Thm.concl_of th, th) net,
42439
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    36
      rules = remove Thm.eq_thm_prop th rules}
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    37
  else (warning ("No such type-checking rule\n" ^ Display.string_of_thm ctxt th); tcs);
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    38
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    39
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    40
(* generic data *)
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    41
33519
e31a85f92ce9 adapted Generic_Data, Proof_Data;
wenzelm
parents: 32170
diff changeset
    42
structure Data = Generic_Data
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    43
(
33519
e31a85f92ce9 adapted Generic_Data, Proof_Data;
wenzelm
parents: 32170
diff changeset
    44
  type T = tcset;
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    45
  val empty = TC {rules = [], net = Net.empty};
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    46
  val extend = I;
33519
e31a85f92ce9 adapted Generic_Data, Proof_Data;
wenzelm
parents: 32170
diff changeset
    47
  fun merge (TC {rules, net}, TC {rules = rules', net = net'}) =
e31a85f92ce9 adapted Generic_Data, Proof_Data;
wenzelm
parents: 32170
diff changeset
    48
    TC {rules = Thm.merge_thms (rules, rules'), net = Net.merge Thm.eq_thm_prop (net, net')};
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    49
);
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    50
42439
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    51
val TC_add =
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    52
  Thm.declaration_attribute (fn thm => fn context =>
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    53
    Data.map (add_rule (Context.proof_of context) thm) context);
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    54
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    55
val TC_del =
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    56
  Thm.declaration_attribute (fn thm => fn context =>
9efdd0af15ac eliminated Display.string_of_thm_without_context;
wenzelm
parents: 38522
diff changeset
    57
    Data.map (del_rule (Context.proof_of context) thm) context);
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    58
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    59
val tcset_of = Data.get o Context.Proof;
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    60
22846
fb79144af9a3 simplified DataFun interfaces;
wenzelm
parents: 22360
diff changeset
    61
fun print_tcset ctxt =
fb79144af9a3 simplified DataFun interfaces;
wenzelm
parents: 22360
diff changeset
    62
  let val TC {rules, ...} = tcset_of ctxt in
fb79144af9a3 simplified DataFun interfaces;
wenzelm
parents: 22360
diff changeset
    63
    Pretty.writeln (Pretty.big_list "type-checking rules:"
51584
98029ceda8ce more item markup;
wenzelm
parents: 46961
diff changeset
    64
      (map (Display.pretty_thm_item ctxt) rules))
22846
fb79144af9a3 simplified DataFun interfaces;
wenzelm
parents: 22360
diff changeset
    65
  end;
fb79144af9a3 simplified DataFun interfaces;
wenzelm
parents: 22360
diff changeset
    66
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    67
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
    68
(* tactics *)
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    69
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    70
(*resolution using a net rather than rules*)
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 59164
diff changeset
    71
fun net_res_tac ctxt maxr net =
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    72
  SUBGOAL
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 59164
diff changeset
    73
    (fn (prem, i) =>
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    74
      let val rls = Net.unify_term net (Logic.strip_assums_concl prem)
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    75
      in
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 59164
diff changeset
    76
         if length rls <= maxr then resolve_tac ctxt rls i else no_tac
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    77
      end);
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
    78
38522
de7984a7172b deglobalization
haftmann
parents: 36960
diff changeset
    79
fun is_rigid_elem (Const(@{const_name Trueprop},_) $ (Const(@{const_name mem},_) $ a $ _)) =
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    80
      not (is_Var (head_of a))
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    81
  | is_rigid_elem _ = false;
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    82
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    83
(*Try solving a:A by assumption provided a is rigid!*)
58963
26bf09b95dda proper context for assume_tac (atac remains as fall-back without context);
wenzelm
parents: 58893
diff changeset
    84
fun test_assume_tac ctxt = SUBGOAL(fn (prem,i) =>
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    85
    if is_rigid_elem (Logic.strip_assums_concl prem)
58963
26bf09b95dda proper context for assume_tac (atac remains as fall-back without context);
wenzelm
parents: 58893
diff changeset
    86
    then  assume_tac ctxt i  else  eq_assume_tac i);
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    87
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
    88
(*Type checking solves a:?A (a rigid, ?A maybe flexible).
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    89
  match_tac is too strict; would refuse to instantiate ?A*)
58963
26bf09b95dda proper context for assume_tac (atac remains as fall-back without context);
wenzelm
parents: 58893
diff changeset
    90
fun typecheck_step_tac ctxt =
26bf09b95dda proper context for assume_tac (atac remains as fall-back without context);
wenzelm
parents: 58893
diff changeset
    91
  let val TC {net, ...} = tcset_of ctxt
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 59164
diff changeset
    92
  in FIRSTGOAL (test_assume_tac ctxt ORELSE' net_res_tac ctxt 3 net) end;
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    93
58963
26bf09b95dda proper context for assume_tac (atac remains as fall-back without context);
wenzelm
parents: 58893
diff changeset
    94
fun typecheck_tac ctxt = REPEAT (typecheck_step_tac ctxt);
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    95
59164
ff40c53d1af9 proper context for "net" tactics;
wenzelm
parents: 58963
diff changeset
    96
(*Compile a term-net for speed*)
ff40c53d1af9 proper context for "net" tactics;
wenzelm
parents: 58963
diff changeset
    97
val basic_net =
ff40c53d1af9 proper context for "net" tactics;
wenzelm
parents: 58963
diff changeset
    98
  Tactic.build_net @{thms TrueI refl reflexive iff_refl ballI allI conjI impI};
6049
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
    99
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
   100
(*Instantiates variables in typing conditions.
7fef0169ab5e moved from ZF to new subdirectory Tools
paulson
parents:
diff changeset
   101
  drawback: does not simplify conjunctions*)
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
   102
fun type_solver_tac ctxt hyps = SELECT_GOAL
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 59164
diff changeset
   103
    (DEPTH_SOLVE (eresolve_tac ctxt @{thms FalseE} 1
59164
ff40c53d1af9 proper context for "net" tactics;
wenzelm
parents: 58963
diff changeset
   104
                  ORELSE resolve_from_net_tac ctxt basic_net 1
60774
6c28d8ed2488 proper context;
wenzelm
parents: 60097
diff changeset
   105
                  ORELSE (ares_tac ctxt hyps 1
58963
26bf09b95dda proper context for assume_tac (atac remains as fall-back without context);
wenzelm
parents: 58893
diff changeset
   106
                          APPEND typecheck_step_tac ctxt)));
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
   107
43596
78211f66cf8d simplified/unified Simplifier.mk_solver;
wenzelm
parents: 42795
diff changeset
   108
val type_solver =
51717
9e7d1c139569 simplifier uses proper Proof.context instead of historic type simpset;
wenzelm
parents: 51658
diff changeset
   109
  Simplifier.mk_solver "ZF typecheck" (fn ctxt =>
9e7d1c139569 simplifier uses proper Proof.context instead of historic type simpset;
wenzelm
parents: 51658
diff changeset
   110
    type_solver_tac ctxt (Simplifier.prems_of ctxt));
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
   111
58828
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   112
val _ = Theory.setup (map_theory_simpset (fn ctxt => ctxt setSolver type_solver));
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   113
6153
bff90585cce5 new typechecking solver for the simplifier
paulson
parents: 6112
diff changeset
   114
18736
541d04c79e12 simplified type attribute;
wenzelm
parents: 18708
diff changeset
   115
(* concrete syntax *)
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
   116
58828
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   117
val _ =
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   118
  Theory.setup
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   119
   (Attrib.setup @{binding TC} (Attrib.add_del TC_add TC_del)
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   120
      "declaration of type-checking rule" #>
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   121
    Method.setup @{binding typecheck}
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   122
      (Method.sections
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   123
        [Args.add -- Args.colon >> K (Method.modifier TC_add @{here}),
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   124
         Args.del -- Args.colon >> K (Method.modifier TC_del @{here})]
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   125
        >> K (fn ctxt => SIMPLE_METHOD (CHANGED (typecheck_tac ctxt))))
6d076fdd933d modernized setup;
wenzelm
parents: 58048
diff changeset
   126
      "ZF type-checking");
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
   127
24867
e5b55d7be9bb simplified interfaces for outer syntax;
wenzelm
parents: 24826
diff changeset
   128
val _ =
59936
b8ffc3dc9e24 @{command_spec} is superseded by @{command_keyword};
wenzelm
parents: 59498
diff changeset
   129
  Outer_Syntax.command @{command_keyword print_tcset} "print context of ZF typecheck"
60097
d20ca79d50e4 discontinued pointless warnings: commands are only defined inside a theory context;
wenzelm
parents: 59936
diff changeset
   130
    (Scan.succeed (Toplevel.keep (print_tcset o Toplevel.context_of)));
12189
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
   131
4729bbf86626 Isar attribute and method setup;
wenzelm
parents: 12109
diff changeset
   132
end;