Z3
Public Member Functions
FPNumRef Class Reference

FP Numerals. More...

+ Inheritance diagram for FPNumRef:

Public Member Functions

def sign (self)
 
def sign_as_bv (self)
 
def significand (self)
 
def significand_as_long (self)
 
def significand_as_bv (self)
 
def exponent (self, biased=True)
 
def exponent_as_long (self, biased=True)
 
def exponent_as_bv (self, biased=True)
 
def isNaN (self)
 
def isInf (self)
 
def isZero (self)
 
def isNormal (self)
 
def isSubnormal (self)
 
def isPositive (self)
 
def isNegative (self)
 
def as_string (self)
 
- Public Member Functions inherited from FPRef
def sort (self)
 
def ebits (self)
 
def sbits (self)
 
def __le__ (self, other)
 
def __lt__ (self, other)
 
def __ge__ (self, other)
 
def __gt__ (self, other)
 
def __add__ (self, other)
 
def __radd__ (self, other)
 
def __sub__ (self, other)
 
def __rsub__ (self, other)
 
def __mul__ (self, other)
 
def __rmul__ (self, other)
 
def __pos__ (self)
 
def __neg__ (self)
 
def __div__ (self, other)
 
def __rdiv__ (self, other)
 
def __truediv__ (self, other)
 
def __rtruediv__ (self, other)
 
def __mod__ (self, other)
 
def __rmod__ (self, other)
 
- Public Member Functions inherited from ExprRef
def as_ast (self)
 
def get_id (self)
 
def sort_kind (self)
 
def __eq__ (self, other)
 
def __hash__ (self)
 
def __ne__ (self, other)
 
def params (self)
 
def decl (self)
 
def num_args (self)
 
def arg (self, idx)
 
def children (self)
 
- Public Member Functions inherited from AstRef
def __init__ (self, ast, ctx=None)
 
def __del__ (self)
 
def __deepcopy__ (self, memo={})
 
def __str__ (self)
 
def __repr__ (self)
 
def __nonzero__ (self)
 
def __bool__ (self)
 
def sexpr (self)
 
def ctx_ref (self)
 
def eq (self, other)
 
def translate (self, target)
 
def __copy__ (self)
 
def hash (self)
 
- Public Member Functions inherited from Z3PPObject
def use_pp (self)
 

Additional Inherited Members

- Data Fields inherited from AstRef
 ast
 
 ctx
 

Detailed Description

FP Numerals.

The sign of the numeral.

>>> x = FPVal(+1.0, FPSort(8, 24))
>>> x.sign()
False
>>> x = FPVal(-1.0, FPSort(8, 24))
>>> x.sign()
True

Definition at line 8937 of file z3py.py.

Member Function Documentation

◆ as_string()

def as_string (   self)
Return a Z3 floating point expression as a Python string.

Reimplemented from FPRef.

Definition at line 9051 of file z3py.py.

9051  def as_string(self):
9052  s = Z3_get_numeral_string(self.ctx.ref(), self.as_ast())
9053  return ("FPVal(%s, %s)" % (s, self.sort()))
9054 
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.

◆ exponent()

def exponent (   self,
  biased = True 
)

Definition at line 8994 of file z3py.py.

8994  def exponent(self, biased=True):
8995  return Z3_fpa_get_numeral_exponent_string(self.ctx.ref(), self.as_ast(), biased)
8996 
Z3_string Z3_API Z3_fpa_get_numeral_exponent_string(Z3_context c, Z3_ast t, bool biased)
Return the exponent value of a floating-point numeral as a string.

◆ exponent_as_bv()

def exponent_as_bv (   self,
  biased = True 
)

Definition at line 9013 of file z3py.py.

9013  def exponent_as_bv(self, biased=True):
9014  return BitVecNumRef(Z3_fpa_get_numeral_exponent_bv(self.ctx.ref(), self.as_ast(), biased), self.ctx)
9015 
Z3_ast Z3_API Z3_fpa_get_numeral_exponent_bv(Z3_context c, Z3_ast t, bool biased)
Retrieves the exponent of a floating-point literal as a bit-vector expression.

◆ exponent_as_long()

def exponent_as_long (   self,
  biased = True 
)

Definition at line 9003 of file z3py.py.

9003  def exponent_as_long(self, biased=True):
9004  ptr = (ctypes.c_longlong * 1)()
9005  if not Z3_fpa_get_numeral_exponent_int64(self.ctx.ref(), self.as_ast(), ptr, biased):
9006  raise Z3Exception("error retrieving the exponent of a numeral.")
9007  return ptr[0]
9008 
bool Z3_API Z3_fpa_get_numeral_exponent_int64(Z3_context c, Z3_ast t, int64_t *n, bool biased)
Return the exponent value of a floating-point numeral as a signed 64-bit integer.

◆ isInf()

def isInf (   self)

Definition at line 9021 of file z3py.py.

9021  def isInf(self):
9022  return Z3_fpa_is_numeral_inf(self.ctx.ref(), self.as_ast())
9023 
bool Z3_API Z3_fpa_is_numeral_inf(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is a +oo or -oo.

◆ isNaN()

def isNaN (   self)

Definition at line 9017 of file z3py.py.

9017  def isNaN(self):
9018  return Z3_fpa_is_numeral_nan(self.ctx.ref(), self.as_ast())
9019 
bool Z3_API Z3_fpa_is_numeral_nan(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is a NaN.

◆ isNegative()

def isNegative (   self)

Definition at line 9041 of file z3py.py.

9041  def isNegative(self):
9042  return Z3_fpa_is_numeral_negative(self.ctx.ref(), self.as_ast())
9043 
bool Z3_API Z3_fpa_is_numeral_negative(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is negative.

◆ isNormal()

def isNormal (   self)

Definition at line 9029 of file z3py.py.

9029  def isNormal(self):
9030  return Z3_fpa_is_numeral_normal(self.ctx.ref(), self.as_ast())
9031 
bool Z3_API Z3_fpa_is_numeral_normal(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is normal.

◆ isPositive()

def isPositive (   self)

Definition at line 9037 of file z3py.py.

9037  def isPositive(self):
9038  return Z3_fpa_is_numeral_positive(self.ctx.ref(), self.as_ast())
9039 
bool Z3_API Z3_fpa_is_numeral_positive(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is positive.

◆ isSubnormal()

def isSubnormal (   self)

Definition at line 9033 of file z3py.py.

9033  def isSubnormal(self):
9034  return Z3_fpa_is_numeral_subnormal(self.ctx.ref(), self.as_ast())
9035 
bool Z3_API Z3_fpa_is_numeral_subnormal(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is subnormal.

◆ isZero()

def isZero (   self)

Definition at line 9025 of file z3py.py.

9025  def isZero(self):
9026  return Z3_fpa_is_numeral_zero(self.ctx.ref(), self.as_ast())
9027 
bool Z3_API Z3_fpa_is_numeral_zero(Z3_context c, Z3_ast t)
Checks whether a given floating-point numeral is +zero or -zero.

◆ sign()

def sign (   self)

Definition at line 8947 of file z3py.py.

8947  def sign(self):
8948  l = (ctypes.c_int)()
8949  if Z3_fpa_get_numeral_sign(self.ctx.ref(), self.as_ast(), byref(l)) == False:
8950  raise Z3Exception("error retrieving the sign of a numeral.")
8951  return l.value != 0
8952 
bool Z3_API Z3_fpa_get_numeral_sign(Z3_context c, Z3_ast t, int *sgn)
Retrieves the sign of a floating-point literal.

◆ sign_as_bv()

def sign_as_bv (   self)

Definition at line 8957 of file z3py.py.

8957  def sign_as_bv(self):
8958  return BitVecNumRef(Z3_fpa_get_numeral_sign_bv(self.ctx.ref(), self.as_ast()), self.ctx)
8959 
Z3_ast Z3_API Z3_fpa_get_numeral_sign_bv(Z3_context c, Z3_ast t)
Retrieves the sign of a floating-point literal as a bit-vector expression.

◆ significand()

def significand (   self)

Definition at line 8966 of file z3py.py.

8966  def significand(self):
8967  return Z3_fpa_get_numeral_significand_string(self.ctx.ref(), self.as_ast())
8968 
Z3_string Z3_API Z3_fpa_get_numeral_significand_string(Z3_context c, Z3_ast t)
Return the significand value of a floating-point numeral as a string.

◆ significand_as_bv()

def significand_as_bv (   self)

Definition at line 8985 of file z3py.py.

8985  def significand_as_bv(self):
8986  return BitVecNumRef(Z3_fpa_get_numeral_significand_bv(self.ctx.ref(), self.as_ast()), self.ctx)
8987 
Z3_ast Z3_API Z3_fpa_get_numeral_significand_bv(Z3_context c, Z3_ast t)
Retrieves the significand of a floating-point literal as a bit-vector expression.

◆ significand_as_long()

def significand_as_long (   self)

Definition at line 8975 of file z3py.py.

8975  def significand_as_long(self):
8976  ptr = (ctypes.c_ulonglong * 1)()
8977  if not Z3_fpa_get_numeral_significand_uint64(self.ctx.ref(), self.as_ast(), ptr):
8978  raise Z3Exception("error retrieving the significand of a numeral.")
8979  return ptr[0]
8980 
bool Z3_API Z3_fpa_get_numeral_significand_uint64(Z3_context c, Z3_ast t, uint64_t *n)
Return the significand value of a floating-point numeral as a uint64.