CBMC
|
#include <smt2_conv.h>
Classes | |
struct | identifiert |
class | smt2_symbolt |
Public Types | |
enum class | solvert { GENERIC , BITWUZLA , BOOLECTOR , CPROVER_SMT2 , CVC3 , CVC4 , CVC5 , MATHSAT , YICES , Z3 } |
Public Types inherited from decision_proceduret | |
enum class | resultt { D_SATISFIABLE , D_UNSATISFIABLE , 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... | |
void | set_converter (irep_idt id, std::function< void(const exprt &)> converter) |
Public Member Functions inherited from stack_decision_proceduret | |
virtual | ~stack_decision_proceduret ()=default |
Public Member Functions inherited from decision_proceduret | |
void | set_to_true (const exprt &) |
For a Boolean expression expr , add the constraint 'expr'. More... | |
void | set_to_false (const exprt &) |
For a Boolean expression expr , add the constraint 'not expr'. More... | |
resultt | operator() () |
Run the decision procedure to solve the problem This corresponds to SMT-LIB's check-sat. More... | |
resultt | operator() (const exprt &assumption) |
Run the decision procedure to solve the problem under the given assumption. 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 class | wheret { BEGIN , END } |
using | converterst = std::unordered_map< irep_idt, std::function< void(const exprt &)>, irep_id_hash > |
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 (const exprt &) override |
Implementation of the decision procedure. 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 update_exprt &) |
void | convert_update_bit (const update_bit_exprt &) |
void | convert_update_bits (const update_bits_exprt &) |
void | convert_expr (const exprt &) |
void | convert_type (const typet &) |
void | convert_literal (const literalt) |
void | convert_string_literal (const std::string &) |
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 |
converterst | converters |
std::vector< literalt > | assumptions |
boolbv_widtht | boolbv_width |
std::size_t | number_of_solver_calls = 0 |
letifyt | letify |
std::unordered_map< irep_idt, irept > | current_bindings |
std::set< irep_idt > | bvfp_set |
std::set< irep_idt > | state_fkt_declared |
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 39 of file smt2_conv.h.
|
protected |
Definition at line 103 of file smt2_conv.h.
|
protected |
Definition at line 268 of file smt2_conv.h.
|
protected |
Definition at line 277 of file smt2_conv.h.
|
protected |
Definition at line 260 of file smt2_conv.h.
|
protected |
Definition at line 286 of file smt2_conv.h.
|
strong |
Enumerator | |
---|---|
GENERIC | |
BITWUZLA | |
BOOLECTOR | |
CPROVER_SMT2 | |
CVC3 | |
CVC4 | |
CVC5 | |
MATHSAT | |
YICES | |
Z3 |
Definition at line 42 of file smt2_conv.h.
|
strongprotected |
Enumerator | |
---|---|
BEGIN | |
END |
Definition at line 232 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 56 of file smt2_conv.cpp.
|
overridedefault |
Definition at line 896 of file smt2_conv.cpp.
|
protected |
Definition at line 783 of file smt2_conv.cpp.
|
protected |
Definition at line 3329 of file smt2_conv.cpp.
|
protected |
Definition at line 3963 of file smt2_conv.cpp.
|
protected |
Definition at line 3488 of file smt2_conv.cpp.
|
protected |
Definition at line 1165 of file smt2_conv.cpp.
|
protected |
Definition at line 1118 of file smt2_conv.cpp.
|
protected |
Definition at line 4007 of file smt2_conv.cpp.
|
protected |
Definition at line 3943 of file smt2_conv.cpp.
|
protected |
Definition at line 4102 of file smt2_conv.cpp.
|
protected |
Definition at line 3829 of file smt2_conv.cpp.
|
protected |
Definition at line 4122 of file smt2_conv.cpp.
|
protected |
Definition at line 3051 of file smt2_conv.cpp.
|
static |
Definition at line 1020 of file smt2_conv.cpp.
|
protected |
Definition at line 4370 of file smt2_conv.cpp.
|
protected |
Definition at line 3522 of file smt2_conv.cpp.
|
protected |
Definition at line 961 of file smt2_conv.cpp.
|
protected |
Definition at line 4440 of file smt2_conv.cpp.
|
protected |
Definition at line 3864 of file smt2_conv.cpp.
|
protected |
Definition at line 3503 of file smt2_conv.cpp.
|
protected |
Definition at line 4027 of file smt2_conv.cpp.
|
protected |
Definition at line 3666 of file smt2_conv.cpp.
|
protected |
Definition at line 3559 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 3772 of file smt2_conv.cpp.
|
protected |
Definition at line 1152 of file smt2_conv.cpp.
|
protected |
Definition at line 3195 of file smt2_conv.cpp.
|
protected |
Definition at line 5524 of file smt2_conv.cpp.
|
protected |
Definition at line 2490 of file smt2_conv.cpp.
|
protected |
Definition at line 3301 of file smt2_conv.cpp.
|
protected |
Definition at line 4353 of file smt2_conv.cpp.
|
protected |
Definition at line 4360 of file smt2_conv.cpp.
|
protected |
Definition at line 4365 of file smt2_conv.cpp.
|
protected |
Definition at line 4145 of file smt2_conv.cpp.
|
overrideprotectedvirtual |
Implementation of the decision procedure.
Implements decision_proceduret.
Reimplemented in smt2_dect.
Definition at line 320 of file smt2_conv.cpp.
|
overridevirtual |
Return a textual description of the decision procedure.
Implements decision_proceduret.
Reimplemented in smt2_dect.
Definition at line 145 of file smt2_conv.cpp.
|
protected |
Definition at line 284 of file smt2_conv.cpp.
|
protected |
Definition at line 4945 of file smt2_conv.cpp.
|
protected |
Definition at line 5659 of file smt2_conv.cpp.
Definition at line 5665 of file smt2_conv.cpp.
|
protected |
Definition at line 4511 of file smt2_conv.cpp.
|
protected |
produce a flat bit-vector for a given array of fixed size
Definition at line 3270 of file smt2_conv.cpp.
|
protected |
Definition at line 1111 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 335 of file smt2_conv.cpp.
|
overridevirtual |
Return the number of incremental solver calls.
Implements decision_proceduret.
Definition at line 5866 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 952 of file smt2_conv.cpp.
Definition at line 160 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 4874 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 531 of file smt2_conv.cpp.
|
protected |
Definition at line 394 of file smt2_conv.cpp.
Definition at line 698 of file smt2_conv.cpp.
|
protected |
Definition at line 629 of file smt2_conv.cpp.
|
protected |
Definition at line 613 of file smt2_conv.cpp.
|
overridevirtual |
Currently, only implements a single stack element (no nested contexts)
Implements stack_decision_proceduret.
Definition at line 998 of file smt2_conv.cpp.
Perform steps necessary before an expression is passed to convert_expr.
expr | expression to prepare |
Definition at line 4906 of file smt2_conv.cpp.
|
overridevirtual |
Print satisfying assignment to out
.
Implements decision_proceduret.
Definition at line 150 of file smt2_conv.cpp.
|
overridevirtual |
|
overridevirtual |
Currently, only implements a single stack element (no nested contexts)
Implements stack_decision_proceduret.
Definition at line 989 of file smt2_conv.cpp.
|
inline |
Definition at line 93 of file smt2_conv.h.
|
overridevirtual |
For a Boolean expression expr
, add the constraint 'expr' if value
is true
, otherwise add 'not expr'.
Implements decision_proceduret.
Definition at line 4719 of file smt2_conv.cpp.
|
inlineprotected |
Definition at line 222 of file smt2_conv.h.
|
protected |
Definition at line 1055 of file smt2_conv.cpp.
Definition at line 4602 of file smt2_conv.cpp.
|
protected |
Definition at line 5512 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 575 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 205 of file smt2_conv.cpp.
|
protected |
Definition at line 173 of file smt2_conv.cpp.
|
protected |
Definition at line 107 of file smt2_conv.h.
|
protected |
Definition at line 101 of file smt2_conv.h.
|
protected |
Definition at line 108 of file smt2_conv.h.
|
protected |
Definition at line 291 of file smt2_conv.h.
|
protected |
Definition at line 203 of file smt2_conv.h.
|
protected |
Definition at line 105 of file smt2_conv.h.
Definition at line 197 of file smt2_conv.h.
|
protected |
Definition at line 269 of file smt2_conv.h.
|
protected |
Definition at line 278 of file smt2_conv.h.
bool smt2_convt::emit_set_logic |
Definition at line 72 of file smt2_conv.h.
|
protected |
Definition at line 262 of file smt2_conv.h.
|
protected |
Definition at line 174 of file smt2_conv.h.
|
protected |
Definition at line 101 of file smt2_conv.h.
|
protected |
Definition at line 290 of file smt2_conv.h.
|
protected |
Definition at line 101 of file smt2_conv.h.
|
protected |
Definition at line 99 of file smt2_conv.h.
|
protected |
Definition at line 110 of file smt2_conv.h.
|
protected |
Definition at line 284 of file smt2_conv.h.
|
protected |
Definition at line 100 of file smt2_conv.h.
|
protected |
Definition at line 237 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 282 of file smt2_conv.h.
|
protected |
Definition at line 287 of file smt2_conv.h.
|
protected |
Definition at line 102 of file smt2_conv.h.
|
protected |
Definition at line 207 of file smt2_conv.h.
bool smt2_convt::use_array_of_bool |
Definition at line 67 of file smt2_conv.h.
bool smt2_convt::use_as_const |
Definition at line 68 of file smt2_conv.h.
bool smt2_convt::use_check_sat_assuming |
Definition at line 69 of file smt2_conv.h.
bool smt2_convt::use_datatypes |
Definition at line 70 of file smt2_conv.h.
bool smt2_convt::use_FPA_theory |
Definition at line 66 of file smt2_conv.h.
bool smt2_convt::use_lambda_for_array |
Definition at line 71 of file smt2_conv.h.