Z3
Loading...
Searching...
No Matches
FuncEntry Class Reference

Public Member Functions

 __init__ (self, entry, ctx)
 __deepcopy__ (self, memo={})
 __del__ (self)
 num_args (self)
 arg_value (self, idx)
 value (self)
 as_list (self)
 __repr__ (self)

Data Fields

 entry = entry
 ctx = ctx

Detailed Description

Store the value of the interpretation of a function in a particular point.

Definition at line 6259 of file z3py.py.

Constructor & Destructor Documentation

◆ __init__()

__init__ ( self,
entry,
ctx )

Definition at line 6262 of file z3py.py.

6262 def __init__(self, entry, ctx):
6263 self.entry = entry
6264 self.ctx = ctx
6265 Z3_func_entry_inc_ref(self.ctx.ref(), self.entry)
6266
void Z3_API Z3_func_entry_inc_ref(Z3_context c, Z3_func_entry e)
Increment the reference counter of the given Z3_func_entry object.

◆ __del__()

__del__ ( self)

Definition at line 6270 of file z3py.py.

6270 def __del__(self):
6271 if self.ctx.ref() is not None and Z3_func_entry_dec_ref is not None:
6272 Z3_func_entry_dec_ref(self.ctx.ref(), self.entry)
6273
void Z3_API Z3_func_entry_dec_ref(Z3_context c, Z3_func_entry e)
Decrement the reference counter of the given Z3_func_entry object.

Member Function Documentation

◆ __deepcopy__()

__deepcopy__ ( self,
memo = {} )

Definition at line 6267 of file z3py.py.

6267 def __deepcopy__(self, memo={}):
6268 return FuncEntry(self.entry, self.ctx)
6269

◆ __repr__()

__repr__ ( self)

Definition at line 6364 of file z3py.py.

6364 def __repr__(self):
6365 return repr(self.as_list())
6366
6367

◆ arg_value()

arg_value ( self,
idx )
Return the value of argument `idx`.

>>> f = Function('f', IntSort(), IntSort(), IntSort())
>>> s = Solver()
>>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
>>> s.check()
sat
>>> m = s.model()
>>> f_i = m[f]
>>> f_i.num_entries()
1
>>> e = f_i.entry(0)
>>> e
[1, 2, 20]
>>> e.num_args()
2
>>> e.arg_value(0)
1
>>> e.arg_value(1)
2
>>> try:
...   e.arg_value(2)
... except IndexError:
...   print("index error")
index error

Definition at line 6292 of file z3py.py.

6292 def arg_value(self, idx):
6293 """Return the value of argument `idx`.
6294
6295 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6296 >>> s = Solver()
6297 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6298 >>> s.check()
6299 sat
6300 >>> m = s.model()
6301 >>> f_i = m[f]
6302 >>> f_i.num_entries()
6303 1
6304 >>> e = f_i.entry(0)
6305 >>> e
6306 [1, 2, 20]
6307 >>> e.num_args()
6308 2
6309 >>> e.arg_value(0)
6310 1
6311 >>> e.arg_value(1)
6312 2
6313 >>> try:
6314 ... e.arg_value(2)
6315 ... except IndexError:
6316 ... print("index error")
6317 index error
6318 """
6319 if idx >= self.num_args():
6320 raise IndexError
6321 return _to_expr_ref(Z3_func_entry_get_arg(self.ctx.ref(), self.entry, idx), self.ctx)
6322
Z3_ast Z3_API Z3_func_entry_get_arg(Z3_context c, Z3_func_entry e, unsigned i)
Return an argument of a Z3_func_entry object.

Referenced by as_list().

◆ as_list()

as_list ( self)
Return entry `self` as a Python list.
>>> f = Function('f', IntSort(), IntSort(), IntSort())
>>> s = Solver()
>>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
>>> s.check()
sat
>>> m = s.model()
>>> f_i = m[f]
>>> f_i.num_entries()
1
>>> e = f_i.entry(0)
>>> e.as_list()
[1, 2, 20]

Definition at line 6345 of file z3py.py.

6345 def as_list(self):
6346 """Return entry `self` as a Python list.
6347 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6348 >>> s = Solver()
6349 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6350 >>> s.check()
6351 sat
6352 >>> m = s.model()
6353 >>> f_i = m[f]
6354 >>> f_i.num_entries()
6355 1
6356 >>> e = f_i.entry(0)
6357 >>> e.as_list()
6358 [1, 2, 20]
6359 """
6360 args = [self.arg_value(i) for i in range(self.num_args())]
6361 args.append(self.value())
6362 return args
6363

Referenced by __repr__().

◆ num_args()

num_args ( self)
Return the number of arguments in the given entry.

>>> f = Function('f', IntSort(), IntSort(), IntSort())
>>> s = Solver()
>>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
>>> s.check()
sat
>>> m = s.model()
>>> f_i = m[f]
>>> f_i.num_entries()
1
>>> e = f_i.entry(0)
>>> e.num_args()
2

Definition at line 6274 of file z3py.py.

6274 def num_args(self):
6275 """Return the number of arguments in the given entry.
6276
6277 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6278 >>> s = Solver()
6279 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6280 >>> s.check()
6281 sat
6282 >>> m = s.model()
6283 >>> f_i = m[f]
6284 >>> f_i.num_entries()
6285 1
6286 >>> e = f_i.entry(0)
6287 >>> e.num_args()
6288 2
6289 """
6290 return int(Z3_func_entry_get_num_args(self.ctx.ref(), self.entry))
6291
unsigned Z3_API Z3_func_entry_get_num_args(Z3_context c, Z3_func_entry e)
Return the number of arguments in a Z3_func_entry object.

Referenced by AstRef.__bool__(), arg_value(), and as_list().

◆ value()

value ( self)
Return the value of the function at point `self`.

>>> f = Function('f', IntSort(), IntSort(), IntSort())
>>> s = Solver()
>>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
>>> s.check()
sat
>>> m = s.model()
>>> f_i = m[f]
>>> f_i.num_entries()
1
>>> e = f_i.entry(0)
>>> e
[1, 2, 20]
>>> e.num_args()
2
>>> e.value()
20

Definition at line 6323 of file z3py.py.

6323 def value(self):
6324 """Return the value of the function at point `self`.
6325
6326 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6327 >>> s = Solver()
6328 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6329 >>> s.check()
6330 sat
6331 >>> m = s.model()
6332 >>> f_i = m[f]
6333 >>> f_i.num_entries()
6334 1
6335 >>> e = f_i.entry(0)
6336 >>> e
6337 [1, 2, 20]
6338 >>> e.num_args()
6339 2
6340 >>> e.value()
6341 20
6342 """
6343 return _to_expr_ref(Z3_func_entry_get_value(self.ctx.ref(), self.entry), self.ctx)
6344
Z3_ast Z3_API Z3_func_entry_get_value(Z3_context c, Z3_func_entry e)
Return the value of this point.

Referenced by as_list().

Field Documentation

◆ ctx

◆ entry

entry = entry

Definition at line 6263 of file z3py.py.

Referenced by __deepcopy__(), __del__(), arg_value(), FuncInterp.as_list(), num_args(), and value().