src/HOL/Tools/Predicate_Compile/predicate_compile_data.ML
author haftmann
Thu, 19 Jun 2025 17:15:40 +0200
changeset 82734 89347c0cc6a3
parent 81510 a14eb229011d
permissions -rw-r--r--
treat map_filter similar to list_all, list_ex, list_ex1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33265
01c9c6dbd890 proper headers;
wenzelm
parents: 33252
diff changeset
     1
(*  Title:      HOL/Tools/Predicate_Compile/predicate_compile_data.ML
01c9c6dbd890 proper headers;
wenzelm
parents: 33252
diff changeset
     2
    Author:     Lukas Bulwahn, TU Muenchen
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
     3
33265
01c9c6dbd890 proper headers;
wenzelm
parents: 33252
diff changeset
     4
Book-keeping datastructure for the predicate compiler.
01c9c6dbd890 proper headers;
wenzelm
parents: 33252
diff changeset
     5
*)
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
     6
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
     7
signature PREDICATE_COMPILE_DATA =
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
     8
sig
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
     9
  val ignore_consts : string list -> theory -> theory
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    10
  val keep_functions : string list -> theory -> theory
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    11
  val keep_function : theory -> string -> bool
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    12
  val processed_specs : theory -> string -> (string * thm list) list option
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    13
  val store_processed_specs : (string * (string * thm list) list) -> theory -> theory
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    14
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    15
  val get_specification : Predicate_Compile_Aux.options -> theory -> term -> thm list
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
    16
  val obtain_specification_graph :
35404
de56579ae229 just one copy of structure Term_Graph (in Pure);
wenzelm
parents: 35324
diff changeset
    17
    Predicate_Compile_Aux.options -> theory -> term -> thm list Term_Graph.T
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    18
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    19
  val normalize_equation : theory -> thm -> thm
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    20
end;
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    21
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    22
structure Predicate_Compile_Data : PREDICATE_COMPILE_DATA =
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    23
struct
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    24
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    25
open Predicate_Compile_Aux;
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    26
33522
737589bb9bb8 adapted Theory_Data;
wenzelm
parents: 33487
diff changeset
    27
structure Data = Theory_Data
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    28
(
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    29
  type T =
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    30
    {ignore_consts : Symset.T,
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    31
     keep_functions : Symset.T,
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    32
     processed_specs : ((string * thm list) list) Symtab.table};
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    33
  val empty =
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    34
    {ignore_consts = Symset.empty,
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    35
     keep_functions = Symset.empty,
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    36
     processed_specs =  Symtab.empty};
33522
737589bb9bb8 adapted Theory_Data;
wenzelm
parents: 33487
diff changeset
    37
  fun merge
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    38
    ({ignore_consts = c1, keep_functions = k1, processed_specs = s1},
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    39
     {ignore_consts = c2, keep_functions = k2, processed_specs = s2}) =
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    40
     {ignore_consts = Symset.merge (c1, c2),
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    41
      keep_functions = Symset.merge (k1, k2),
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    42
      processed_specs = Symtab.merge (K true) (s1, s2)}
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    43
);
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    44
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    45
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    46
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    47
fun mk_data (c, k, s) = {ignore_consts = c, keep_functions = k, processed_specs = s}
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    48
fun map_data f {ignore_consts = c, keep_functions = k, processed_specs = s} = mk_data (f (c, k, s))
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    49
59057
5b649fb2f2e1 added ML antiquotation @{apply n} or @{apply n(k)};
wenzelm
parents: 57962
diff changeset
    50
fun ignore_consts cs =
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    51
  Data.map (map_data (@{apply 3(1)} (fold Symset.insert cs)))
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    52
59057
5b649fb2f2e1 added ML antiquotation @{apply n} or @{apply n(k)};
wenzelm
parents: 57962
diff changeset
    53
fun keep_functions cs =
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    54
  Data.map (map_data (@{apply 3(2)} (fold Symset.insert cs)))
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    55
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
    56
fun keep_function thy = Symset.member (#keep_functions (Data.get thy))
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    57
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    58
fun processed_specs thy = Symtab.lookup (#processed_specs (Data.get thy))
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    59
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    60
fun store_processed_specs (constname, specs) =
59057
5b649fb2f2e1 added ML antiquotation @{apply n} or @{apply n(k)};
wenzelm
parents: 57962
diff changeset
    61
  Data.map (map_data (@{apply 3(3)} (Symtab.update_new (constname, specs))))
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
    62
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    63
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
    64
fun defining_term_of_introrule_term t =
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    65
  let
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    66
    val _ $ u = Logic.strip_imp_concl t
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
    67
  in fst (strip_comb u) end
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    68
(*
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    69
  in case pred of
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    70
    Const (c, T) => c
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    71
    | _ => raise TERM ("defining_const_of_introrule_term failed: Not a constant", [t])
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    72
  end
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
    73
*)
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    74
val defining_term_of_introrule = defining_term_of_introrule_term o Thm.prop_of
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    75
40142
128f8a1611e6 relaxing the filtering condition for getting specifications from Spec_Rules
bulwahn
parents: 40053
diff changeset
    76
fun defining_const_of_introrule th =
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    77
  (case defining_term_of_introrule th of
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    78
    Const (c, _) => c
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    79
  | _ => raise TERM ("defining_const_of_introrule failed: Not a constant", [Thm.prop_of th]))
40142
128f8a1611e6 relaxing the filtering condition for getting specifications from Spec_Rules
bulwahn
parents: 40053
diff changeset
    80
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    81
(*TODO*)
50056
72efd6b4038d dropped dead code
haftmann
parents: 49561
diff changeset
    82
fun is_introlike_term _ = true
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    83
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    84
val is_introlike = is_introlike_term o Thm.prop_of
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    85
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
    86
fun check_equation_format_term (t as (Const (\<^const_name>\<open>Pure.eq\<close>, _) $ u $ _)) =
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    87
      (case strip_comb u of
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    88
        (Const (_, T), args) =>
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    89
          if (length (binder_types T) = length args) then
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    90
            true
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    91
          else
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    92
            raise TERM ("check_equation_format_term failed: Number of arguments mismatch", [t])
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    93
      | _ => raise TERM ("check_equation_format_term failed: Not a constant", [t]))
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    94
  | check_equation_format_term t =
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
    95
      raise TERM ("check_equation_format_term failed: Not an equation", [t])
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    96
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    97
val check_equation_format = check_equation_format_term o Thm.prop_of
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
    98
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
    99
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   100
fun defining_term_of_equation_term (Const (\<^const_name>\<open>Pure.eq\<close>, _) $ u $ _) = fst (strip_comb u)
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   101
  | defining_term_of_equation_term t =
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   102
      raise TERM ("defining_const_of_equation_term failed: Not an equation", [t])
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   103
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
   104
val defining_term_of_equation = defining_term_of_equation_term o Thm.prop_of
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   105
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   106
fun defining_const_of_equation th =
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   107
  (case defining_term_of_equation th of
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   108
    Const (c, _) => c
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
   109
  | _ => raise TERM ("defining_const_of_equation failed: Not a constant", [Thm.prop_of th]))
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   110
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   111
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   112
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   113
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   114
(* Normalizing equations *)
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   115
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   116
fun mk_meta_equation th =
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
   117
  (case Thm.prop_of th of
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   118
    Const (\<^const_name>\<open>Trueprop\<close>, _) $ (Const (\<^const_name>\<open>HOL.eq\<close>, _) $ _ $ _) =>
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   119
      th RS @{thm eq_reflection}
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   120
  | _ => th)
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   121
62958
b41c1cb5e251 Type_Infer.object_logic controls improvement of type inference result;
wenzelm
parents: 61268
diff changeset
   122
val meta_fun_cong = @{lemma "\<And>f :: 'a::{} \<Rightarrow> 'b::{}.f == g ==> f x == g x" by simp}
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   123
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   124
fun full_fun_cong_expand th =
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   125
  let
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
   126
    val (f, args) = strip_comb (fst (Logic.dest_equals (Thm.prop_of th)))
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   127
    val i = length (binder_types (fastype_of f)) - length args
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   128
  in funpow i (fn th => th RS meta_fun_cong) th end;
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   129
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   130
fun split_all_pairs thy th =
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   131
  let
51552
c713c9505f68 clarified Skip_Proof.cheat_tac: more standard tactic;
wenzelm
parents: 50056
diff changeset
   132
    val ctxt = Proof_Context.init_global thy  (* FIXME proper context!? *)
50056
72efd6b4038d dropped dead code
haftmann
parents: 49561
diff changeset
   133
    val ((_, [th']), _) = Variable.import true [th] ctxt
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
   134
    val t = Thm.prop_of th'
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   135
    val frees = Term.add_frees t []
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   136
    fun mk_tuple_rewrites (x, T) nctxt =
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   137
      let
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   138
        val Ts = HOLogic.flatten_tupleT T
81510
a14eb229011d misc tuning and clarification: more direct use of Name.context operations;
wenzelm
parents: 80636
diff changeset
   139
        val xTs = Name.invent_names nctxt x Ts
a14eb229011d misc tuning and clarification: more direct use of Name.context operations;
wenzelm
parents: 80636
diff changeset
   140
        val nctxt' = fold (Name.declare o #1) xTs nctxt
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   141
        val paths = HOLogic.flat_tupleT_paths T
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   142
      in ((Free (x, T), HOLogic.mk_ptuple paths T (map Free xTs)), nctxt') end
81510
a14eb229011d misc tuning and clarification: more direct use of Name.context operations;
wenzelm
parents: 80636
diff changeset
   143
    val (rewr, _) =
a14eb229011d misc tuning and clarification: more direct use of Name.context operations;
wenzelm
parents: 80636
diff changeset
   144
      Name.build_context (Term.declare_free_names t)
a14eb229011d misc tuning and clarification: more direct use of Name.context operations;
wenzelm
parents: 80636
diff changeset
   145
      |> fold_map mk_tuple_rewrites frees
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   146
    val t' = Pattern.rewrite_term thy rewr [] t
51552
c713c9505f68 clarified Skip_Proof.cheat_tac: more standard tactic;
wenzelm
parents: 50056
diff changeset
   147
    val th'' =
c713c9505f68 clarified Skip_Proof.cheat_tac: more standard tactic;
wenzelm
parents: 50056
diff changeset
   148
      Goal.prove ctxt (Term.add_free_names t' []) [] t'
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 59205
diff changeset
   149
        (fn _ => ALLGOALS (Skip_Proof.cheat_tac ctxt))
63170
eae6549dbea2 tuned proofs, to allow unfold_abs_def;
wenzelm
parents: 62958
diff changeset
   150
    val th''' = Local_Defs.unfold0 ctxt [@{thm split_conv}, @{thm fst_conv}, @{thm snd_conv}] th''
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   151
  in
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   152
    th'''
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   153
  end;
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   154
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   155
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   156
fun inline_equations thy th =
33404
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   157
  let
51717
9e7d1c139569 simplifier uses proper Proof.context instead of historic type simpset;
wenzelm
parents: 51685
diff changeset
   158
    val ctxt = Proof_Context.init_global thy
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   159
    val inline_defs = Named_Theorems.get ctxt \<^named_theorems>\<open>code_pred_inline\<close>
57962
0284a7d083be updated to named_theorems;
wenzelm
parents: 56245
diff changeset
   160
    val th' = Simplifier.full_simplify (put_simpset HOL_basic_ss ctxt addsimps inline_defs) th
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   161
    (*val _ = print_step options
33404
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   162
      ("Inlining " ^ (Syntax.string_of_term_global thy (prop_of th))
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   163
       ^ "with " ^ (commas (map ((Syntax.string_of_term_global thy) o prop_of) inline_defs))
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   164
       ^" to " ^ (Syntax.string_of_term_global thy (prop_of th')))*)
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   165
  in
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   166
    th'
66746e4b4531 adapted the inlining in the predicate compiler
bulwahn
parents: 33376
diff changeset
   167
  end
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   168
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   169
fun normalize_equation thy th =
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   170
  mk_meta_equation th
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   171
  |> full_fun_cong_expand
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   172
  |> split_all_pairs thy
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   173
  |> tap check_equation_format
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   174
  |> inline_equations thy
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   175
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   176
fun normalize_intros thy th =
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   177
  split_all_pairs thy th
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   178
  |> inline_equations thy
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   179
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   180
fun normalize thy th =
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   181
  if is_equationlike th then
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   182
    normalize_equation thy th
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   183
  else
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   184
    normalize_intros thy th
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   185
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   186
fun get_specification options thy t =
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   187
  let
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   188
    (*val (c, T) = dest_Const t
51685
385ef6706252 more standard module name Axclass (according to file name);
wenzelm
parents: 51552
diff changeset
   189
    val t = Const (Axclass.unoverload_const thy (c, T), T)*)
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   190
    val _ = if show_steps options then
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   191
        tracing ("getting specification of " ^ Syntax.string_of_term_global thy t ^
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   192
          " with type " ^ Syntax.string_of_typ_global thy (fastype_of t))
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   193
      else ()
42361
23f352990944 modernized structure Proof_Context;
wenzelm
parents: 40142
diff changeset
   194
    val ctxt = Proof_Context.init_global thy
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   195
    fun filtering th =
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   196
      if is_equationlike th andalso
80636
4041e7c8059d tuned: more explicit dest_Const_name and dest_Const_type;
wenzelm
parents: 77723
diff changeset
   197
        defining_const_of_equation (normalize_equation thy th) = dest_Const_name t then
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   198
        SOME (normalize_equation thy th)
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   199
      else
80636
4041e7c8059d tuned: more explicit dest_Const_name and dest_Const_type;
wenzelm
parents: 77723
diff changeset
   200
        if is_introlike th andalso defining_const_of_introrule th = dest_Const_name t then
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   201
          SOME th
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   202
        else
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   203
          NONE
35758
c029f85d3879 adopting predicate compiler to changes in Spec_Rules; removed dependency to Nitpick_Intros
bulwahn
parents: 35624
diff changeset
   204
    fun filter_defs ths = map_filter filtering (map (normalize thy o Thm.transfer thy) ths)
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   205
    val spec =
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   206
      (case filter_defs (Named_Theorems.get ctxt \<^named_theorems>\<open>code_pred_def\<close>) of
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   207
        [] =>
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   208
          (case Spec_Rules.retrieve ctxt t of
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   209
            [] => error ("No specification for " ^ Syntax.string_of_term_global thy t)
71179
592e2afdd50c more informative spec rules: optional name;
wenzelm
parents: 69593
diff changeset
   210
          | ({rules = ths, ...} :: _) => filter_defs ths)
57962
0284a7d083be updated to named_theorems;
wenzelm
parents: 56245
diff changeset
   211
      | ths => ths)
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   212
    val _ =
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   213
      if show_intermediate_results options then
43277
1fd31f859fc7 pervasive Output operations;
wenzelm
parents: 42361
diff changeset
   214
        tracing ("Specification for " ^ (Syntax.string_of_term_global thy t) ^ ":\n" ^
61268
abe08fb15a12 moved remaining display.ML to more_thm.ML;
wenzelm
parents: 59582
diff changeset
   215
          commas (map (Thm.string_of_thm_global thy) spec))
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   216
      else ()
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   217
  in
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   218
    spec
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   219
  end
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   220
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   221
val logic_operator_names =
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   222
  [\<^const_name>\<open>Pure.eq\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   223
   \<^const_name>\<open>Pure.imp\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   224
   \<^const_name>\<open>Trueprop\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   225
   \<^const_name>\<open>Not\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   226
   \<^const_name>\<open>HOL.eq\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   227
   \<^const_name>\<open>HOL.implies\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   228
   \<^const_name>\<open>All\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   229
   \<^const_name>\<open>Ex\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   230
   \<^const_name>\<open>HOL.conj\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   231
   \<^const_name>\<open>HOL.disj\<close>]
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   232
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   233
fun special_cases (c, _) =
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   234
  member (op =)
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   235
   [\<^const_name>\<open>Product_Type.Unity\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   236
    \<^const_name>\<open>False\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   237
    \<^const_name>\<open>Suc\<close>, \<^const_name>\<open>Nat.zero_nat_inst.zero_nat\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   238
    \<^const_name>\<open>Nat.one_nat_inst.one_nat\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   239
    \<^const_name>\<open>Orderings.less\<close>, \<^const_name>\<open>Orderings.less_eq\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   240
    \<^const_name>\<open>Groups.zero\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   241
    \<^const_name>\<open>Groups.one\<close>,  \<^const_name>\<open>Groups.plus\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   242
    \<^const_name>\<open>Nat.ord_nat_inst.less_eq_nat\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   243
    \<^const_name>\<open>Nat.ord_nat_inst.less_nat\<close>,
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   244
  (* FIXME
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   245
    @{const_name number_nat_inst.number_of_nat},
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   246
  *)
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   247
    \<^const_name>\<open>Num.Bit0\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   248
    \<^const_name>\<open>Num.Bit1\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   249
    \<^const_name>\<open>Num.One\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   250
    \<^const_name>\<open>Int.zero_int_inst.zero_int\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   251
    \<^const_name>\<open>List.filter\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   252
    \<^const_name>\<open>HOL.If\<close>,
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 63170
diff changeset
   253
    \<^const_name>\<open>Groups.minus\<close>] c
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   254
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   255
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   256
fun obtain_specification_graph options thy t =
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   257
  let
42361
23f352990944 modernized structure Proof_Context;
wenzelm
parents: 40142
diff changeset
   258
    val ctxt = Proof_Context.init_global thy
50056
72efd6b4038d dropped dead code
haftmann
parents: 49561
diff changeset
   259
    fun is_nondefining_const (c, _) = member (op =) logic_operator_names c
72efd6b4038d dropped dead code
haftmann
parents: 49561
diff changeset
   260
    fun has_code_pred_intros (c, _) = can (Core_Data.intros_of ctxt) c
55399
5c8e91f884af ported predicate compiler to 'ctr_sugar'
blanchet
parents: 51717
diff changeset
   261
    fun case_consts (c, _) = is_some (Ctr_Sugar.ctr_sugar_of_case ctxt c)
5c8e91f884af ported predicate compiler to 'ctr_sugar'
blanchet
parents: 51717
diff changeset
   262
    fun is_datatype_constructor (x as (_, T)) =
5c8e91f884af ported predicate compiler to 'ctr_sugar'
blanchet
parents: 51717
diff changeset
   263
      (case body_type T of
5c8e91f884af ported predicate compiler to 'ctr_sugar'
blanchet
parents: 51717
diff changeset
   264
        Type (Tcon, _) => can (Ctr_Sugar.dest_ctr ctxt Tcon) (Const x)
5c8e91f884af ported predicate compiler to 'ctr_sugar'
blanchet
parents: 51717
diff changeset
   265
      | _ => false)
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   266
    fun defiants_of specs =
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
   267
      fold (Term.add_consts o Thm.prop_of) specs []
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   268
      |> filter_out is_datatype_constructor
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   269
      |> filter_out is_nondefining_const
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   270
      |> filter_out has_code_pred_intros
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   271
      |> filter_out case_consts
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   272
      |> filter_out special_cases
77723
b761c91c2447 performance tuning: prefer functor Set() over Table();
wenzelm
parents: 74561
diff changeset
   273
      |> filter_out (fn (c, _) => Symset.member (#ignore_consts (Data.get thy)) c)
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   274
      |> map (fn (c, _) => (c, Sign.the_const_constraint thy c))
34948
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   275
      |> map Const
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   276
      (*
2d5f2a9f7601 refactoring the predicate compiler; adding theories for Sequences; adding retrieval to Spec_Rules; adding timing to Quickcheck
bulwahn
parents: 33756
diff changeset
   277
      |> filter is_defining_constname*)
35405
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   278
    fun extend t gr =
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   279
      if can (Term_Graph.get_node gr) t then gr
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   280
      else
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   281
        let
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   282
          val specs = get_specification options thy t
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   283
          (*val _ = print_specification options thy constname specs*)
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   284
          val us = defiants_of specs
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   285
        in
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   286
          gr
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   287
          |> Term_Graph.new_node (t, specs)
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   288
          |> fold extend us
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   289
          |> fold (fn u => Term_Graph.add_edge (t, u)) us
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   290
        end
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   291
  in
35405
fc130c5e81ec code simplification by inlining;
wenzelm
parents: 35404
diff changeset
   292
    extend t Term_Graph.empty
33250
5c2af18a3237 including the predicate compiler in HOL-Main; added RandomPredicate monad to Quickcheck
bulwahn
parents:
diff changeset
   293
  end;
35324
c9f428269b38 adopting mutabelle and quickcheck to return timing information; exporting make_case_combs in datatype package for predicate compiler; adding Spec_Rules declaration for tail recursive functions; improving the predicate compiler and function flattening
bulwahn
parents: 35267
diff changeset
   294
55437
3fd63b92ea3b tuned whitespace;
wenzelm
parents: 51717
diff changeset
   295
end