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

10126 def as_string(self):
10127 s = Z3_get_numeral_string(self.ctx.ref(), self.as_ast())
10128 return ("FPVal(%s, %s)" % (s, self.sort()))
10129
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 10059 of file z3py.py.

10059 def exponent(self, biased=True):
10060 return Z3_fpa_get_numeral_exponent_string(self.ctx.ref(), self.as_ast(), biased)
10061
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 10080 of file z3py.py.

10080 def exponent_as_bv(self, biased=True):
10081 return BitVecNumRef(Z3_fpa_get_numeral_exponent_bv(self.ctx.ref(), self.as_ast(), biased), self.ctx)
10082
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 10069 of file z3py.py.

10069 def exponent_as_long(self, biased=True):
10070 ptr = (ctypes.c_longlong * 1)()
10071 if not Z3_fpa_get_numeral_exponent_int64(self.ctx.ref(), self.as_ast(), ptr, biased):
10072 raise Z3Exception("error retrieving the exponent of a numeral.")
10073 return ptr[0]
10074
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 10090 of file z3py.py.

10090 def isInf(self):
10091 return Z3_fpa_is_numeral_inf(self.ctx.ref(), self.as_ast())
10092
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 10085 of file z3py.py.

10085 def isNaN(self):
10086 return Z3_fpa_is_numeral_nan(self.ctx.ref(), self.as_ast())
10087
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 10115 of file z3py.py.

10115 def isNegative(self):
10116 return Z3_fpa_is_numeral_negative(self.ctx.ref(), self.as_ast())
10117
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 10100 of file z3py.py.

10100 def isNormal(self):
10101 return Z3_fpa_is_numeral_normal(self.ctx.ref(), self.as_ast())
10102
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 10110 of file z3py.py.

10110 def isPositive(self):
10111 return Z3_fpa_is_numeral_positive(self.ctx.ref(), self.as_ast())
10112
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 10105 of file z3py.py.

10105 def isSubnormal(self):
10106 return Z3_fpa_is_numeral_subnormal(self.ctx.ref(), self.as_ast())
10107
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 10095 of file z3py.py.

10095 def isZero(self):
10096 return Z3_fpa_is_numeral_zero(self.ctx.ref(), self.as_ast())
10097
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 10130 of file z3py.py.

10130 def py_value(self):
10131 bv = simplify(fpToIEEEBV(self))
10132 binary = bv.py_value()
10133 if not isinstance(binary, int):
10134 return None
10135 # Decode the IEEE 754 binary representation
10136 import struct
10137 bytes_rep = binary.to_bytes(8, byteorder='big')
10138 return struct.unpack('>d', bytes_rep)[0]
10139
10140

◆ sign()

sign ( self)

Definition at line 10006 of file z3py.py.

10006 def sign(self):
10007 num = (ctypes.c_int)()
10008 nsign = Z3_fpa_get_numeral_sign(self.ctx.ref(), self.as_ast(), byref(num))
10009 if nsign is False:
10010 raise Z3Exception("error retrieving the sign of a numeral.")
10011 return num.value != 0
10012
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 10018 of file z3py.py.

10018 def sign_as_bv(self):
10019 return BitVecNumRef(Z3_fpa_get_numeral_sign_bv(self.ctx.ref(), self.as_ast()), self.ctx)
10020
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 10028 of file z3py.py.

10028 def significand(self):
10029 return Z3_fpa_get_numeral_significand_string(self.ctx.ref(), self.as_ast())
10030
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 10049 of file z3py.py.

10049 def significand_as_bv(self):
10050 return BitVecNumRef(Z3_fpa_get_numeral_significand_bv(self.ctx.ref(), self.as_ast()), self.ctx)
10051
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 10038 of file z3py.py.

10038 def significand_as_long(self):
10039 ptr = (ctypes.c_ulonglong * 1)()
10040 if not Z3_fpa_get_numeral_significand_uint64(self.ctx.ref(), self.as_ast(), ptr):
10041 raise Z3Exception("error retrieving the significand of a numeral.")
10042 return ptr[0]
10043
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.