src/HOL/Tools/SMT/smt_systems.ML
author wenzelm
Thu, 11 Jan 2018 13:48:17 +0100
changeset 67405 e9ab4ad7bd15
parent 67399 eab6ce8368fa
child 67522 9e712280cc37
permissions -rw-r--r--
uniform use of Standard ML op-infix -- eliminated warnings;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
     1
(*  Title:      HOL/Tools/SMT/smt_systems.ML
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
     2
    Author:     Sascha Boehme, TU Muenchen
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
     3
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
     4
Setup SMT solvers.
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
     5
*)
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
     6
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
     7
signature SMT_SYSTEMS =
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
     8
sig
59960
372ddff01244 updated SMT module and Sledgehammer to fully open source Z3
blanchet
parents: 59035
diff changeset
     9
  val cvc4_extensions: bool Config.T
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    10
  val z3_extensions: bool Config.T
57229
blanchet
parents: 57210
diff changeset
    11
end;
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    12
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    13
structure SMT_Systems: SMT_SYSTEMS =
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    14
struct
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    15
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    16
(* helper functions *)
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    17
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    18
fun make_avail name () = getenv (name ^ "_SOLVER") <> ""
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    19
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    20
fun make_command name () = [getenv (name ^ "_SOLVER")]
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    21
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    22
fun outcome_of unsat sat unknown solver_name line =
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    23
  if String.isPrefix unsat line then SMT_Solver.Unsat
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    24
  else if String.isPrefix sat line then SMT_Solver.Sat
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    25
  else if String.isPrefix unknown line then SMT_Solver.Unknown
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    26
  else raise SMT_Failure.SMT (SMT_Failure.Other_Failure ("Solver " ^ quote solver_name ^
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    27
    " failed -- enable tracing using the " ^ quote (Config.name_of SMT_Config.trace) ^
56094
2adbc6e4cd8f let exception pass through in debug mode
blanchet
parents: 56091
diff changeset
    28
    " option for details"))
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    29
60201
90e88e521e0e made CVC4 support work also without unsat cores
blanchet
parents: 59960
diff changeset
    30
fun is_blank_or_error_line "" = true
90e88e521e0e made CVC4 support work also without unsat cores
blanchet
parents: 59960
diff changeset
    31
  | is_blank_or_error_line s = String.isPrefix "(error " s
90e88e521e0e made CVC4 support work also without unsat cores
blanchet
parents: 59960
diff changeset
    32
57239
a40edeaa01b1 don't ask proof-disabled solvers to do proofs
blanchet
parents: 57237
diff changeset
    33
fun on_first_line test_outcome solver_name lines =
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    34
  let
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    35
    val split_first = (fn [] => ("", []) | l :: ls => (l, ls))
60201
90e88e521e0e made CVC4 support work also without unsat cores
blanchet
parents: 59960
diff changeset
    36
    val (l, ls) = split_first (snd (take_prefix is_blank_or_error_line lines))
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    37
  in (test_outcome solver_name l, ls) end
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    38
57704
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
    39
fun on_first_non_unsupported_line test_outcome solver_name lines =
67405
e9ab4ad7bd15 uniform use of Standard ML op-infix -- eliminated warnings;
wenzelm
parents: 67399
diff changeset
    40
  on_first_line test_outcome solver_name (filter (curry (op <>) "unsupported") lines)
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    41
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    42
(* CVC3 *)
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    43
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    44
local
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    45
  fun cvc3_options ctxt = [
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    46
    "-seed", string_of_int (Config.get ctxt SMT_Config.random_seed),
57239
a40edeaa01b1 don't ask proof-disabled solvers to do proofs
blanchet
parents: 57237
diff changeset
    47
    "-lang", "smt2",
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    48
    "-timeout", string_of_int (Real.ceil (Config.get ctxt SMT_Config.timeout))]
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    49
in
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    50
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    51
val cvc3: SMT_Solver.solver_config = {
57209
7ffa0f7e2775 removed '_new' sufffix in SMT2 solver names (in some cases)
blanchet
parents: 57168
diff changeset
    52
  name = "cvc3",
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    53
  class = K SMTLIB_Interface.smtlibC,
57210
5d61d875076a rationalized CVC3 and Yices environment variable -- no need (unlike for Z3) to distinguish between old and new versions
blanchet
parents: 57209
diff changeset
    54
  avail = make_avail "CVC3",
5d61d875076a rationalized CVC3 and Yices environment variable -- no need (unlike for Z3) to distinguish between old and new versions
blanchet
parents: 57209
diff changeset
    55
  command = make_command "CVC3",
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    56
  options = cvc3_options,
57239
a40edeaa01b1 don't ask proof-disabled solvers to do proofs
blanchet
parents: 57237
diff changeset
    57
  smt_options = [],
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    58
  default_max_relevant = 400 (* FUDGE *),
57239
a40edeaa01b1 don't ask proof-disabled solvers to do proofs
blanchet
parents: 57237
diff changeset
    59
  outcome = on_first_line (outcome_of "unsat" "sat" "unknown"),
57157
87b4d54b1fbe split replay and proof parsing for Z3
blanchet
parents: 57156
diff changeset
    60
  parse_proof = NONE,
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    61
  replay = NONE }
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    62
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    63
end
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
    64
66551
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    65
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    66
(* CVC4 *)
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    67
58360
dee1fd1cc631 added interface for CVC4 extensions
blanchet
parents: 58061
diff changeset
    68
val cvc4_extensions = Attrib.setup_config_bool @{binding cvc4_extensions} (K false)
dee1fd1cc631 added interface for CVC4 extensions
blanchet
parents: 58061
diff changeset
    69
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    70
local
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    71
  fun cvc4_options ctxt = [
64461
be149db8207a disable CVC4 statistics, and hence crashes upon user interruptions
blanchet
parents: 63102
diff changeset
    72
    "--no-statistics",
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    73
    "--random-seed=" ^ string_of_int (Config.get ctxt SMT_Config.random_seed),
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    74
    "--lang=smt2",
60201
90e88e521e0e made CVC4 support work also without unsat cores
blanchet
parents: 59960
diff changeset
    75
    "--continued-execution",
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    76
    "--tlimit", string_of_int (Real.ceil (1000.0 * Config.get ctxt SMT_Config.timeout))]
58360
dee1fd1cc631 added interface for CVC4 extensions
blanchet
parents: 58061
diff changeset
    77
dee1fd1cc631 added interface for CVC4 extensions
blanchet
parents: 58061
diff changeset
    78
  fun select_class ctxt =
66551
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    79
    if Config.get ctxt cvc4_extensions then
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    80
      if Config.get ctxt SMT_Config.higher_order then
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    81
        CVC4_Interface.hosmtlib_cvc4C
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    82
      else
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    83
        CVC4_Interface.smtlib_cvc4C
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    84
    else
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    85
      if Config.get ctxt SMT_Config.higher_order then
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    86
        SMTLIB_Interface.hosmtlibC
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    87
      else
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
    88
        SMTLIB_Interface.smtlibC
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    89
in
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    90
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
    91
val cvc4: SMT_Solver.solver_config = {
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    92
  name = "cvc4",
58360
dee1fd1cc631 added interface for CVC4 extensions
blanchet
parents: 58061
diff changeset
    93
  class = select_class,
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    94
  avail = make_avail "CVC4",
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    95
  command = make_command "CVC4",
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    96
  options = cvc4_options,
59015
627a93f67182 parse CVC4 unsat cores
blanchet
parents: 58496
diff changeset
    97
  smt_options = [(":produce-unsat-cores", "true")],
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    98
  default_max_relevant = 400 (* FUDGE *),
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
    99
  outcome = on_first_line (outcome_of "unsat" "sat" "unknown"),
59015
627a93f67182 parse CVC4 unsat cores
blanchet
parents: 58496
diff changeset
   100
  parse_proof = SOME (K CVC4_Proof_Parse.parse_proof),
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
   101
  replay = NONE }
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
   102
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
   103
end
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
   104
66551
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   105
57704
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   106
(* veriT *)
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   107
66551
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   108
local
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   109
  fun select_class ctxt =
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   110
    if Config.get ctxt SMT_Config.higher_order then
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   111
      SMTLIB_Interface.hosmtlibC
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   112
    else
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   113
      SMTLIB_Interface.smtlibC
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   114
in
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   115
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   116
val veriT: SMT_Solver.solver_config = {
59035
3a2153676705 renamed 'veriT' to 'verit', to stick to all-lowercase rule for prover names
blanchet
parents: 59015
diff changeset
   117
  name = "verit",
66551
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   118
  class = select_class,
57704
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   119
  avail = make_avail "VERIT",
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   120
  command = make_command "VERIT",
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   121
  options = (fn ctxt => [
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   122
    "--proof-version=1",
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   123
    "--proof-prune",
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   124
    "--proof-merge",
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   125
    "--disable-print-success",
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   126
    "--disable-banner",
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   127
    "--max-time=" ^ string_of_int (Real.ceil (Config.get ctxt SMT_Config.timeout))]),
61587
c3974cd2d381 updating options to verit
fleury <Mathias.Fleury@mpi-inf.mpg.de>
parents: 60201
diff changeset
   128
  smt_options = [(":produce-proofs", "true")],
58496
2ba52ecc4996 give more facts to veriT -- it seems to be able to cope with them
blanchet
parents: 58491
diff changeset
   129
  default_max_relevant = 200 (* FUDGE *),
63102
71059cf60658 better handling of veriT's 'unknown' status
fleury <Mathias.Fleury@mpi-inf.mpg.de>
parents: 61611
diff changeset
   130
  outcome = on_first_non_unsupported_line (outcome_of "unsat" "sat" "unknown"),
58491
blanchet
parents: 58360
diff changeset
   131
  parse_proof = SOME (K VeriT_Proof_Parse.parse_proof),
57704
c0da3fc313e3 Basic support for the SMT prover veriT.
fleury
parents: 57240
diff changeset
   132
  replay = NONE }
57240
9a5729600ba9 added support for CVC4 in SMT2
blanchet
parents: 57239
diff changeset
   133
66551
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   134
end
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   135
4df6b0ae900d towards support for HO SMT-LIB
blanchet
parents: 64461
diff changeset
   136
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   137
(* Z3 *)
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   138
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   139
val z3_extensions = Attrib.setup_config_bool @{binding z3_extensions} (K false)
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   140
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   141
local
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   142
  fun z3_options ctxt =
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   143
    ["smt.random_seed=" ^ string_of_int (Config.get ctxt SMT_Config.random_seed),
57168
af95a414136a disable hard-to-reconstruct Z3 feature
blanchet
parents: 57164
diff changeset
   144
     "smt.refine_inj_axioms=false",
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   145
     "-T:" ^ string_of_int (Real.ceil (Config.get ctxt SMT_Config.timeout)),
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   146
     "-smt2"]
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   147
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   148
  fun select_class ctxt =
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   149
    if Config.get ctxt z3_extensions then Z3_Interface.smtlib_z3C else SMTLIB_Interface.smtlibC
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   150
in
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   151
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   152
val z3: SMT_Solver.solver_config = {
57209
7ffa0f7e2775 removed '_new' sufffix in SMT2 solver names (in some cases)
blanchet
parents: 57168
diff changeset
   153
  name = "z3",
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   154
  class = select_class,
59960
372ddff01244 updated SMT module and Sledgehammer to fully open source Z3
blanchet
parents: 59035
diff changeset
   155
  avail = make_avail "Z3",
372ddff01244 updated SMT module and Sledgehammer to fully open source Z3
blanchet
parents: 59035
diff changeset
   156
  command = make_command "Z3",
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   157
  options = z3_options,
57239
a40edeaa01b1 don't ask proof-disabled solvers to do proofs
blanchet
parents: 57237
diff changeset
   158
  smt_options = [(":produce-proofs", "true")],
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   159
  default_max_relevant = 350 (* FUDGE *),
57239
a40edeaa01b1 don't ask proof-disabled solvers to do proofs
blanchet
parents: 57237
diff changeset
   160
  outcome = on_first_line (outcome_of "unsat" "sat" "unknown"),
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   161
  parse_proof = SOME Z3_Replay.parse_proof,
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   162
  replay = SOME Z3_Replay.replay }
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   163
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   164
end
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   165
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   166
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   167
(* overall setup *)
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   168
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   169
val _ = Theory.setup (
58061
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   170
  SMT_Solver.add_solver cvc3 #>
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   171
  SMT_Solver.add_solver cvc4 #>
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   172
  SMT_Solver.add_solver veriT #>
3d060f43accb renamed new SMT module from 'SMT2' to 'SMT'
blanchet
parents: 57714
diff changeset
   173
  SMT_Solver.add_solver z3)
56078
624faeda77b5 moved 'SMT2' (SMT-LIB-2-based SMT module) into Isabelle
blanchet
parents:
diff changeset
   174
57229
blanchet
parents: 57210
diff changeset
   175
end;