CBMC
|
#include <smt2_conv.h>
Classes | |
struct | identifiert |
class | smt2_symbolt |
Public Types | |
enum | solvert { solvert::GENERIC, solvert::BOOLECTOR, solvert::CPROVER_SMT2, solvert::CVC3, solvert::CVC4, solvert::MATHSAT, solvert::YICES, solvert::Z3 } |
![]() | |
enum | resultt { resultt::D_SATISFIABLE, resultt::D_UNSATISFIABLE, resultt::D_ERROR } |
Result of running the decision procedure. More... | |
Public Member Functions | |
smt2_convt (const namespacet &_ns, const std::string &_benchmark, const std::string &_notes, const std::string &_logic, solvert _solver, std::ostream &_out) | |
~smt2_convt () override=default | |
exprt | handle (const exprt &expr) override |
Generate a handle, which is an expression that has the same value as the argument in any model that is generated; this offers an efficient way to refer to the expression in subsequent calls to get or set_to. More... | |
void | set_to (const exprt &expr, bool value) override |
For a Boolean expression expr , add the constraint 'expr' if value is true , otherwise add 'not expr'. More... | |
exprt | get (const exprt &expr) const override |
Return expr with variables replaced by values from satisfying assignment if available. More... | |
std::string | decision_procedure_text () const override |
Return a textual description of the decision procedure. More... | |
void | print_assignment (std::ostream &out) const override |
Print satisfying assignment to out . More... | |
void | push () override |
Unimplemented. More... | |
void | push (const std::vector< exprt > &_assumptions) override |
Currently, only implements a single stack element (no nested contexts) More... | |
void | pop () override |
Currently, only implements a single stack element (no nested contexts) More... | |
std::size_t | get_number_of_solver_calls () const override |
Return the number of incremental solver calls. More... | |
![]() | |
virtual | ~stack_decision_proceduret ()=default |
![]() | |
void | set_to_true (const exprt &expr) |
For a Boolean expression expr , add the constraint 'expr'. More... | |
void | set_to_false (const exprt &expr) |
For a Boolean expression expr , add the constraint 'not expr'. More... | |
resultt | operator() () |
Run the decision procedure to solve the problem. More... | |
virtual | ~decision_proceduret () |
Static Public Member Functions | |
static std::string | convert_identifier (const irep_idt &identifier) |
Public Attributes | |
bool | use_FPA_theory |
bool | use_array_of_bool |
bool | use_as_const |
bool | use_check_sat_assuming |
bool | use_datatypes |
bool | use_lambda_for_array |
bool | emit_set_logic |
Protected Types | |
enum | wheret { wheret::BEGIN, wheret::END } |
typedef std::unordered_map< irep_idt, identifiert > | identifier_mapt |
typedef std::map< typet, std::string > | datatype_mapt |
typedef std::map< exprt, irep_idt > | defined_expressionst |
typedef std::set< std::string > | smt2_identifierst |
Protected Member Functions | |
resultt | dec_solve () override |
Run the decision procedure to solve the problem. More... | |
void | write_header () |
void | write_footer () |
Writes the end of the SMT file to the smt_convt::out stream. More... | |
bool | use_array_theory (const exprt &) |
void | flatten_array (const exprt &) |
produce a flat bit-vector for a given array of fixed size More... | |
void | convert_typecast (const typecast_exprt &expr) |
void | convert_floatbv_typecast (const floatbv_typecast_exprt &expr) |
void | convert_struct (const struct_exprt &expr) |
void | convert_union (const union_exprt &expr) |
void | convert_constant (const constant_exprt &expr) |
void | convert_relation (const binary_relation_exprt &) |
void | convert_is_dynamic_object (const unary_exprt &) |
void | convert_plus (const plus_exprt &expr) |
void | convert_minus (const minus_exprt &expr) |
void | convert_div (const div_exprt &expr) |
void | convert_mult (const mult_exprt &expr) |
void | convert_rounding_mode_FPA (const exprt &expr) |
Converting a constant or symbolic rounding mode to SMT-LIB. More... | |
void | convert_floatbv_plus (const ieee_float_op_exprt &expr) |
void | convert_floatbv_minus (const ieee_float_op_exprt &expr) |
void | convert_floatbv_div (const ieee_float_op_exprt &expr) |
void | convert_floatbv_mult (const ieee_float_op_exprt &expr) |
void | convert_floatbv_rem (const binary_exprt &expr) |
void | convert_mod (const mod_exprt &expr) |
void | convert_euclidean_mod (const euclidean_mod_exprt &expr) |
void | convert_index (const index_exprt &expr) |
void | convert_member (const member_exprt &expr) |
void | convert_with (const with_exprt &expr) |
void | convert_update (const exprt &expr) |
void | convert_expr (const exprt &) |
void | convert_type (const typet &) |
void | convert_literal (const literalt) |
literalt | convert (const exprt &expr) |
tvt | l_get (literalt l) const |
exprt | prepare_for_convert_expr (const exprt &expr) |
Perform steps necessary before an expression is passed to convert_expr. More... | |
exprt | lower_byte_operators (const exprt &expr) |
Lower byte_update and byte_extract operations within expr . More... | |
void | find_symbols (const exprt &expr) |
void | find_symbols (const typet &type) |
void | find_symbols_rec (const typet &type, std::set< irep_idt > &recstack) |
constant_exprt | parse_literal (const irept &, const typet &type) |
struct_exprt | parse_struct (const irept &s, const struct_typet &type) |
exprt | parse_union (const irept &s, const union_typet &type) |
exprt | parse_array (const irept &s, const array_typet &type) |
This function is for parsing array output from SMT solvers when "(get-value |???|)" returns an array object. More... | |
exprt | parse_rec (const irept &s, const typet &type) |
void | walk_array_tree (std::unordered_map< int64_t, exprt > *operands_map, const irept &src, const array_typet &type) |
This function walks the SMT output and populates a map with index/value pairs for the array. More... | |
void | convert_floatbv (const exprt &expr) |
std::string | type2id (const typet &) const |
std::string | floatbv_suffix (const exprt &) const |
const smt2_symbolt & | to_smt2_symbol (const exprt &expr) |
void | flatten2bv (const exprt &) |
void | unflatten (wheret, const typet &, unsigned nesting=0) |
void | convert_address_of_rec (const exprt &expr, const pointer_typet &result_type) |
void | define_object_size (const irep_idt &id, const object_size_exprt &expr) |
Protected Attributes | |
const namespacet & | ns |
std::ostream & | out |
std::string | benchmark |
std::string | notes |
std::string | logic |
solvert | solver |
std::vector< exprt > | assumptions |
boolbv_widtht | boolbv_width |
std::size_t | number_of_solver_calls = 0 |
letifyt | letify |
std::set< irep_idt > | bvfp_set |
pointer_logict | pointer_logic |
identifier_mapt | identifier_map |
datatype_mapt | datatype_map |
defined_expressionst | defined_expressions |
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 asserted as true / false in the output smt2 formula. More... | |
std::map< object_size_exprt, irep_idt > | object_sizes |
smt2_identifierst | smt2_identifiers |
std::size_t | no_boolean_variables |
std::vector< bool > | boolean_assignment |
Definition at line 36 of file smt2_conv.h.
|
protected |
Definition at line 244 of file smt2_conv.h.
|
protected |
Definition at line 253 of file smt2_conv.h.
|
protected |
Definition at line 236 of file smt2_conv.h.
|
protected |
Definition at line 262 of file smt2_conv.h.
|
strong |
Enumerator | |
---|---|
GENERIC | |
BOOLECTOR | |
CPROVER_SMT2 | |
CVC3 | |
CVC4 | |
MATHSAT | |
YICES | |
Z3 |
Definition at line 39 of file smt2_conv.h.
|
strongprotected |
Enumerator | |
---|---|
BEGIN | |
END |
Definition at line 211 of file smt2_conv.h.
smt2_convt::smt2_convt | ( | const namespacet & | _ns, |
const std::string & | _benchmark, | ||
const std::string & | _notes, | ||
const std::string & | _logic, | ||
solvert | _solver, | ||
std::ostream & | _out | ||
) |
Definition at line 55 of file smt2_conv.cpp.
|
overridedefault |
Definition at line 804 of file smt2_conv.cpp.
|
protected |
Definition at line 702 of file smt2_conv.cpp.
|
protected |
Definition at line 3146 of file smt2_conv.cpp.
|
protected |
Definition at line 3831 of file smt2_conv.cpp.
|
protected |
Definition at line 3290 of file smt2_conv.cpp.
|
protected |
Definition at line 1046 of file smt2_conv.cpp.
|
protected |
Definition at line 1012 of file smt2_conv.cpp.
|
protected |
Definition at line 3875 of file smt2_conv.cpp.
|
protected |
Definition at line 3811 of file smt2_conv.cpp.
|
protected |
Definition at line 3970 of file smt2_conv.cpp.
|
protected |
Definition at line 3661 of file smt2_conv.cpp.
|
protected |
Definition at line 3990 of file smt2_conv.cpp.
|
protected |
Definition at line 2876 of file smt2_conv.cpp.
|
static |
Definition at line 926 of file smt2_conv.cpp.
|
protected |
Definition at line 4258 of file smt2_conv.cpp.
|
protected |
Definition at line 3324 of file smt2_conv.cpp.
|
protected |
Definition at line 869 of file smt2_conv.cpp.
|
protected |
Definition at line 4355 of file smt2_conv.cpp.
|
protected |
Definition at line 3702 of file smt2_conv.cpp.
|
protected |
Definition at line 3305 of file smt2_conv.cpp.
|
protected |
Definition at line 3895 of file smt2_conv.cpp.
|
protected |
Definition at line 3468 of file smt2_conv.cpp.
|
protected |
Definition at line 3361 of file smt2_conv.cpp.
|
protected |
Converting a constant or symbolic rounding mode to SMT-LIB.
Only called when use_FPA_theory is enabled. SMT-LIB output to is sent to out
.
Definition at line 3604 of file smt2_conv.cpp.
|
protected |
Definition at line 3020 of file smt2_conv.cpp.
|
protected |
Definition at line 5124 of file smt2_conv.cpp.
|
protected |
Definition at line 2343 of file smt2_conv.cpp.
|
protected |
Definition at line 3117 of file smt2_conv.cpp.
|
protected |
Definition at line 4251 of file smt2_conv.cpp.
|
protected |
Definition at line 4013 of file smt2_conv.cpp.
|
overrideprotectedvirtual |
Run the decision procedure to solve the problem.
Implements decision_proceduret.
Reimplemented in smt2_dect.
Definition at line 272 of file smt2_conv.cpp.
|
overridevirtual |
Return a textual description of the decision procedure.
Implements decision_proceduret.
Reimplemented in smt2_dect.
Definition at line 126 of file smt2_conv.cpp.
|
protected |
Definition at line 235 of file smt2_conv.cpp.
|
protected |
Definition at line 4800 of file smt2_conv.cpp.
|
protected |
Definition at line 5257 of file smt2_conv.cpp.
Definition at line 5263 of file smt2_conv.cpp.
|
protected |
Definition at line 4416 of file smt2_conv.cpp.
|
protected |
produce a flat bit-vector for a given array of fixed size
Definition at line 3086 of file smt2_conv.cpp.
|
protected |
Definition at line 1005 of file smt2_conv.cpp.
Return expr
with variables replaced by values from satisfying assignment if available.
Return nil
if not available
Implements decision_proceduret.
Definition at line 279 of file smt2_conv.cpp.
|
overridevirtual |
Return the number of incremental solver calls.
Implements decision_proceduret.
Definition at line 5478 of file smt2_conv.cpp.
Generate a handle, which is an expression that has the same value as the argument in any model that is generated; this offers an efficient way to refer to the expression in subsequent calls to get or set_to.
The returned expression may be the expression itself or a more compact but solver-specific representation.
Implements decision_proceduret.
Definition at line 860 of file smt2_conv.cpp.
Definition at line 141 of file smt2_conv.cpp.
Lower byte_update and byte_extract operations within expr
.
Return an equivalent expression that doesn't use byte operators. Note this replaces operators post-order (compare lower_byte_operators, which uses a pre-order walk, replacing in child expressions before the parent). Pre-order replacement currently fails regression tests: see https://github.com/diffblue/cbmc/issues/4380
Definition at line 4753 of file smt2_conv.cpp.
|
protected |
This function is for parsing array output from SMT solvers when "(get-value |???|)" returns an array object.
s | is the irept parsed from the SMT output |
type | is the expected type |
Definition at line 477 of file smt2_conv.cpp.
|
protected |
Definition at line 339 of file smt2_conv.cpp.
Definition at line 636 of file smt2_conv.cpp.
|
protected |
Definition at line 577 of file smt2_conv.cpp.
|
protected |
Definition at line 561 of file smt2_conv.cpp.
|
overridevirtual |
Currently, only implements a single stack element (no nested contexts)
Implements stack_decision_proceduret.
Definition at line 904 of file smt2_conv.cpp.
Perform steps necessary before an expression is passed to convert_expr.
expr | expression to prepare |
Definition at line 4785 of file smt2_conv.cpp.
|
overridevirtual |
Print satisfying assignment to out
.
Implements decision_proceduret.
Definition at line 131 of file smt2_conv.cpp.
|
overridevirtual |
|
overridevirtual |
Currently, only implements a single stack element (no nested contexts)
Implements stack_decision_proceduret.
Definition at line 897 of file smt2_conv.cpp.
|
overridevirtual |
For a Boolean expression expr
, add the constraint 'expr' if value
is true
, otherwise add 'not expr'.
Implements decision_proceduret.
Definition at line 4609 of file smt2_conv.cpp.
|
inlineprotected |
Definition at line 201 of file smt2_conv.h.
|
protected |
Definition at line 961 of file smt2_conv.cpp.
Definition at line 4505 of file smt2_conv.cpp.
|
protected |
Definition at line 5103 of file smt2_conv.cpp.
|
protected |
This function walks the SMT output and populates a map with index/value pairs for the array.
operands_map | is a map of the operands to the array being constructed indexed by their index. |
src | is the irept source for the SMT output |
type | is the type of the array |
Definition at line 521 of file smt2_conv.cpp.
|
protected |
Writes the end of the SMT file to the smt_convt::out
stream.
These parts of the output may be changed when using multiple rounds of solving. They include the following parts of the output file -
assumptions
member variable.(check-sat)
or check-sat-assuming
command.(get-value |identifier|)
command for each of the identifiers in smt2_convt::smt2_identifiers
.(exit)
command. Definition at line 184 of file smt2_conv.cpp.
|
protected |
Definition at line 154 of file smt2_conv.cpp.
|
protected |
Definition at line 94 of file smt2_conv.h.
|
protected |
Definition at line 91 of file smt2_conv.h.
|
protected |
Definition at line 95 of file smt2_conv.h.
|
protected |
Definition at line 267 of file smt2_conv.h.
|
protected |
Definition at line 186 of file smt2_conv.h.
|
protected |
Definition at line 245 of file smt2_conv.h.
|
protected |
Definition at line 254 of file smt2_conv.h.
bool smt2_convt::emit_set_logic |
Definition at line 67 of file smt2_conv.h.
|
protected |
Definition at line 238 of file smt2_conv.h.
|
protected |
Definition at line 158 of file smt2_conv.h.
|
protected |
Definition at line 91 of file smt2_conv.h.
|
protected |
Definition at line 266 of file smt2_conv.h.
|
protected |
Definition at line 91 of file smt2_conv.h.
|
protected |
Definition at line 89 of file smt2_conv.h.
|
protected |
Definition at line 97 of file smt2_conv.h.
|
protected |
Definition at line 260 of file smt2_conv.h.
|
protected |
Definition at line 90 of file smt2_conv.h.
|
protected |
Definition at line 216 of file smt2_conv.h.
|
protected |
The values which boolean identifiers have been smt2_convt::set_to
or in other words those which are asserted as true / false in the output smt2 formula.
Definition at line 258 of file smt2_conv.h.
|
protected |
Definition at line 263 of file smt2_conv.h.
|
protected |
Definition at line 92 of file smt2_conv.h.
bool smt2_convt::use_array_of_bool |
Definition at line 62 of file smt2_conv.h.
bool smt2_convt::use_as_const |
Definition at line 63 of file smt2_conv.h.
bool smt2_convt::use_check_sat_assuming |
Definition at line 64 of file smt2_conv.h.
bool smt2_convt::use_datatypes |
Definition at line 65 of file smt2_conv.h.
bool smt2_convt::use_FPA_theory |
Definition at line 61 of file smt2_conv.h.
bool smt2_convt::use_lambda_for_array |
Definition at line 66 of file smt2_conv.h.