26 if(type_id==ID_pointer)
34 else if(type_id==ID_integer ||
40 else if(type_id==ID_unsignedbv)
46 else if(type_id==ID_signedbv)
52 else if(type_id==ID_c_bool)
58 else if(type_id==ID_c_enum)
61 if(underlying_type.
id() == ID_signedbv)
67 else if(underlying_type.
id() == ID_unsignedbv)
74 else if(type_id==ID_c_bit_field)
77 const auto width = c_bit_field_type.get_width();
78 const typet &underlying_type = c_bit_field_type.underlying_type();
80 if(underlying_type.
id() == ID_signedbv)
85 else if(underlying_type.
id() == ID_unsignedbv)
90 else if(underlying_type.
id() == ID_c_bool)
106 if(type_id==ID_integer)
110 else if(type_id==ID_natural)
115 else if(type_id==ID_unsignedbv)
120 else if(type_id==ID_bv)
125 else if(type_id==ID_signedbv)
130 else if(type_id==ID_c_enum)
132 const std::size_t width =
136 else if(type_id==ID_c_bool)
141 else if(type_id==ID_bool)
149 else if(type_id==ID_pointer)
154 else if(type_id==ID_c_bit_field)
159 else if(type_id==ID_fixedbv)
166 else if(type_id==ID_floatbv)
183 std::size_t result = 1;
185 for(
mp_integer x = 2; x < size; ++result, x *= 2) {}
187 INVARIANT(
power(2, result) >= size,
"address_bits(size) >= log2(size)");
204 if(base.is_long() && exponent.is_long())
206 switch(base.to_long())
211 result.setPower2(numeric_cast_v<unsigned>(exponent));
228 if(exponent.is_odd())
265 std::size_t bit_index)
273 const auto nibble_index = bit_index / 4;
275 if(nibble_index >= src.
size())
278 const char nibble = src[src.
size() - 1 - nibble_index];
281 isdigit(nibble) || (nibble >=
'A' && nibble <=
'F'),
282 "bvrep is hexadecimal, upper-case");
284 const unsigned char nibble_value =
285 isdigit(nibble) ? nibble -
'0' : nibble -
'A' + 10;
287 return ((nibble_value >> (bit_index % 4)) & 1) != 0;
296 return 'A' + nibble - 10;
306 make_bvrep(
const std::size_t width,
const std::function<
bool(std::size_t)> f)
309 result.reserve((width + 3) / 4);
310 unsigned char nibble = 0;
312 for(std::size_t i = 0; i < width; i++)
314 const auto bit_in_nibble = i % 4;
316 nibble |= ((
unsigned char)f(i)) << bit_in_nibble;
318 if(bit_in_nibble == 3)
329 const std::size_t
pos = result.find_last_not_of(
'0');
331 if(
pos == std::string::npos)
335 result.resize(
pos + 1);
337 std::reverse(result.begin(), result.end());
353 const std::size_t width,
354 const std::function<
bool(
bool,
bool)> f)
356 return make_bvrep(width, [&a, &b, &width, f](std::size_t i) {
369 const std::size_t width,
370 const std::function<
bool(
bool)> f)
372 return make_bvrep(width, [&a, &width, f](std::size_t i) {
384 if(src.is_negative())
408 const auto p =
power(2, width - 1);
411 const auto result = tmp - 2 * p;
const floatbv_typet & to_floatbv_type(const typet &type)
Cast a typet to a floatbv_typet.
const signedbv_typet & to_signedbv_type(const typet &type)
Cast a typet to a signedbv_typet.
const bitvector_typet & to_bitvector_type(const typet &type)
Cast a typet to a bitvector_typet.
const fixedbv_typet & to_fixedbv_type(const typet &type)
Cast a typet to a fixedbv_typet.
const unsignedbv_typet & to_unsignedbv_type(const typet &type)
Cast a typet to an unsignedbv_typet.
const bv_typet & to_bv_type(const typet &type)
Cast a typet to a bv_typet.
const c_enum_typet & to_c_enum_type(const typet &type)
Cast a typet to a c_enum_typet.
const c_bit_field_typet & to_c_bit_field_type(const typet &type)
Cast a typet to a c_bit_field_typet.
const c_bool_typet & to_c_bool_type(const typet &type)
Cast a typet to a c_bool_typet.
std::size_t get_width() const
const typet & underlying_type() const
A constant literal expression.
const irep_idt & get_value() const
bool is_null_pointer() const
Returns true if expr has a pointer type and a value NULL; it also returns true when expr has value ze...
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
typet & type()
Return the type of the expression.
The Boolean constant false.
void from_integer(const mp_integer &i)
constant_exprt to_expr() const
constant_exprt to_expr() const
void from_integer(const mp_integer &i)
const irep_idt & id() const
The null pointer constant.
The Boolean constant true.
The type of an expression, extends irept.
Deprecated expression utility functions.
const std::string & id2string(const irep_idt &d)
const mp_integer string2integer(const std::string &n, unsigned base)
const std::string integer2string(const mp_integer &n, unsigned base)
const pointer_typet & to_pointer_type(const typet &type)
Cast a typet to a pointer_typet.
#define DATA_INVARIANT(CONDITION, REASON)
This condition should be used to document that assumptions that are made on goto_functions,...
#define PRECONDITION(CONDITION)
#define INVARIANT(CONDITION, REASON)
This macro uses the wrapper function 'invariant_violated_string'.
API to expression classes.
bool is_signed(const typet &t)
Convenience function – is the type signed?