41 temp_file_stdout(
"smt2_dec_stdout_",
""),
42 temp_file_stderr(
"smt2_dec_stderr_",
"");
44 const auto write_problem_to_file = [&](std::ofstream problem_out) {
60 write_problem_to_file(std::ofstream(
63 std::vector<std::string> argv;
64 std::string stdin_filename;
69 argv = {
"bitwuzla", temp_file_problem()};
73 argv = {
"boolector",
"--smt2", temp_file_problem(),
"-m"};
77 argv = {
"smt2_solver"};
78 stdin_filename = temp_file_problem();
94 argv = {
"cvc4",
"-L",
"smt2", temp_file_problem()};
98 argv = {
"cvc5",
"--lang",
"smtlib", temp_file_problem()};
107 "-preprocessor.toplevel_propagation=true",
108 "-preprocessor.simplification=7",
109 "-dpll.branching_random_frequency=0.01",
110 "-dpll.branching_random_invalidate_phase_cache=true",
111 "-dpll.restart_strategy=3",
112 "-dpll.glucose_var_activity=true",
113 "-dpll.glucose_learnt_minimization=true",
114 "-theory.bv.eager=true",
115 "-theory.bv.bit_blast_mode=1",
116 "-theory.bv.delay_propagated_eqs=true",
118 "-theory.fp.bit_blast_mode=2",
119 "-theory.arr.mode=1"};
121 stdin_filename = temp_file_problem();
127 argv = {
"yices-smt2", temp_file_problem()};
131 argv = {
"z3",
"-smt2", temp_file_problem()};
139 run(argv[0], argv, stdin_filename, temp_file_stdout(), temp_file_stderr());
148 std::ifstream in(temp_file_stdout());
154 if(src.size() >= 2 && src.front() ==
'|' && src.back() ==
'|')
155 return std::string(src, 1, src.size() - 2);
168 typedef std::unordered_map<irep_idt, irept> valuest;
169 valuest parsed_values;
175 if(!parsed_opt.has_value())
178 const auto &parsed = parsed_opt.value();
180 if(parsed.id()==
"sat")
182 else if(parsed.id()==
"unsat")
184 else if(parsed.id() ==
"unknown")
191 parsed.id().empty() && parsed.get_sub().size() == 1 &&
192 parsed.get_sub().front().get_sub().size() == 2)
203 parsed_values[s0.
id()] =
s1;
206 parsed.id().empty() && parsed.get_sub().size() == 2 &&
207 parsed.get_sub().front().id() ==
"error")
213 const auto &message =
id2string(parsed.get_sub()[1].id());
215 log.error() <<
"SMT2 solver returned error message:\n"
230 const irept &value = parsed_values[conv_id];
231 assignment.second.value =
parse_rec(value, assignment.second.type);
237 const std::string boolean_identifier =
239 const auto found_parsed_value =
240 parsed_values.find(
drop_quotes(boolean_identifier));
241 if(found_parsed_value != parsed_values.end())
243 const irept &value = found_parsed_value->second;
245 if(value.
id() != ID_true && value.
id() != ID_false)
248 log.error() <<
"SMT2 solver returned non-constant value for variable "
257 const auto found_set_value =
set_values.find(boolean_identifier);
265 const irept &value = parsed_values[boolean_identifier];
267 if(value.
id() != ID_true && value.
id() != ID_false)
271 <<
"SMT2 solver returned non-Boolean value for variable "
resultt
Result of running the decision procedure.
Base class for all expressions.
There are a large number of kinds of tree structured or tree-like data in CPROVER.
const irep_idt & id() const
Class that provides messages with a built-in verbosity 'level'.
std::size_t number_of_solver_calls
void write_footer()
Writes the end of the SMT file to the smt_convt::out stream.
static std::string convert_identifier(const irep_idt &identifier)
std::unordered_map< irep_idt, bool > set_values
The values which boolean identifiers have been smt2_convt::set_to or in other words those which are a...
exprt parse_rec(const irept &s, const typet &type)
std::vector< bool > boolean_assignment
std::vector< literalt > assumptions
identifier_mapt identifier_map
std::size_t no_boolean_variables
literalt convert(const exprt &expr)
message_handlert & message_handler
std::string decision_procedure_text() const override
Return a textual description of the decision procedure.
resultt dec_solve(const exprt &) override
Implementation of the decision procedure.
resultt read_result(std::istream &in)
std::stringstream cached_output
Everything except the footer is cached, so that output files can be rewritten with varying footers.
std::stringstream stringstream
const std::string & id2string(const irep_idt &d)
int run(const std::string &what, const std::vector< std::string > &argv)
static std::string drop_quotes(std::string src)
std::optional< irept > smt2irep(std::istream &in, message_handlert &message_handler)
returns an irep for an SMT-LIB2 expression read from a given stream returns {} when EOF is encountere...
#define UNREACHABLE
This should be used to mark dead code.
std::string to_string(const string_not_contains_constraintt &expr)
Used for debug printing.