Z3
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Public Member Functions
BitVecNumRef Class Reference
+ Inheritance diagram for BitVecNumRef:

Public Member Functions

def as_long
 
def as_signed_long
 
def as_string
 
- Public Member Functions inherited from BitVecRef
def sort
 
def size
 
def __add__
 
def __radd__
 
def __mul__
 
def __rmul__
 
def __sub__
 
def __rsub__
 
def __or__
 
def __ror__
 
def __and__
 
def __rand__
 
def __xor__
 
def __rxor__
 
def __pos__
 
def __neg__
 
def __invert__
 
def __div__
 
def __truediv__
 
def __rdiv__
 
def __rtruediv__
 
def __mod__
 
def __rmod__
 
def __le__
 
def __lt__
 
def __gt__
 
def __ge__
 
def __rshift__
 
def __lshift__
 
def __rrshift__
 
def __rlshift__
 
- Public Member Functions inherited from ExprRef
def as_ast
 
def get_id
 
def sort
 
def sort_kind
 
def __eq__
 
def __ne__
 
def decl
 
def num_args
 
def arg
 
def children
 
- Public Member Functions inherited from AstRef
def __init__
 
def __del__
 
def __str__
 
def __repr__
 
def sexpr
 
def as_ast
 
def get_id
 
def ctx_ref
 
def eq
 
def translate
 
def hash
 
- Public Member Functions inherited from Z3PPObject
def use_pp
 

Additional Inherited Members

- Data Fields inherited from AstRef
 ast
 
 ctx
 

Detailed Description

Bit-vector values.

Definition at line 3376 of file z3py.py.

Member Function Documentation

def as_long (   self)
Return a Z3 bit-vector numeral as a Python long (bignum) numeral. 

>>> v = BitVecVal(0xbadc0de, 32)
>>> v
195936478
>>> print("0x%.8x" % v.as_long())
0x0badc0de

Definition at line 3379 of file z3py.py.

3380  def as_long(self):
3381  """Return a Z3 bit-vector numeral as a Python long (bignum) numeral.
3382 
3383  >>> v = BitVecVal(0xbadc0de, 32)
3384  >>> v
3385  195936478
3386  >>> print("0x%.8x" % v.as_long())
3387  0x0badc0de
3388  """
3389  return int(self.as_string())
def as_signed_long (   self)
Return a Z3 bit-vector numeral as a Python long (bignum) numeral. The most significant bit is assumed to be the sign.

>>> BitVecVal(4, 3).as_signed_long()
-4
>>> BitVecVal(7, 3).as_signed_long()
-1
>>> BitVecVal(3, 3).as_signed_long()
3
>>> BitVecVal(2**32 - 1, 32).as_signed_long()
-1
>>> BitVecVal(2**64 - 1, 64).as_signed_long()
-1

Definition at line 3390 of file z3py.py.

3391  def as_signed_long(self):
3392  """Return a Z3 bit-vector numeral as a Python long (bignum) numeral. The most significant bit is assumed to be the sign.
3393 
3394  >>> BitVecVal(4, 3).as_signed_long()
3395  -4
3396  >>> BitVecVal(7, 3).as_signed_long()
3397  -1
3398  >>> BitVecVal(3, 3).as_signed_long()
3399  3
3400  >>> BitVecVal(2**32 - 1, 32).as_signed_long()
3401  -1
3402  >>> BitVecVal(2**64 - 1, 64).as_signed_long()
3403  -1
3404  """
3405  sz = self.size()
3406  val = self.as_long()
3407  if val >= 2**(sz - 1):
3408  val = val - 2**sz
3409  if val < -2**(sz - 1):
3410  val = val + 2**sz
3411  return int(val)
def as_signed_long
Definition: z3py.py:3390
def as_string (   self)

Definition at line 3412 of file z3py.py.

Referenced by BitVecNumRef.as_long().

3413  def as_string(self):
3414  return Z3_get_numeral_string(self.ctx_ref(), self.as_ast())
Z3_string Z3_API Z3_get_numeral_string(Z3_context c, Z3_ast a)
Return numeral value, as a string of a numeric constant term.
def as_ast
Definition: z3py.py:296
def ctx_ref
Definition: z3py.py:304