wenzelm@28592
|
1 |
(* Title: HOL/Tools/atp_wrapper.ML
|
wenzelm@28592
|
2 |
ID: $Id$
|
wenzelm@28592
|
3 |
Author: Fabian Immler, TU Muenchen
|
wenzelm@28592
|
4 |
|
wenzelm@28592
|
5 |
Wrapper functions for external ATPs.
|
wenzelm@28592
|
6 |
*)
|
wenzelm@28592
|
7 |
|
wenzelm@28592
|
8 |
signature ATP_WRAPPER =
|
wenzelm@28592
|
9 |
sig
|
wenzelm@28592
|
10 |
val destdir: string ref
|
wenzelm@28592
|
11 |
val problem_name: string ref
|
wenzelm@28592
|
12 |
val external_prover:
|
immler@30536
|
13 |
(thm * (string * int)) list ->
|
immler@30536
|
14 |
(Path.T -> thm -> int -> (thm * (string * int)) list -> theory -> string vector) ->
|
immler@30536
|
15 |
Path.T * string -> (string -> string option) ->
|
wenzelm@28592
|
16 |
(string * string vector * Proof.context * thm * int -> string) ->
|
wenzelm@28596
|
17 |
AtpManager.prover
|
wenzelm@28596
|
18 |
val tptp_prover_opts_full: int -> bool -> bool -> Path.T * string -> AtpManager.prover
|
wenzelm@28596
|
19 |
val tptp_prover_opts: int -> bool -> Path.T * string -> AtpManager.prover
|
wenzelm@28596
|
20 |
val tptp_prover: Path.T * string -> AtpManager.prover
|
wenzelm@28596
|
21 |
val full_prover_opts: int -> bool -> Path.T * string -> AtpManager.prover
|
wenzelm@28596
|
22 |
val full_prover: Path.T * string -> AtpManager.prover
|
wenzelm@28596
|
23 |
val vampire_opts: int -> bool -> AtpManager.prover
|
wenzelm@28596
|
24 |
val vampire: AtpManager.prover
|
wenzelm@28596
|
25 |
val vampire_opts_full: int -> bool -> AtpManager.prover
|
wenzelm@28596
|
26 |
val vampire_full: AtpManager.prover
|
wenzelm@28596
|
27 |
val eprover_opts: int -> bool -> AtpManager.prover
|
wenzelm@28596
|
28 |
val eprover: AtpManager.prover
|
wenzelm@28596
|
29 |
val eprover_opts_full: int -> bool -> AtpManager.prover
|
wenzelm@28596
|
30 |
val eprover_full: AtpManager.prover
|
wenzelm@28596
|
31 |
val spass_opts: int -> bool -> AtpManager.prover
|
wenzelm@28596
|
32 |
val spass: AtpManager.prover
|
immler@29590
|
33 |
val remote_prover_opts: int -> bool -> string -> AtpManager.prover
|
immler@29590
|
34 |
val remote_prover: string -> AtpManager.prover
|
wenzelm@28592
|
35 |
end;
|
wenzelm@28592
|
36 |
|
wenzelm@28592
|
37 |
structure AtpWrapper: ATP_WRAPPER =
|
wenzelm@28592
|
38 |
struct
|
wenzelm@28596
|
39 |
|
wenzelm@28596
|
40 |
(** generic ATP wrapper **)
|
wenzelm@28596
|
41 |
|
wenzelm@28596
|
42 |
(* global hooks for writing problemfiles *)
|
wenzelm@28596
|
43 |
|
wenzelm@28596
|
44 |
val destdir = ref ""; (*Empty means write files to /tmp*)
|
wenzelm@28596
|
45 |
val problem_name = ref "prob";
|
wenzelm@28596
|
46 |
|
wenzelm@28596
|
47 |
|
wenzelm@28596
|
48 |
(* basic template *)
|
wenzelm@28596
|
49 |
|
immler@30537
|
50 |
fun external_prover axiom_clauses write_problem_file (cmd, args) find_failure produce_answer timeout subgoalno goal =
|
wenzelm@28596
|
51 |
let
|
wenzelm@28596
|
52 |
(* path to unique problem file *)
|
wenzelm@28592
|
53 |
val destdir' = ! destdir
|
wenzelm@28592
|
54 |
val problem_name' = ! problem_name
|
wenzelm@28592
|
55 |
fun prob_pathname nr =
|
wenzelm@28596
|
56 |
let val probfile = Path.basic (problem_name' ^ serial_string () ^ "_" ^ string_of_int nr)
|
wenzelm@28592
|
57 |
in if destdir' = "" then File.tmp_path probfile
|
wenzelm@28592
|
58 |
else if File.exists (Path.explode (destdir'))
|
wenzelm@28592
|
59 |
then Path.append (Path.explode (destdir')) probfile
|
wenzelm@28592
|
60 |
else error ("No such directory: " ^ destdir')
|
wenzelm@28592
|
61 |
end
|
wenzelm@28596
|
62 |
|
wenzelm@28592
|
63 |
(* write out problem file and call prover *)
|
immler@30537
|
64 |
val (ctxt, (chain_ths, th)) = goal
|
immler@30536
|
65 |
val thy = ProofContext.theory_of ctxt
|
wenzelm@28596
|
66 |
val chain_ths = map (Thm.put_name_hint ResReconstruct.chained_hint) chain_ths
|
immler@30536
|
67 |
val probfile = prob_pathname subgoalno
|
immler@30536
|
68 |
val fname = File.platform_path probfile
|
immler@30537
|
69 |
val thm_names = write_problem_file probfile th subgoalno axiom_clauses thy
|
wenzelm@28596
|
70 |
val cmdline =
|
wenzelm@30899
|
71 |
if File.exists cmd then "exec " ^ File.shell_path cmd ^ " " ^ args
|
wenzelm@28596
|
72 |
else error ("Bad executable: " ^ Path.implode cmd)
|
immler@30536
|
73 |
val (proof, rc) = system_out (cmdline ^ " " ^ fname)
|
wenzelm@28592
|
74 |
|
wenzelm@28596
|
75 |
(* remove *temporary* files *)
|
immler@30536
|
76 |
val _ = if destdir' = "" then OS.FileSys.remove fname else ()
|
immler@29590
|
77 |
|
immler@29590
|
78 |
(* check for success and print out some information on failure *)
|
immler@29590
|
79 |
val failure = find_failure proof
|
immler@29597
|
80 |
val success = rc = 0 andalso is_none failure
|
wenzelm@28596
|
81 |
val message =
|
wenzelm@30896
|
82 |
if is_some failure then "External prover failed."
|
wenzelm@30896
|
83 |
else if rc <> 0 then "External prover failed: " ^ proof
|
immler@30537
|
84 |
else "Try this command: " ^ produce_answer (proof, thm_names, ctxt, th, subgoalno)
|
immler@30535
|
85 |
|
wenzelm@30896
|
86 |
val _ =
|
wenzelm@30896
|
87 |
if is_some failure
|
immler@29952
|
88 |
then Output.debug (fn () => "Sledgehammer failure: " ^ the failure ^ "\nOutput: " ^ proof)
|
immler@29952
|
89 |
else ()
|
wenzelm@30896
|
90 |
val _ =
|
wenzelm@30896
|
91 |
if rc <> 0
|
immler@29952
|
92 |
then Output.debug (fn () => "Sledgehammer exited with return code " ^ string_of_int rc ^ ":\n" ^ proof)
|
immler@29952
|
93 |
else ()
|
wenzelm@28596
|
94 |
in (success, message) end;
|
wenzelm@28596
|
95 |
|
wenzelm@28596
|
96 |
|
wenzelm@28596
|
97 |
|
wenzelm@28596
|
98 |
(** common provers **)
|
wenzelm@28596
|
99 |
|
wenzelm@28596
|
100 |
(* generic TPTP-based provers *)
|
wenzelm@28596
|
101 |
|
immler@30537
|
102 |
fun tptp_prover_opts_full max_new theory_const full command timeout n goal =
|
wenzelm@28596
|
103 |
external_prover
|
immler@30537
|
104 |
(ResAtp.get_relevant max_new theory_const goal n)
|
immler@30536
|
105 |
(ResAtp.write_problem_file false)
|
wenzelm@28592
|
106 |
command
|
immler@30874
|
107 |
ResReconstruct.find_failure
|
immler@30536
|
108 |
(if full then ResReconstruct.structured_proof else ResReconstruct.lemma_list_tstp)
|
immler@30537
|
109 |
timeout n goal;
|
wenzelm@28592
|
110 |
|
wenzelm@28596
|
111 |
(*arbitrary ATP with TPTP input/output and problemfile as last argument*)
|
wenzelm@28596
|
112 |
fun tptp_prover_opts max_new theory_const =
|
wenzelm@28596
|
113 |
tptp_prover_opts_full max_new theory_const false;
|
wenzelm@28592
|
114 |
|
wenzelm@28596
|
115 |
val tptp_prover = tptp_prover_opts 60 true;
|
wenzelm@28592
|
116 |
|
wenzelm@28596
|
117 |
(*for structured proofs: prover must support TSTP*)
|
wenzelm@28596
|
118 |
fun full_prover_opts max_new theory_const =
|
wenzelm@28596
|
119 |
tptp_prover_opts_full max_new theory_const true;
|
wenzelm@28592
|
120 |
|
wenzelm@28596
|
121 |
val full_prover = full_prover_opts 60 true;
|
wenzelm@28596
|
122 |
|
wenzelm@28596
|
123 |
|
wenzelm@28596
|
124 |
(* Vampire *)
|
wenzelm@28596
|
125 |
|
wenzelm@28596
|
126 |
(*NB: Vampire does not work without explicit timelimit*)
|
wenzelm@28596
|
127 |
|
immler@29593
|
128 |
fun vampire_opts max_new theory_const timeout = tptp_prover_opts
|
wenzelm@28596
|
129 |
max_new theory_const
|
immler@29593
|
130 |
(Path.explode "$VAMPIRE_HOME/vampire",
|
immler@29593
|
131 |
("--output_syntax tptp --mode casc -t " ^ string_of_int timeout))
|
immler@29593
|
132 |
timeout;
|
wenzelm@28596
|
133 |
|
wenzelm@28596
|
134 |
val vampire = vampire_opts 60 false;
|
wenzelm@28596
|
135 |
|
immler@29593
|
136 |
fun vampire_opts_full max_new theory_const timeout = full_prover_opts
|
wenzelm@28596
|
137 |
max_new theory_const
|
immler@29593
|
138 |
(Path.explode "$VAMPIRE_HOME/vampire",
|
immler@29593
|
139 |
("--output_syntax tptp --mode casc -t " ^ string_of_int timeout))
|
immler@29593
|
140 |
timeout;
|
wenzelm@28596
|
141 |
|
wenzelm@28596
|
142 |
val vampire_full = vampire_opts 60 false;
|
wenzelm@28596
|
143 |
|
wenzelm@28596
|
144 |
|
wenzelm@28596
|
145 |
(* E prover *)
|
wenzelm@28596
|
146 |
|
immler@30536
|
147 |
fun eprover_opts max_new theory_const timeout = tptp_prover_opts
|
wenzelm@28596
|
148 |
max_new theory_const
|
immler@30536
|
149 |
(Path.explode "$E_HOME/eproof",
|
immler@30536
|
150 |
"--tstp-in --tstp-out -l5 -xAutoDev -tAutoDev --silent --cpu-limit=" ^ string_of_int timeout)
|
immler@30536
|
151 |
timeout;
|
wenzelm@28596
|
152 |
|
wenzelm@28596
|
153 |
val eprover = eprover_opts 100 false;
|
wenzelm@28596
|
154 |
|
immler@30536
|
155 |
fun eprover_opts_full max_new theory_const timeout = full_prover_opts
|
wenzelm@28596
|
156 |
max_new theory_const
|
immler@30536
|
157 |
(Path.explode "$E_HOME/eproof",
|
immler@30536
|
158 |
"--tstp-in --tstp-out -l5 -xAutoDev -tAutoDev --silent --cpu-limit=" ^ string_of_int timeout)
|
immler@30536
|
159 |
timeout;
|
wenzelm@28596
|
160 |
|
wenzelm@28596
|
161 |
val eprover_full = eprover_opts_full 100 false;
|
wenzelm@28596
|
162 |
|
wenzelm@28596
|
163 |
|
wenzelm@28596
|
164 |
(* SPASS *)
|
wenzelm@28596
|
165 |
|
immler@30537
|
166 |
fun spass_opts max_new theory_const timeout n goal = external_prover
|
immler@30537
|
167 |
(ResAtp.get_relevant max_new theory_const goal n)
|
immler@30536
|
168 |
(ResAtp.write_problem_file true)
|
immler@30536
|
169 |
(Path.explode "$SPASS_HOME/SPASS",
|
immler@30536
|
170 |
"-Auto -SOS=1 -PGiven=0 -PProblem=0 -Splits=0 -FullRed=0 -DocProof -TimeLimit=" ^ string_of_int timeout)
|
immler@30874
|
171 |
ResReconstruct.find_failure
|
immler@30536
|
172 |
ResReconstruct.lemma_list_dfg
|
immler@30537
|
173 |
timeout n goal;
|
wenzelm@28596
|
174 |
|
wenzelm@28596
|
175 |
val spass = spass_opts 40 true;
|
wenzelm@28596
|
176 |
|
wenzelm@28596
|
177 |
|
wenzelm@28596
|
178 |
(* remote prover invocation via SystemOnTPTP *)
|
wenzelm@28596
|
179 |
|
immler@29593
|
180 |
fun remote_prover_opts max_new theory_const args timeout =
|
wenzelm@28596
|
181 |
tptp_prover_opts max_new theory_const
|
immler@30542
|
182 |
(Path.explode "$ISABELLE_HOME/contrib/SystemOnTPTP/remote", args ^ " -t " ^ string_of_int timeout)
|
immler@29593
|
183 |
timeout;
|
wenzelm@28596
|
184 |
|
wenzelm@28596
|
185 |
val remote_prover = remote_prover_opts 60 false;
|
wenzelm@28592
|
186 |
|
wenzelm@28592
|
187 |
end;
|
immler@30536
|
188 |
|
immler@30536
|
189 |
|