Z3
Loading...
Searching...
No Matches
FPNumRef Class Reference
Inheritance diagram for FPNumRef:

Public Member Functions

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

Additional Inherited Members

Data Fields inherited from AstRef
 ast = ast
 ctx = _get_ctx(ctx)
Protected Member Functions inherited from Z3PPObject
 _repr_html_ (self)

Detailed Description

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 9966 of file z3py.py.

Member Function Documentation

◆ as_string()

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

Reimplemented from FPRef.

Definition at line 10097 of file z3py.py.

10097 def as_string(self):
10098 s = Z3_get_numeral_string(self.ctx.ref(), self.as_ast())
10099 return ("FPVal(%s, %s)" % (s, self.sort()))
10100
Z3_string Z3_API Z3_get_numeral_string(Z3_context c, Z3_ast a)
Return numeral value, as a decimal string of a numeric constant term.

◆ exponent()

exponent ( self,
biased = True )

Definition at line 10030 of file z3py.py.

10030 def exponent(self, biased=True):
10031 return Z3_fpa_get_numeral_exponent_string(self.ctx.ref(), self.as_ast(), biased)
10032
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()

exponent_as_bv ( self,
biased = True )

Definition at line 10051 of file z3py.py.

10051 def exponent_as_bv(self, biased=True):
10052 return BitVecNumRef(Z3_fpa_get_numeral_exponent_bv(self.ctx.ref(), self.as_ast(), biased), self.ctx)
10053
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()

exponent_as_long ( self,
biased = True )

Definition at line 10040 of file z3py.py.

10040 def exponent_as_long(self, biased=True):
10041 ptr = (ctypes.c_longlong * 1)()
10042 if not Z3_fpa_get_numeral_exponent_int64(self.ctx.ref(), self.as_ast(), ptr, biased):
10043 raise Z3Exception("error retrieving the exponent of a numeral.")
10044 return ptr[0]
10045
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()

isInf ( self)

Definition at line 10061 of file z3py.py.

10061 def isInf(self):
10062 return Z3_fpa_is_numeral_inf(self.ctx.ref(), self.as_ast())
10063
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()

isNaN ( self)

Definition at line 10056 of file z3py.py.

10056 def isNaN(self):
10057 return Z3_fpa_is_numeral_nan(self.ctx.ref(), self.as_ast())
10058
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()

isNegative ( self)

Definition at line 10086 of file z3py.py.

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

◆ isNormal()

isNormal ( self)

Definition at line 10071 of file z3py.py.

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

◆ isPositive()

isPositive ( self)

Definition at line 10081 of file z3py.py.

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

◆ isSubnormal()

isSubnormal ( self)

Definition at line 10076 of file z3py.py.

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

◆ isZero()

isZero ( self)

Definition at line 10066 of file z3py.py.

10066 def isZero(self):
10067 return Z3_fpa_is_numeral_zero(self.ctx.ref(), self.as_ast())
10068
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.

◆ py_value()

py_value ( self)
Return a Python value that is equivalent to `self`.

Reimplemented from AstRef.

Definition at line 10101 of file z3py.py.

10101 def py_value(self):
10102 bv = simplify(fpToIEEEBV(self))
10103 binary = bv.py_value()
10104 if not isinstance(binary, int):
10105 return None
10106 # Decode the IEEE 754 binary representation
10107 import struct
10108 bytes_rep = binary.to_bytes(8, byteorder='big')
10109 return struct.unpack('>d', bytes_rep)[0]
10110
10111

◆ sign()

sign ( self)

Definition at line 9977 of file z3py.py.

9977 def sign(self):
9978 num = (ctypes.c_int)()
9979 nsign = Z3_fpa_get_numeral_sign(self.ctx.ref(), self.as_ast(), byref(num))
9980 if nsign is False:
9981 raise Z3Exception("error retrieving the sign of a numeral.")
9982 return num.value != 0
9983
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()

sign_as_bv ( self)

Definition at line 9989 of file z3py.py.

9989 def sign_as_bv(self):
9990 return BitVecNumRef(Z3_fpa_get_numeral_sign_bv(self.ctx.ref(), self.as_ast()), self.ctx)
9991
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()

significand ( self)

Definition at line 9999 of file z3py.py.

9999 def significand(self):
10000 return Z3_fpa_get_numeral_significand_string(self.ctx.ref(), self.as_ast())
10001
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()

significand_as_bv ( self)

Definition at line 10020 of file z3py.py.

10020 def significand_as_bv(self):
10021 return BitVecNumRef(Z3_fpa_get_numeral_significand_bv(self.ctx.ref(), self.as_ast()), self.ctx)
10022
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()

significand_as_long ( self)

Definition at line 10009 of file z3py.py.

10009 def significand_as_long(self):
10010 ptr = (ctypes.c_ulonglong * 1)()
10011 if not Z3_fpa_get_numeral_significand_uint64(self.ctx.ref(), self.as_ast(), ptr):
10012 raise Z3Exception("error retrieving the significand of a numeral.")
10013 return ptr[0]
10014
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.