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

10102 def as_string(self):
10103 s = Z3_get_numeral_string(self.ctx.ref(), self.as_ast())
10104 return ("FPVal(%s, %s)" % (s, self.sort()))
10105
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 10035 of file z3py.py.

10035 def exponent(self, biased=True):
10036 return Z3_fpa_get_numeral_exponent_string(self.ctx.ref(), self.as_ast(), biased)
10037
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 10056 of file z3py.py.

10056 def exponent_as_bv(self, biased=True):
10057 return BitVecNumRef(Z3_fpa_get_numeral_exponent_bv(self.ctx.ref(), self.as_ast(), biased), self.ctx)
10058
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 10045 of file z3py.py.

10045 def exponent_as_long(self, biased=True):
10046 ptr = (ctypes.c_longlong * 1)()
10047 if not Z3_fpa_get_numeral_exponent_int64(self.ctx.ref(), self.as_ast(), ptr, biased):
10048 raise Z3Exception("error retrieving the exponent of a numeral.")
10049 return ptr[0]
10050
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 10066 of file z3py.py.

10066 def isInf(self):
10067 return Z3_fpa_is_numeral_inf(self.ctx.ref(), self.as_ast())
10068
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 10061 of file z3py.py.

10061 def isNaN(self):
10062 return Z3_fpa_is_numeral_nan(self.ctx.ref(), self.as_ast())
10063
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 10091 of file z3py.py.

10091 def isNegative(self):
10092 return Z3_fpa_is_numeral_negative(self.ctx.ref(), self.as_ast())
10093
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 10076 of file z3py.py.

10076 def isNormal(self):
10077 return Z3_fpa_is_numeral_normal(self.ctx.ref(), self.as_ast())
10078
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 10086 of file z3py.py.

10086 def isPositive(self):
10087 return Z3_fpa_is_numeral_positive(self.ctx.ref(), self.as_ast())
10088
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 10081 of file z3py.py.

10081 def isSubnormal(self):
10082 return Z3_fpa_is_numeral_subnormal(self.ctx.ref(), self.as_ast())
10083
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 10071 of file z3py.py.

10071 def isZero(self):
10072 return Z3_fpa_is_numeral_zero(self.ctx.ref(), self.as_ast())
10073
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 10106 of file z3py.py.

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

◆ sign()

sign ( self)

Definition at line 9982 of file z3py.py.

9982 def sign(self):
9983 num = (ctypes.c_int)()
9984 nsign = Z3_fpa_get_numeral_sign(self.ctx.ref(), self.as_ast(), byref(num))
9985 if nsign is False:
9986 raise Z3Exception("error retrieving the sign of a numeral.")
9987 return num.value != 0
9988
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 9994 of file z3py.py.

9994 def sign_as_bv(self):
9995 return BitVecNumRef(Z3_fpa_get_numeral_sign_bv(self.ctx.ref(), self.as_ast()), self.ctx)
9996
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 10004 of file z3py.py.

10004 def significand(self):
10005 return Z3_fpa_get_numeral_significand_string(self.ctx.ref(), self.as_ast())
10006
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 10025 of file z3py.py.

10025 def significand_as_bv(self):
10026 return BitVecNumRef(Z3_fpa_get_numeral_significand_bv(self.ctx.ref(), self.as_ast()), self.ctx)
10027
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 10014 of file z3py.py.

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