src/HOL/TPTP/MaSh_Export.thy
author blanchet
Tue, 19 Feb 2013 13:21:49 +0100
changeset 52319 962190eab40d
parent 52209 0f817f80bcca
child 54257 43d5f3d6d04e
permissions -rw-r--r--
provide two modes for MaSh driver: linearized or real visibility
blanchet@49249
     1
(*  Title:      HOL/TPTP/MaSh_Export.thy
blanchet@49249
     2
    Author:     Jasmin Blanchette, TU Muenchen
blanchet@49249
     3
*)
blanchet@49249
     4
blanchet@49249
     5
header {* MaSh Exporter *}
blanchet@49249
     6
blanchet@49249
     7
theory MaSh_Export
blanchet@51365
     8
imports Main
blanchet@49249
     9
begin
blanchet@49249
    10
wenzelm@49906
    11
ML_file "mash_export.ML"
wenzelm@49906
    12
blanchet@49260
    13
sledgehammer_params
blanchet@51534
    14
  [provers = spass, max_facts = 32, strict, dont_slice, type_enc = mono_native,
blanchet@51940
    15
   lam_trans = lifting, timeout = 2, dont_preplay, minimize]
blanchet@49254
    16
blanchet@51940
    17
declare [[sledgehammer_instantiate_inducts = false]]
blanchet@51449
    18
blanchet@52209
    19
hide_fact (open) HOL.ext
blanchet@52209
    20
blanchet@49249
    21
ML {*
blanchet@51534
    22
!Multithreading.max_threads
blanchet@51534
    23
*}
blanchet@51534
    24
blanchet@51534
    25
ML {*
blanchet@49249
    26
open MaSh_Export
blanchet@49249
    27
*}
blanchet@49249
    28
blanchet@49249
    29
ML {*
blanchet@49348
    30
val do_it = false (* switch to "true" to generate the files *)
blanchet@51365
    31
val thys = [@{theory List}]
blanchet@49348
    32
val params as {provers, ...} = Sledgehammer_Isar.default_params @{context} []
blanchet@49348
    33
val prover = hd provers
blanchet@51969
    34
val range = (1, NONE)
blanchet@51969
    35
val step = 1
blanchet@52319
    36
val linearize = false
blanchet@51979
    37
val max_suggestions = 1024
blanchet@51528
    38
val dir = "List"
blanchet@51364
    39
val prefix = "/tmp/" ^ dir ^ "/"
blanchet@51352
    40
*}
blanchet@51352
    41
blanchet@51352
    42
ML {*
blanchet@51365
    43
if do_it then
blanchet@51365
    44
  Isabelle_System.mkdir (Path.explode prefix)
blanchet@51365
    45
else
blanchet@51365
    46
  ()
blanchet@49261
    47
*}
blanchet@49546
    48
blanchet@49261
    49
ML {*
blanchet@49260
    50
if do_it then
blanchet@52319
    51
  generate_accessibility @{context} thys linearize
blanchet@52319
    52
      (prefix ^ "mash_accessibility")
blanchet@49260
    53
else
blanchet@49260
    54
  ()
blanchet@49249
    55
*}
blanchet@49249
    56
blanchet@49249
    57
ML {*
blanchet@49260
    58
if do_it then
blanchet@52319
    59
  generate_features @{context} prover thys (prefix ^ "mash_features")
blanchet@49260
    60
else
blanchet@49260
    61
  ()
blanchet@49249
    62
*}
blanchet@49249
    63
blanchet@49249
    64
ML {*
blanchet@49260
    65
if do_it then
blanchet@52319
    66
  generate_isar_dependencies @{context} thys linearize
blanchet@51499
    67
      (prefix ^ "mash_dependencies")
blanchet@49348
    68
else
blanchet@49348
    69
  ()
blanchet@49348
    70
*}
blanchet@49348
    71
blanchet@49348
    72
ML {*
blanchet@49348
    73
if do_it then
blanchet@51969
    74
  generate_isar_commands @{context} prover (range, step) thys
blanchet@52319
    75
      linearize (prefix ^ "mash_commands")
blanchet@49348
    76
else
blanchet@49348
    77
  ()
blanchet@49348
    78
*}
blanchet@49348
    79
blanchet@49348
    80
ML {*
blanchet@51831
    81
if do_it then
blanchet@51969
    82
  generate_mepo_suggestions @{context} params (range, step) thys
blanchet@52319
    83
      linearize max_suggestions (prefix ^ "mepo_suggestions")
blanchet@51829
    84
else
blanchet@51829
    85
  ()
blanchet@51829
    86
*}
blanchet@51829
    87
blanchet@51829
    88
ML {*
blanchet@49348
    89
if do_it then
blanchet@51829
    90
  generate_mesh_suggestions max_suggestions (prefix ^ "mash_suggestions")
blanchet@51829
    91
      (prefix ^ "mepo_suggestions") (prefix ^ "mesh_suggestions")
blanchet@49260
    92
else
blanchet@49260
    93
  ()
blanchet@49249
    94
*}
blanchet@49249
    95
blanchet@49249
    96
ML {*
blanchet@49260
    97
if do_it then
blanchet@52319
    98
  generate_prover_dependencies @{context} params range thys linearize
blanchet@51499
    99
      (prefix ^ "mash_prover_dependencies")
blanchet@49260
   100
else
blanchet@49260
   101
  ()
blanchet@49260
   102
*}
blanchet@49260
   103
blanchet@51426
   104
ML {*
blanchet@51426
   105
if do_it then
blanchet@51969
   106
  generate_prover_commands @{context} params (range, step) thys
blanchet@52319
   107
      linearize (prefix ^ "mash_prover_commands")
blanchet@51426
   108
else
blanchet@51426
   109
  ()
blanchet@51426
   110
*}
blanchet@51426
   111
blanchet@51981
   112
ML {*
blanchet@51981
   113
if do_it then
blanchet@51981
   114
  generate_mesh_suggestions max_suggestions (prefix ^ "mash_prover_suggestions")
blanchet@51981
   115
      (prefix ^ "mepo_suggestions") (prefix ^ "mesh_prover_suggestions")
blanchet@51981
   116
else
blanchet@51981
   117
  ()
blanchet@51981
   118
*}
blanchet@51981
   119
blanchet@49249
   120
end