CBMC
Loading...
Searching...
No Matches
boolbv_power.cpp
Go to the documentation of this file.
1/*******************************************************************\
2
3Module:
4
5Author: Daniel Kroening, kroening@kroening.com
6
7\*******************************************************************/
8
10
11#include "boolbv.h"
12
14{
15 const typet &type = expr.type();
16
17 std::size_t width=boolbv_width(type);
18
19 if(type.id()==ID_unsignedbv ||
20 type.id()==ID_signedbv)
21 {
22 // Let's do the special case 2**x
23 bvt base = convert_bv(expr.base());
24 bvt exponent = convert_bv(expr.exponent());
25
27 bv_utils.equal(base, bv_utils.build_constant(2, base.size()));
28
29 bvt one=bv_utils.build_constant(1, width);
30 bvt shift = bv_utils.shift(one, bv_utilst::shiftt::SHIFT_LEFT, exponent);
31
33
34 return bv_utils.select(eq_2, shift, nondet);
35 }
36
37 return conversion_failed(expr);
38}
ait supplies three of the four components needed: an abstract interpreter (in this case handling func...
Definition ai.h:566
virtual const bvt & convert_bv(const exprt &expr, const std::optional< std::size_t > expected_width={})
Convert expression to vector of literalts, using an internal cache to speed up conversion if availabl...
Definition boolbv.cpp:40
virtual bvt convert_power(const power_exprt &expr)
bv_utilst bv_utils
Definition boolbv.h:120
bvt conversion_failed(const exprt &expr)
Print that the expression of x has failed conversion, then return a vector of x's width.
Definition boolbv.cpp:95
virtual std::size_t boolbv_width(const typet &type) const
Definition boolbv.h:105
bvt select(literalt s, const bvt &a, const bvt &b)
If s is true, selects a otherwise selects b.
Definition bv_utils.cpp:97
static bvt build_constant(const mp_integer &i, std::size_t width)
Definition bv_utils.cpp:16
literalt equal(const bvt &op0, const bvt &op1)
Bit-blasting ID_equal and use in other encodings.
static bvt shift(const bvt &op, const shiftt shift, std::size_t distance)
Definition bv_utils.cpp:538
typet & type()
Return the type of the expression.
Definition expr.h:85
const irep_idt & id() const
Definition irep.h:388
Exponentiation.
const exprt & base() const
const exprt & exponent() const
virtual bvt new_variables(std::size_t width)
generates a bitvector of given width with new variables
Definition prop.cpp:30
The type of an expression, extends irept.
Definition type.h:29
std::vector< literalt > bvt
Definition literal.h:201
API to expression classes for 'mathematical' expressions.