author | blanchet |
Fri, 31 Jan 2014 16:10:39 +0100 | |
changeset 55212 | 5832470d956e |
parent 55208 | 11dd3d1da83b |
child 57120 | f8112c4b9cb8 |
permissions | -rw-r--r-- |
48234 | 1 |
(* Title: HOL/TPTP/MaSh_Export.thy |
2 |
Author: Jasmin Blanchette, TU Muenchen |
|
3 |
*) |
|
4 |
||
5 |
header {* MaSh Exporter *} |
|
6 |
||
7 |
theory MaSh_Export |
|
50350
136d5318b1fe
tuned MaSh exporter -- and don't make temp directories unless explicitly told so
blanchet
parents:
50349
diff
changeset
|
8 |
imports Main |
48234 | 9 |
begin |
10 |
||
48891 | 11 |
ML_file "mash_export.ML" |
12 |
||
48245 | 13 |
sledgehammer_params |
50519 | 14 |
[provers = spass, max_facts = 32, strict, dont_slice, type_enc = mono_native, |
50925 | 15 |
lam_trans = lifting, timeout = 2, dont_preplay, minimize] |
48239
0016290f904c
generate Meng--Paulson facts for evaluation purposes
blanchet
parents:
48235
diff
changeset
|
16 |
|
50925 | 17 |
declare [[sledgehammer_instantiate_inducts = false]] |
50434
960a3429615c
more MaSh tweaking -- in particular, export the same facts in "MaSh_Export" as are later tried in "MaSh_Eval"
blanchet
parents:
50411
diff
changeset
|
18 |
|
51027
0f817f80bcca
hide "ext" name, but keep "HOL.ext", to ensure consistency in naming when "ext" is used by LEO-II or Satallax implicitly
blanchet
parents:
50966
diff
changeset
|
19 |
hide_fact (open) HOL.ext |
0f817f80bcca
hide "ext" name, but keep "HOL.ext", to ensure consistency in naming when "ext" is used by LEO-II or Satallax implicitly
blanchet
parents:
50966
diff
changeset
|
20 |
|
48234 | 21 |
ML {* |
54717 | 22 |
Multithreading.max_threads_value () |
50519 | 23 |
*} |
24 |
||
25 |
ML {* |
|
48234 | 26 |
open MaSh_Export |
27 |
*} |
|
28 |
||
29 |
ML {* |
|
48333 | 30 |
val do_it = false (* switch to "true" to generate the files *) |
50350
136d5318b1fe
tuned MaSh exporter -- and don't make temp directories unless explicitly told so
blanchet
parents:
50349
diff
changeset
|
31 |
val thys = [@{theory List}] |
55208 | 32 |
val params as {provers, ...} = Sledgehammer_Commands.default_params @{theory} [] |
48333 | 33 |
val prover = hd provers |
50954 | 34 |
val range = (1, NONE) |
35 |
val step = 1 |
|
51182
962190eab40d
provide two modes for MaSh driver: linearized or real visibility
blanchet
parents:
51027
diff
changeset
|
36 |
val linearize = false |
50964
2a990baa09af
use precomputed MaSh/MePo data whenever available
blanchet
parents:
50954
diff
changeset
|
37 |
val max_suggestions = 1024 |
50513 | 38 |
val dir = "List" |
50349 | 39 |
val prefix = "/tmp/" ^ dir ^ "/" |
50337 | 40 |
*} |
41 |
||
42 |
ML {* |
|
50350
136d5318b1fe
tuned MaSh exporter -- and don't make temp directories unless explicitly told so
blanchet
parents:
50349
diff
changeset
|
43 |
if do_it then |
136d5318b1fe
tuned MaSh exporter -- and don't make temp directories unless explicitly told so
blanchet
parents:
50349
diff
changeset
|
44 |
Isabelle_System.mkdir (Path.explode prefix) |
136d5318b1fe
tuned MaSh exporter -- and don't make temp directories unless explicitly told so
blanchet
parents:
50349
diff
changeset
|
45 |
else |
136d5318b1fe
tuned MaSh exporter -- and don't make temp directories unless explicitly told so
blanchet
parents:
50349
diff
changeset
|
46 |
() |
48246
fb11c09d7729
add Isabelle dependencies to tweak relevance filter
blanchet
parents:
48245
diff
changeset
|
47 |
*} |
48531 | 48 |
|
48246
fb11c09d7729
add Isabelle dependencies to tweak relevance filter
blanchet
parents:
48245
diff
changeset
|
49 |
ML {* |
48245 | 50 |
if do_it then |
51182
962190eab40d
provide two modes for MaSh driver: linearized or real visibility
blanchet
parents:
51027
diff
changeset
|
51 |
generate_accessibility @{context} thys linearize |
962190eab40d
provide two modes for MaSh driver: linearized or real visibility
blanchet
parents:
51027
diff
changeset
|
52 |
(prefix ^ "mash_accessibility") |
48245 | 53 |
else |
54 |
() |
|
55 |
*} |
|
56 |
||
57 |
ML {* |
|
58 |
if do_it then |
|
55212 | 59 |
generate_features @{context} thys (prefix ^ "mash_features") |
48245 | 60 |
else |
61 |
() |
|
48239
0016290f904c
generate Meng--Paulson facts for evaluation purposes
blanchet
parents:
48235
diff
changeset
|
62 |
*} |
0016290f904c
generate Meng--Paulson facts for evaluation purposes
blanchet
parents:
48235
diff
changeset
|
63 |
|
0016290f904c
generate Meng--Paulson facts for evaluation purposes
blanchet
parents:
48235
diff
changeset
|
64 |
ML {* |
48245 | 65 |
if do_it then |
54118 | 66 |
generate_isar_dependencies @{context} range thys linearize |
50484
8ec31bdb9d36
adopt the neutral "prover" terminology for MaSh rather than the ambiguous/wrong ATP terminology (which sometimes excludes SMT solvers)
blanchet
parents:
50434
diff
changeset
|
67 |
(prefix ^ "mash_dependencies") |
48333 | 68 |
else |
69 |
() |
|
70 |
*} |
|
71 |
||
72 |
ML {* |
|
73 |
if do_it then |
|
53120 | 74 |
generate_isar_commands @{context} prover (range, step) thys linearize |
75 |
max_suggestions (prefix ^ "mash_commands") |
|
48333 | 76 |
else |
77 |
() |
|
78 |
*} |
|
79 |
||
80 |
ML {* |
|
50816 | 81 |
if do_it then |
53120 | 82 |
generate_mepo_suggestions @{context} params (range, step) thys linearize |
83 |
max_suggestions (prefix ^ "mepo_suggestions") |
|
50814 | 84 |
else |
85 |
() |
|
86 |
*} |
|
87 |
||
88 |
ML {* |
|
48333 | 89 |
if do_it then |
50814 | 90 |
generate_mesh_suggestions max_suggestions (prefix ^ "mash_suggestions") |
91 |
(prefix ^ "mepo_suggestions") (prefix ^ "mesh_suggestions") |
|
48245 | 92 |
else |
93 |
() |
|
94 |
*} |
|
95 |
||
96 |
ML {* |
|
97 |
if do_it then |
|
51182
962190eab40d
provide two modes for MaSh driver: linearized or real visibility
blanchet
parents:
51027
diff
changeset
|
98 |
generate_prover_dependencies @{context} params range thys linearize |
50484
8ec31bdb9d36
adopt the neutral "prover" terminology for MaSh rather than the ambiguous/wrong ATP terminology (which sometimes excludes SMT solvers)
blanchet
parents:
50434
diff
changeset
|
99 |
(prefix ^ "mash_prover_dependencies") |
48245 | 100 |
else |
101 |
() |
|
48234 | 102 |
*} |
103 |
||
50411 | 104 |
ML {* |
105 |
if do_it then |
|
53120 | 106 |
generate_prover_commands @{context} params (range, step) thys linearize |
107 |
max_suggestions (prefix ^ "mash_prover_commands") |
|
50411 | 108 |
else |
109 |
() |
|
110 |
*} |
|
111 |
||
50966 | 112 |
ML {* |
113 |
if do_it then |
|
114 |
generate_mesh_suggestions max_suggestions (prefix ^ "mash_prover_suggestions") |
|
115 |
(prefix ^ "mepo_suggestions") (prefix ^ "mesh_prover_suggestions") |
|
116 |
else |
|
117 |
() |
|
118 |
*} |
|
119 |
||
48234 | 120 |
end |