src/Tools/try.ML
author wenzelm
Wed, 13 Oct 2021 11:04:35 +0200
changeset 74508 3315c551fe6e
parent 74507 a241eadc0e3f
child 74510 21a20b990724
permissions -rw-r--r--
clarified signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43018
121aa59b4d17 renamed "Auto_Tools" "Try"
blanchet
parents: 40931
diff changeset
     1
(*  Title:      Tools/try.ML
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
     2
    Author:     Jasmin Blanchette, TU Muenchen
74507
a241eadc0e3f removed unused material (left-over from fd0c85d7da38);
wenzelm
parents: 69593
diff changeset
     3
    Author:     Makarius
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
     4
43018
121aa59b4d17 renamed "Auto_Tools" "Try"
blanchet
parents: 40931
diff changeset
     5
Manager for tools that should be tried on conjectures.
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
     6
*)
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
     7
43018
121aa59b4d17 renamed "Auto_Tools" "Try"
blanchet
parents: 40931
diff changeset
     8
signature TRY =
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
     9
sig
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    10
  val serial_commas: string -> string list -> string list
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    11
  val subgoal_count: Proof.state -> int
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    12
  type body = bool -> Proof.state -> bool * (string * string list)
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    13
  type tool = {name: string, weight: int, auto_option: string, body: body}
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    14
  val get_tools: theory -> tool list
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    15
  val try_tools: Proof.state -> (string * string) option
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    16
  val tool_setup: tool -> unit
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    17
end;
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    18
43018
121aa59b4d17 renamed "Auto_Tools" "Try"
blanchet
parents: 40931
diff changeset
    19
structure Try : TRY =
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    20
struct
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    21
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    22
(* helpers *)
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    23
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    24
fun serial_commas _ [] = ["??"]
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    25
  | serial_commas _ [s] = [s]
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    26
  | serial_commas conj [s1, s2] = [s1, conj, s2]
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    27
  | serial_commas conj [s1, s2, s3] = [s1 ^ ",", s2 ^ ",", conj, s3]
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    28
  | serial_commas conj (s :: ss) = s ^ "," :: serial_commas conj ss;
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    29
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    30
val subgoal_count = Logic.count_prems o Thm.prop_of o #goal o Proof.goal;
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    31
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    32
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    33
(* configuration *)
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    34
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    35
type body = bool -> Proof.state -> bool * (string * string list);
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    36
type tool = {name: string, weight: int, auto_option: string, body: body};
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    37
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    38
fun tool_ord (tool1: tool, tool2: tool) =
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    39
  prod_ord int_ord string_ord ((#weight tool1, #name tool1), (#weight tool2, #name tool2));
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    40
33600
16a263d2b1c9 adapted Theory_Data;
wenzelm
parents: 33561
diff changeset
    41
structure Data = Theory_Data
16a263d2b1c9 adapted Theory_Data;
wenzelm
parents: 33561
diff changeset
    42
(
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    43
  type T = tool list;
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    44
  val empty = [];
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    45
  val extend = I;
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    46
  fun merge data : T = Ord_List.merge tool_ord data;
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    47
);
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    48
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    49
val get_tools = Data.get;
43020
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    50
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    51
val register_tool = Data.map o Ord_List.insert tool_ord;
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    52
52641
c56b6fa636e8 hybrid "auto" tool setup, for TTY (within theory) and PIDE (global print function);
wenzelm
parents: 52639
diff changeset
    53
43020
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    54
(* try command *)
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    55
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    56
fun try_tools state =
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    57
  if subgoal_count state = 0 then
58843
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 58842
diff changeset
    58
    (writeln "No subgoal!"; NONE)
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    59
  else
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    60
    get_tools (Proof.theory_of state)
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    61
    |> tap (fn tools =>
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    62
               "Trying " ^ space_implode " "
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    63
                    (serial_commas "and" (map (quote o #name) tools)) ^ "..."
58843
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 58842
diff changeset
    64
               |> writeln)
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    65
    |> Par_List.get_some
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    66
           (fn {name, body, ...} =>
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    67
               case try (body false) state of
43028
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    68
                 SOME (true, (outcome_code, _)) => SOME (name, outcome_code)
1c451bbb3ad7 repaired theory merging and defined/used helpers
blanchet
parents: 43024
diff changeset
    69
               | _ => NONE)
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    70
    |> tap (fn NONE => writeln "Tried in vain" | _ => ());
43020
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    71
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    72
val _ =
67149
e61557884799 prefer control symbol antiquotations;
wenzelm
parents: 63690
diff changeset
    73
  Outer_Syntax.command \<^command_keyword>\<open>try\<close>
46961
5c6955f487e5 outer syntax command definitions based on formal command_spec derived from theory header declarations;
wenzelm
parents: 43061
diff changeset
    74
    "try a combination of automatic proving and disproving tools"
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
    75
    (Scan.succeed (Toplevel.keep_proof (ignore o try_tools o Toplevel.proof_of)));
43020
abb5d1f907e4 added "try" command, to launch Solve Direct, Quickcheck, Nitpick, Sledgehammer, and Try Methods
blanchet
parents: 43018
diff changeset
    76
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
    77
74507
a241eadc0e3f removed unused material (left-over from fd0c85d7da38);
wenzelm
parents: 69593
diff changeset
    78
(* asynchronous print function *)
52641
c56b6fa636e8 hybrid "auto" tool setup, for TTY (within theory) and PIDE (global print function);
wenzelm
parents: 52639
diff changeset
    79
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    80
fun print_function ({name, weight, auto_option, body}: tool) =
53839
274a892b1230 avoid clash of auto print functions with query operations, notably sledgehammer (cf. 3461985dcbc3);
wenzelm
parents: 53171
diff changeset
    81
  Command.print_function ("auto_" ^ name)
58923
cb9b69cca999 more explicit Keyword.keywords;
wenzelm
parents: 58893
diff changeset
    82
    (fn {keywords, command_name, ...} =>
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    83
      if Keyword.is_theory_goal keywords command_name andalso Options.default_bool auto_option then
52651
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    84
        SOME
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 67149
diff changeset
    85
         {delay = SOME (seconds (Options.default_real \<^system_option>\<open>auto_time_start\<close>)),
52651
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    86
          pri = ~ weight,
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    87
          persistent = true,
52953
2c927b7501c5 explicit "strict" flag for print functions (flipped internal meaning);
wenzelm
parents: 52850
diff changeset
    88
          strict = true,
52651
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    89
          print_fn = fn _ => fn st =>
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    90
            let
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    91
              val state = Toplevel.proof_of st
52652
ebdbd5c79a13 avoid spurious warnings, notably of 'try0' about already declared simps etc.;
wenzelm
parents: 52651
diff changeset
    92
                |> Proof.map_context (Context_Position.set_visible false)
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 67149
diff changeset
    93
              val auto_time_limit = Options.default_real \<^system_option>\<open>auto_time_limit\<close>
52651
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    94
            in
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    95
              if auto_time_limit > 0.0 then
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
    96
                (case Timeout.apply (seconds auto_time_limit) (fn () => body true state) () of
59184
830bb7ddb3ab explicit message channels for "state", "information";
wenzelm
parents: 58923
diff changeset
    97
                  (true, (_, outcome)) => List.app Output.information outcome
52651
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    98
                | _ => ())
5adb5c69af97 initial delay for automatically tried tools;
wenzelm
parents: 52648
diff changeset
    99
              else ()
62505
9e2a65912111 clarified modules;
wenzelm
parents: 60190
diff changeset
   100
            end handle exn => if Exn.is_interrupt exn then Exn.reraise exn else ()}
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
   101
      else NONE);
52641
c56b6fa636e8 hybrid "auto" tool setup, for TTY (within theory) and PIDE (global print function);
wenzelm
parents: 52639
diff changeset
   102
c56b6fa636e8 hybrid "auto" tool setup, for TTY (within theory) and PIDE (global print function);
wenzelm
parents: 52639
diff changeset
   103
74508
3315c551fe6e clarified signature;
wenzelm
parents: 74507
diff changeset
   104
(* tool setup *)
52641
c56b6fa636e8 hybrid "auto" tool setup, for TTY (within theory) and PIDE (global print function);
wenzelm
parents: 52639
diff changeset
   105
63690
48a2c88091d7 tuning punctuation in messages output by Isabelle
blanchet
parents: 62519
diff changeset
   106
fun tool_setup tool = (Theory.setup (register_tool tool); print_function tool);
52641
c56b6fa636e8 hybrid "auto" tool setup, for TTY (within theory) and PIDE (global print function);
wenzelm
parents: 52639
diff changeset
   107
33561
ab01b72715ef introduced Auto Nitpick in addition to Auto Quickcheck;
blanchet
parents:
diff changeset
   108
end;