src/HOL/TPTP/atp_problem_import.ML
author wenzelm
Fri, 07 Jun 2024 23:53:31 +0200
changeset 80295 8a9588ffc133
parent 75344 647611e6da76
permissions -rw-r--r--
more accurate Thm_Name.T for PThm / Thm.name_derivation / Thm.derivation_name;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55208
11dd3d1da83b compile
blanchet
parents: 55201
diff changeset
     1
(*  Title:      HOL/TPTP/atp_problem_import.ML
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     2
    Author:     Jasmin Blanchette, TU Muenchen
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     3
    Copyright   2012
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     4
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     5
Import TPTP problems as Isabelle terms or goals.
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     6
*)
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     7
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     8
signature ATP_PROBLEM_IMPORT =
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
     9
sig
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    10
  val read_tptp_file : theory -> (string * term -> 'a) -> string ->
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    11
    'a list * ('a list * 'a list) * local_theory
47794
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
    12
  val nitpick_tptp_file : theory -> int -> string -> unit
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
    13
  val refute_tptp_file : theory -> int -> string -> unit
64561
a7664ca9ffc5 updated CASC instructions + tuning
blanchet
parents: 64445
diff changeset
    14
  val can_tac : Proof.context -> (Proof.context -> tactic) -> term -> bool
47845
2a2bc13669bd export more symbols
blanchet
parents: 47832
diff changeset
    15
  val SOLVE_TIMEOUT :  int -> string -> tactic -> tactic
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    16
  val atp_tac : local_theory -> int -> (string * string) list -> int -> term list -> string ->
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
    17
    int -> tactic
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    18
  val smt_solver_tac : string -> local_theory -> int -> tactic
47845
2a2bc13669bd export more symbols
blanchet
parents: 47832
diff changeset
    19
  val make_conj : term list * term list -> term list -> term
47794
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
    20
  val sledgehammer_tptp_file : theory -> int -> string -> unit
48083
a4148c95134d renamed TPTP commands to agree with Sutcliffe's terminology
blanchet
parents: 48082
diff changeset
    21
  val isabelle_tptp_file : theory -> int -> string -> unit
a4148c95134d renamed TPTP commands to agree with Sutcliffe's terminology
blanchet
parents: 48082
diff changeset
    22
  val isabelle_hot_tptp_file : theory -> int -> string -> unit
54472
073f041d83ae send output of "tptp_translate" to standard output, to simplify Geoff Sutcliffe's life
blanchet
parents: 54434
diff changeset
    23
  val translate_tptp_file : theory -> string -> string -> unit
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
    24
end;
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
    25
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
    26
structure ATP_Problem_Import : ATP_PROBLEM_IMPORT =
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
    27
struct
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
    28
47643
e33c2be488fe reintroduced old FOF and CNF parsers, to work around TPTP_Parser failures
blanchet
parents: 47565
diff changeset
    29
open ATP_Util
e33c2be488fe reintroduced old FOF and CNF parsers, to work around TPTP_Parser failures
blanchet
parents: 47565
diff changeset
    30
open ATP_Problem
e33c2be488fe reintroduced old FOF and CNF parsers, to work around TPTP_Parser failures
blanchet
parents: 47565
diff changeset
    31
open ATP_Proof
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    32
open ATP_Problem_Generate
47643
e33c2be488fe reintroduced old FOF and CNF parsers, to work around TPTP_Parser failures
blanchet
parents: 47565
diff changeset
    33
47776
024cf0f7fb6d further tweaking for Satallax, so that TPTP problems before parsing and after generation are as similar as possible/practical
blanchet
parents: 47771
diff changeset
    34
val debug = false
024cf0f7fb6d further tweaking for Satallax, so that TPTP problems before parsing and after generation are as similar as possible/practical
blanchet
parents: 47771
diff changeset
    35
val overlord = false
024cf0f7fb6d further tweaking for Satallax, so that TPTP problems before parsing and after generation are as similar as possible/practical
blanchet
parents: 47771
diff changeset
    36
47643
e33c2be488fe reintroduced old FOF and CNF parsers, to work around TPTP_Parser failures
blanchet
parents: 47565
diff changeset
    37
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
    38
(** TPTP parsing **)
47643
e33c2be488fe reintroduced old FOF and CNF parsers, to work around TPTP_Parser failures
blanchet
parents: 47565
diff changeset
    39
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    40
fun exploded_absolute_path file_name =
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    41
  Path.explode file_name
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    42
  |> (fn path => path |> not (Path.is_absolute path) ? Path.append (Path.explode "$PWD"))
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    43
47785
d27bb852c430 more tweaking of TPTP/CASC setup
blanchet
parents: 47776
diff changeset
    44
fun read_tptp_file thy postproc file_name =
47644
2d90e10f61f2 prepend PWD to relative paths
blanchet
parents: 47643
diff changeset
    45
  let
47718
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
    46
    fun has_role role (_, role', _, _) = (role' = role)
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    47
    fun get_prop f (name, _, P, _) = P |> f |> close_form |> pair name |> postproc
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    48
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
    49
    val path = exploded_absolute_path file_name
47714
d6683fe037b1 get rid of old parser, hopefully for good
blanchet
parents: 47670
diff changeset
    50
    val ((_, _, problem), thy) =
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    51
      TPTP_Interpret.interpret_file true [Path.dir path, Path.explode "$TPTP"] path [] [] thy
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    52
    val (conjs, defs_and_nondefs) = problem
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    53
      |> List.partition (has_role TPTP_Syntax.Role_Conjecture)
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    54
      ||> List.partition (has_role TPTP_Syntax.Role_Definition)
47644
2d90e10f61f2 prepend PWD to relative paths
blanchet
parents: 47643
diff changeset
    55
  in
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    56
    (map (get_prop I) conjs,
59058
a78612c67ec0 renamed "pairself" to "apply2", in accordance to @{apply 2};
wenzelm
parents: 58843
diff changeset
    57
     apply2 (map (get_prop Logic.varify_global)) defs_and_nondefs,
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
    58
     Named_Target.theory_init thy)
47557
32f35b3d9e42 started integrating Nik's parser into TPTP command-line tools
blanchet
parents: 46325
diff changeset
    59
  end
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    60
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
    61
57547
677b07d777c3 don't generate TPTP THF 'Definition's, because they complicate reconstruction for AgsyHOL and Satallax
blanchet
parents: 57268
diff changeset
    62
(** Nitpick **)
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
    63
74402
e7c10f7e09fa clarified antiquotations;
wenzelm
parents: 72591
diff changeset
    64
fun aptrueprop f ((t0 as \<^Const_>\<open>Trueprop\<close>) $ t1) = t0 $ f t1
47718
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
    65
  | aptrueprop f t = f t
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
    66
74402
e7c10f7e09fa clarified antiquotations;
wenzelm
parents: 72591
diff changeset
    67
fun is_legitimate_tptp_def \<^Const_>\<open>Trueprop for t\<close> = is_legitimate_tptp_def t
e7c10f7e09fa clarified antiquotations;
wenzelm
parents: 72591
diff changeset
    68
  | is_legitimate_tptp_def \<^Const_>\<open>HOL.eq _ for t u\<close> =
57547
677b07d777c3 don't generate TPTP THF 'Definition's, because they complicate reconstruction for AgsyHOL and Satallax
blanchet
parents: 57268
diff changeset
    69
    (is_Const t orelse is_Free t) andalso not (exists_subterm (curry (op =) t) u)
677b07d777c3 don't generate TPTP THF 'Definition's, because they complicate reconstruction for AgsyHOL and Satallax
blanchet
parents: 57268
diff changeset
    70
  | is_legitimate_tptp_def _ = false
677b07d777c3 don't generate TPTP THF 'Definition's, because they complicate reconstruction for AgsyHOL and Satallax
blanchet
parents: 57268
diff changeset
    71
47794
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
    72
fun nitpick_tptp_file thy timeout file_name =
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    73
  let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    74
    val (conjs, (defs, nondefs), lthy) = read_tptp_file thy snd file_name
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    75
    val thy = Proof_Context.theory_of lthy
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    76
    val (defs, pseudo_defs) = defs
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    77
      |> map (ATP_Util.abs_extensionalize_term lthy #> aptrueprop (hol_open_form I))
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    78
      |> List.partition (is_legitimate_tptp_def o perhaps (try HOLogic.dest_Trueprop)
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
    79
        o ATP_Util.unextensionalize_def)
47991
3eb598b044ad make Nitpick's handling of definitions more robust in the face of formulas that don't have the expected format (needed for soundness, cf. RNG100+1)
blanchet
parents: 47957
diff changeset
    80
    val nondefs = pseudo_defs @ nondefs
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
    81
    val state = Proof.init lthy
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    82
    val params =
61569
947ce60a06e1 eliminated Nitpick's pedantic support for 'emdash'
blanchet
parents: 61310
diff changeset
    83
      [("card", "1-100"),
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    84
       ("box", "false"),
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    85
       ("max_threads", "1"),
47791
c17cc1380642 smaller batches, to play safe
blanchet
parents: 47788
diff changeset
    86
       ("batch_size", "5"),
47718
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
    87
       ("falsify", if null conjs then "false" else "true"),
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    88
       ("verbose", "true"),
47776
024cf0f7fb6d further tweaking for Satallax, so that TPTP problems before parsing and after generation are as similar as possible/practical
blanchet
parents: 47771
diff changeset
    89
       ("debug", if debug then "true" else "false"),
024cf0f7fb6d further tweaking for Satallax, so that TPTP problems before parsing and after generation are as similar as possible/practical
blanchet
parents: 47771
diff changeset
    90
       ("overlord", if overlord then "true" else "false"),
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    91
       ("show_consts", "true"),
47755
df437d1bf8db tweak TPTP Nitpick's output
blanchet
parents: 47718
diff changeset
    92
       ("format", "1"),
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    93
       ("max_potential", "0"),
47718
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
    94
       ("timeout", string_of_int timeout),
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
    95
       ("tac_timeout", string_of_int ((timeout + 49) div 50))]
55199
ba93ef2c0d27 tuned ML file name
blanchet
parents: 54547
diff changeset
    96
      |> Nitpick_Commands.default_params thy
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    97
    val i = 1
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    98
    val n = 1
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
    99
    val step = 0
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   100
    val subst = []
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   101
  in
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   102
    Nitpick.pick_nits_in_term state params Nitpick.TPTP i n step subst defs nondefs
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   103
      (case conjs of conj :: _ => conj | [] => \<^prop>\<open>True\<close>);
47718
39229c760636 smoother handling of conjecture, so that its Skolem constants get displayed in countermodels
blanchet
parents: 47715
diff changeset
   104
    ()
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   105
  end
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   106
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   107
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   108
(** Refute **)
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   109
47794
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
   110
fun refute_tptp_file thy timeout file_name =
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   111
  let
52031
9a9238342963 tuning -- renamed '_from_' to '_of_' in Sledgehammer
blanchet
parents: 51717
diff changeset
   112
    fun print_szs_of_outcome falsify s =
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   113
      "% SZS status " ^
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   114
      (if s = "genuine" then
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   115
         if falsify then "CounterSatisfiable" else "Satisfiable"
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   116
       else
61310
9a50ea544fd3 better compliance with TPTP SZS standard
blanchet
parents: 60543
diff changeset
   117
         "GaveUp")
58843
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 57812
diff changeset
   118
      |> writeln
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   119
    val (conjs, (defs, nondefs), lthy) = read_tptp_file thy snd file_name
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   120
    val params =
47714
d6683fe037b1 get rid of old parser, hopefully for good
blanchet
parents: 47670
diff changeset
   121
      [("maxtime", string_of_int timeout),
d6683fe037b1 get rid of old parser, hopefully for good
blanchet
parents: 47670
diff changeset
   122
       ("maxvars", "100000")]
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   123
  in
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   124
    Refute.refute_term lthy params (defs @ nondefs)
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   125
      (case conjs of conj :: _ => conj | [] => \<^prop>\<open>True\<close>)
52031
9a9238342963 tuning -- renamed '_from_' to '_of_' in Sledgehammer
blanchet
parents: 51717
diff changeset
   126
    |> print_szs_of_outcome (not (null conjs))
46325
b170ab46513a implemented "tptp_refute" tool
blanchet
parents: 46324
diff changeset
   127
  end
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   128
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   129
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   130
(** Sledgehammer and Isabelle (combination of provers) **)
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   131
64561
a7664ca9ffc5 updated CASC instructions + tuning
blanchet
parents: 64445
diff changeset
   132
fun can_tac ctxt tactic conj =
74530
823ccd84b879 revert bbfed17243af, breaks HOL-Proofs extraction;
wenzelm
parents: 74526
diff changeset
   133
  can (Goal.prove_internal ctxt [] (Thm.cterm_of ctxt conj)) (fn [] => tactic ctxt)
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   134
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   135
fun SOLVE_TIMEOUT seconds name tac st =
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   136
  let
58843
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 57812
diff changeset
   137
    val _ = writeln ("running " ^ name ^ " for " ^ string_of_int seconds ^ " s")
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   138
    val result =
62519
a564458f94db tuned signature -- clarified modules;
wenzelm
parents: 61860
diff changeset
   139
      Timeout.apply (Time.fromSeconds seconds) (fn () => SINGLE (SOLVE tac) st) ()
64561
a7664ca9ffc5 updated CASC instructions + tuning
blanchet
parents: 64445
diff changeset
   140
      handle Timeout.TIMEOUT _ => NONE | ERROR _ => NONE
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   141
  in
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   142
    (case result of
58843
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 57812
diff changeset
   143
      NONE => (writeln ("FAILURE: " ^ name); Seq.empty)
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 57812
diff changeset
   144
    | SOME st' => (writeln ("SUCCESS: " ^ name); Seq.single st'))
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   145
  end
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   146
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   147
fun nitpick_finite_oracle_tac lthy timeout i th =
47812
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   148
  let
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   149
    fun is_safe (Type (\<^type_name>\<open>fun\<close>, Ts)) = forall is_safe Ts
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   150
      | is_safe \<^typ>\<open>prop\<close> = true
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   151
      | is_safe \<^typ>\<open>bool\<close> = true
47812
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   152
      | is_safe _ = false
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   153
47812
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   154
    val conj = Thm.term_of (Thm.cprem_of th i)
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   155
  in
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   156
    if exists_type (not o is_safe) conj then
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   157
      Seq.empty
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   158
    else
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   159
      let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   160
        val thy = Proof_Context.theory_of lthy
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   161
        val state = Proof.init lthy
47812
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   162
        val params =
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   163
          [("box", "false"),
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   164
           ("max_threads", "1"),
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   165
           ("verbose", "true"),
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   166
           ("debug", if debug then "true" else "false"),
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   167
           ("overlord", if overlord then "true" else "false"),
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   168
           ("max_potential", "0"),
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   169
           ("timeout", string_of_int timeout)]
55199
ba93ef2c0d27 tuned ML file name
blanchet
parents: 54547
diff changeset
   170
          |> Nitpick_Commands.default_params thy
47812
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   171
        val i = 1
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   172
        val n = 1
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   173
        val step = 0
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   174
        val subst = []
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   175
        val (outcome, _) =
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   176
          Nitpick.pick_nits_in_term state params Nitpick.Normal i n step subst [] [] conj
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   177
      in
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   178
        if outcome = "none" then ALLGOALS (Skip_Proof.cheat_tac lthy) th else Seq.empty
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   179
      end
47812
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   180
  end
bb477988edb4 use Nitpick as an oracle for finite problems
blanchet
parents: 47811
diff changeset
   181
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   182
fun atp_tac lthy completeness override_params timeout assms prover =
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   183
  let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   184
    val thy = Proof_Context.theory_of lthy
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   185
    val assm_ths0 = map (Skip_Proof.make_thm thy) assms
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   186
    val ((assm_name, _), lthy) = lthy
64445
233a11ed2dfb generalized experimental feature slightly
blanchet
parents: 62718
diff changeset
   187
      |> Config.put Sledgehammer_Prover_ATP.atp_completish (if completeness > 0 then 3 else 0)
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   188
      |> Local_Theory.note ((\<^binding>\<open>thms\<close>, []), assm_ths0)
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   189
80295
8a9588ffc133 more accurate Thm_Name.T for PThm / Thm.name_derivation / Thm.derivation_name;
wenzelm
parents: 75344
diff changeset
   190
    fun ref_of th = (Facts.named (Thm_Name.short (Thm.derivation_name th)), [])
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   191
    val ref_of_assms = (Facts.named assm_name, [])
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   192
  in
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   193
    Sledgehammer_Tactics.sledgehammer_as_oracle_tac lthy
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   194
      ([("debug", if debug then "true" else "false"),
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   195
        ("overlord", if overlord then "true" else "false"),
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   196
        ("provers", prover),
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   197
        ("timeout", string_of_int timeout)] @
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   198
       (if completeness > 0 then
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   199
          [("type_enc", if completeness = 1 then "mono_native" else "poly_tags")]
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   200
        else
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   201
          []) @
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   202
       override_params)
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   203
      {add = ref_of_assms :: map ref_of [ext, @{thm someI}], del = [], only = true} []
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   204
  end
47765
18f37b7aa6a6 more work on CASC setup
blanchet
parents: 47755
diff changeset
   205
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   206
fun sledgehammer_tac demo lthy timeout assms i =
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   207
  let
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   208
    val frac = if demo then 16 else 12
48143
0186df5074c8 renamed experimental option
blanchet
parents: 48086
diff changeset
   209
    fun slice mult completeness prover =
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   210
      SOLVE_TIMEOUT (mult * timeout div frac)
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   211
        (prover ^ (if completeness > 0 then "(" ^ string_of_int completeness ^ ")" else ""))
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   212
        (atp_tac lthy completeness [] (mult * timeout div frac) assms prover i)
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   213
  in
57154
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   214
    slice 2 0 ATP_Proof.spassN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   215
    ORELSE slice 2 0 ATP_Proof.vampireN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   216
    ORELSE slice 2 0 ATP_Proof.eN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   217
    ORELSE slice 1 1 ATP_Proof.spassN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   218
    ORELSE slice 1 2 ATP_Proof.eN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   219
    ORELSE slice 1 1 ATP_Proof.vampireN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   220
    ORELSE slice 1 2 ATP_Proof.vampireN
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   221
    ORELSE
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   222
      (if demo then
57154
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   223
         slice 2 0 ATP_Proof.satallaxN
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   224
         ORELSE slice 2 0 ATP_Proof.leo2N
47946
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   225
       else
33afcfad3f8d add an experimental "aggressive" mode to Sledgehammer, to experiment with more complete translations of higher-order features without breaking "metis"
blanchet
parents: 47845
diff changeset
   226
         no_tac)
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   227
  end
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   228
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   229
fun smt_solver_tac solver lthy =
47832
7df66b448c4a split into demo and competitive version
blanchet
parents: 47812
diff changeset
   230
  let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   231
    val lthy = lthy |> Context.proof_map (SMT_Config.select_solver solver)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   232
  in SMT_Solver.smt_tac lthy [] end
47832
7df66b448c4a split into demo and competitive version
blanchet
parents: 47812
diff changeset
   233
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   234
fun auto_etc_tac lthy timeout assms i =
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   235
  SOLVE_TIMEOUT (timeout div 20) "nitpick" (nitpick_finite_oracle_tac lthy (timeout div 20) i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   236
  ORELSE SOLVE_TIMEOUT (timeout div 10) "simp" (asm_full_simp_tac lthy i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   237
  ORELSE SOLVE_TIMEOUT (timeout div 10) "blast" (blast_tac lthy i)
47794
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
   238
  ORELSE SOLVE_TIMEOUT (timeout div 5) "auto+spass"
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   239
    (auto_tac lthy THEN ALLGOALS (atp_tac lthy 0 [] (timeout div 5) assms ATP_Proof.spassN))
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   240
  ORELSE SOLVE_TIMEOUT (timeout div 10) "fast" (fast_tac lthy i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   241
  ORELSE SOLVE_TIMEOUT (timeout div 20) "z3" (smt_solver_tac "z3" lthy i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   242
  ORELSE SOLVE_TIMEOUT (timeout div 20) "cvc4" (smt_solver_tac "cvc4" lthy i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   243
  ORELSE SOLVE_TIMEOUT (timeout div 20) "best" (best_tac lthy i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   244
  ORELSE SOLVE_TIMEOUT (timeout div 10) "force" (force_tac lthy i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   245
  ORELSE SOLVE_TIMEOUT (timeout div 10) "meson" (Meson.meson_tac lthy [] i)
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   246
  ORELSE SOLVE_TIMEOUT (timeout div 10) "fastforce" (fast_force_tac lthy i)
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   247
47776
024cf0f7fb6d further tweaking for Satallax, so that TPTP problems before parsing and after generation are as similar as possible/practical
blanchet
parents: 47771
diff changeset
   248
fun make_conj (defs, nondefs) conjs =
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 64561
diff changeset
   249
  Logic.list_implies (rev defs @ rev nondefs, case conjs of conj :: _ => conj | [] => \<^prop>\<open>False\<close>)
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   250
52031
9a9238342963 tuning -- renamed '_from_' to '_of_' in Sledgehammer
blanchet
parents: 51717
diff changeset
   251
fun print_szs_of_success conjs success =
58843
521cea5fa777 discontinued obsolete Output.urgent_message;
wenzelm
parents: 57812
diff changeset
   252
  writeln ("% SZS status " ^
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   253
    (if success then
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   254
       if null conjs then "Unsatisfiable" else "Theorem"
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   255
     else
61310
9a50ea544fd3 better compliance with TPTP SZS standard
blanchet
parents: 60543
diff changeset
   256
       "GaveUp"))
47765
18f37b7aa6a6 more work on CASC setup
blanchet
parents: 47755
diff changeset
   257
47794
4ad62c5f9f88 thread theory cleanly and use "smt" method rather than Sledgehammer for Z3 (because of obscure debilitating bug)
blanchet
parents: 47793
diff changeset
   258
fun sledgehammer_tptp_file thy timeout file_name =
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   259
  let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   260
    val (conjs, assms, lthy) = read_tptp_file thy snd file_name
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   261
    val conj = make_conj ([], []) conjs
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   262
    val assms = op @ assms
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   263
  in
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   264
    can_tac lthy (fn lthy => sledgehammer_tac true lthy timeout assms 1) conj
52031
9a9238342963 tuning -- renamed '_from_' to '_of_' in Sledgehammer
blanchet
parents: 51717
diff changeset
   265
    |> print_szs_of_success conjs
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   266
  end
47766
9f7cdd5fff7c more work on TPTP Isabelle and Sledgehammer tactics
blanchet
parents: 47765
diff changeset
   267
48083
a4148c95134d renamed TPTP commands to agree with Sutcliffe's terminology
blanchet
parents: 48082
diff changeset
   268
fun generic_isabelle_tptp_file demo thy timeout file_name =
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   269
  let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   270
    val (conjs, assms, lthy) = read_tptp_file thy snd file_name
57812
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   271
    val conj = make_conj ([], []) conjs
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   272
    val full_conj = make_conj assms conjs
8dc9dc241973 make TPTP tools work on polymorphic (TFF1) problems as well
blanchet
parents: 57809
diff changeset
   273
    val assms = op @ assms
48143
0186df5074c8 renamed experimental option
blanchet
parents: 48086
diff changeset
   274
    val (last_hope_atp, last_hope_completeness) =
57154
f0eff6393a32 basic setup for zipperposition prover
fleury
parents: 55212
diff changeset
   275
      if demo then (ATP_Proof.satallaxN, 0) else (ATP_Proof.vampireN, 2)
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   276
  in
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   277
    (can_tac lthy (fn lthy => auto_etc_tac lthy (timeout div 2) assms 1) full_conj orelse
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   278
     can_tac lthy (fn lthy => sledgehammer_tac demo lthy (timeout div 2) assms 1) conj orelse
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   279
     can_tac lthy (fn lthy => SOLVE_TIMEOUT timeout (last_hope_atp ^ "(*)")
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   280
       (atp_tac lthy last_hope_completeness [] timeout assms last_hope_atp 1)) full_conj)
52031
9a9238342963 tuning -- renamed '_from_' to '_of_' in Sledgehammer
blanchet
parents: 51717
diff changeset
   281
    |> print_szs_of_success conjs
47771
ba321ce6f344 tuning; no need for relevance filter
blanchet
parents: 47766
diff changeset
   282
  end
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   283
48083
a4148c95134d renamed TPTP commands to agree with Sutcliffe's terminology
blanchet
parents: 48082
diff changeset
   284
val isabelle_tptp_file = generic_isabelle_tptp_file false
a4148c95134d renamed TPTP commands to agree with Sutcliffe's terminology
blanchet
parents: 48082
diff changeset
   285
val isabelle_hot_tptp_file = generic_isabelle_tptp_file true
47832
7df66b448c4a split into demo and competitive version
blanchet
parents: 47812
diff changeset
   286
7df66b448c4a split into demo and competitive version
blanchet
parents: 47812
diff changeset
   287
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   288
(** Translator between TPTP(-like) file formats **)
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   289
54472
073f041d83ae send output of "tptp_translate" to standard output, to simplify Geoff Sutcliffe's life
blanchet
parents: 54434
diff changeset
   290
fun translate_tptp_file thy format_str file_name =
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   291
  let
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   292
    val (conjs, (defs, nondefs), lthy) = read_tptp_file thy I file_name
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   293
    val conj = make_conj ([], []) (map snd conjs)
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   294
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   295
    val (format, type_enc, lam_trans) =
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   296
      (case format_str of
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   297
        "FOF" => (FOF, "mono_guards??", liftingN)
74902
ece4f07ebb04 fixed HOL-TPTP
desharna
parents: 74530
diff changeset
   298
      | "TF0" => (TFF (Monomorphic, Without_FOOL), "mono_native", liftingN)
ece4f07ebb04 fixed HOL-TPTP
desharna
parents: 74530
diff changeset
   299
      | "TH0" => (THF (Monomorphic, {with_ite = false, with_let = false}, THF_Without_Choice),
ece4f07ebb04 fixed HOL-TPTP
desharna
parents: 74530
diff changeset
   300
        "mono_native_higher", keep_lamsN)
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   301
      | "DFG" => (DFG Monomorphic, "mono_native", liftingN)
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   302
      | _ => error ("Unknown format " ^ quote format_str ^
54547
c999e2533487 renamed TFF0/THF0 to three-letter acronyms, in keeping with new TPTP policy
blanchet
parents: 54472
diff changeset
   303
        " (expected \"FOF\", \"TF0\", \"TH0\", or \"DFG\")"))
61860
2ce3d12015b3 cleaner generation of metainformation in DFG format and TPTP theory exporter for Sledgehammer
blanchet
parents: 61569
diff changeset
   304
    val generate_info = false
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   305
    val uncurried_aliases = false
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   306
    val readable_names = true
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   307
    val presimp = true
57809
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   308
    val facts =
a7345fae237b treat variables as frees in 'conjecture's
blanchet
parents: 57547
diff changeset
   309
      map (apfst (rpair (Global, Non_Rec_Def))) defs @
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   310
      map (apfst (rpair (Global, General))) nondefs
57268
027feff882c4 compile
blanchet
parents: 57154
diff changeset
   311
    val (atp_problem, _, _, _) =
72001
3e08311ada8e removed 'freeze_problem_consts' hack in TPTP tools, which wasn't compatible with post-2016 reforms to local theories
blanchet
parents: 69597
diff changeset
   312
      generate_atp_problem lthy generate_info format Hypothesis (type_enc_of_string Strict type_enc)
61860
2ce3d12015b3 cleaner generation of metainformation in DFG format and TPTP theory exporter for Sledgehammer
blanchet
parents: 61569
diff changeset
   313
        Translator
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   314
        lam_trans uncurried_aliases readable_names presimp [] conj facts
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   315
75344
647611e6da76 compile TPTP module
blanchet
parents: 75038
diff changeset
   316
    val lines = lines_of_atp_problem format (K []) atp_problem
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   317
  in
54472
073f041d83ae send output of "tptp_translate" to standard output, to simplify Geoff Sutcliffe's life
blanchet
parents: 54434
diff changeset
   318
    List.app Output.physical_stdout lines
54434
e275d520f49d implemented 'tptp_translate'
blanchet
parents: 52788
diff changeset
   319
  end
46324
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   320
e4bccf5ec61e added problem importer
blanchet
parents:
diff changeset
   321
end;