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

Constructor & Destructor Documentation

◆ __init__()

__init__ ( self,
entry,
ctx )

Definition at line 6357 of file z3py.py.

6357 def __init__(self, entry, ctx):
6358 self.entry = entry
6359 self.ctx = ctx
6360 Z3_func_entry_inc_ref(self.ctx.ref(), self.entry)
6361
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 6365 of file z3py.py.

6365 def __del__(self):
6366 if self.ctx.ref() is not None and Z3_func_entry_dec_ref is not None:
6367 Z3_func_entry_dec_ref(self.ctx.ref(), self.entry)
6368
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 6362 of file z3py.py.

6362 def __deepcopy__(self, memo={}):
6363 return FuncEntry(self.entry, self.ctx)
6364

◆ __repr__()

__repr__ ( self)

Definition at line 6459 of file z3py.py.

6459 def __repr__(self):
6460 return repr(self.as_list())
6461
6462

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

6387 def arg_value(self, idx):
6388 """Return the value of argument `idx`.
6389
6390 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6391 >>> s = Solver()
6392 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6393 >>> s.check()
6394 sat
6395 >>> m = s.model()
6396 >>> f_i = m[f]
6397 >>> f_i.num_entries()
6398 1
6399 >>> e = f_i.entry(0)
6400 >>> e
6401 [1, 2, 20]
6402 >>> e.num_args()
6403 2
6404 >>> e.arg_value(0)
6405 1
6406 >>> e.arg_value(1)
6407 2
6408 >>> try:
6409 ... e.arg_value(2)
6410 ... except IndexError:
6411 ... print("index error")
6412 index error
6413 """
6414 if idx >= self.num_args():
6415 raise IndexError
6416 return _to_expr_ref(Z3_func_entry_get_arg(self.ctx.ref(), self.entry, idx), self.ctx)
6417
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 6440 of file z3py.py.

6440 def as_list(self):
6441 """Return entry `self` as a Python list.
6442 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6443 >>> s = Solver()
6444 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6445 >>> s.check()
6446 sat
6447 >>> m = s.model()
6448 >>> f_i = m[f]
6449 >>> f_i.num_entries()
6450 1
6451 >>> e = f_i.entry(0)
6452 >>> e.as_list()
6453 [1, 2, 20]
6454 """
6455 args = [self.arg_value(i) for i in range(self.num_args())]
6456 args.append(self.value())
6457 return args
6458

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

6369 def num_args(self):
6370 """Return the number of arguments in the given entry.
6371
6372 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6373 >>> s = Solver()
6374 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6375 >>> s.check()
6376 sat
6377 >>> m = s.model()
6378 >>> f_i = m[f]
6379 >>> f_i.num_entries()
6380 1
6381 >>> e = f_i.entry(0)
6382 >>> e.num_args()
6383 2
6384 """
6385 return int(Z3_func_entry_get_num_args(self.ctx.ref(), self.entry))
6386
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 6418 of file z3py.py.

6418 def value(self):
6419 """Return the value of the function at point `self`.
6420
6421 >>> f = Function('f', IntSort(), IntSort(), IntSort())
6422 >>> s = Solver()
6423 >>> s.add(f(0, 1) == 10, f(1, 2) == 20, f(1, 0) == 10)
6424 >>> s.check()
6425 sat
6426 >>> m = s.model()
6427 >>> f_i = m[f]
6428 >>> f_i.num_entries()
6429 1
6430 >>> e = f_i.entry(0)
6431 >>> e
6432 [1, 2, 20]
6433 >>> e.num_args()
6434 2
6435 >>> e.value()
6436 20
6437 """
6438 return _to_expr_ref(Z3_func_entry_get_value(self.ctx.ref(), self.entry), self.ctx)
6439
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 6358 of file z3py.py.

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