Z3
Public Member Functions | Data Fields
ApplyResult Class Reference
+ Inheritance diagram for ApplyResult:

Public Member Functions

def __init__ (self, result, ctx)
 
def __deepcopy__ (self, memo={})
 
def __del__ (self)
 
def __len__ (self)
 
def __getitem__ (self, idx)
 
def __repr__ (self)
 
def sexpr (self)
 
def as_expr (self)
 
- Public Member Functions inherited from Z3PPObject
def use_pp (self)
 

Data Fields

 result
 
 ctx
 

Detailed Description

An ApplyResult object contains the subgoals produced by a tactic when applied to a goal. It also contains model and proof converters.

Definition at line 7518 of file z3py.py.

Constructor & Destructor Documentation

◆ __init__()

def __init__ (   self,
  result,
  ctx 
)

Definition at line 7521 of file z3py.py.

7521  def __init__(self, result, ctx):
7522  self.result = result
7523  self.ctx = ctx
7524  Z3_apply_result_inc_ref(self.ctx.ref(), self.result)
7525 
void Z3_API Z3_apply_result_inc_ref(Z3_context c, Z3_apply_result r)
Increment the reference counter of the given Z3_apply_result object.

◆ __del__()

def __del__ (   self)

Definition at line 7529 of file z3py.py.

7529  def __del__(self):
7530  if self.ctx.ref() is not None:
7531  Z3_apply_result_dec_ref(self.ctx.ref(), self.result)
7532 
void Z3_API Z3_apply_result_dec_ref(Z3_context c, Z3_apply_result r)
Decrement the reference counter of the given Z3_apply_result object.

Member Function Documentation

◆ __deepcopy__()

def __deepcopy__ (   self,
  memo = {} 
)

Definition at line 7526 of file z3py.py.

7526  def __deepcopy__(self, memo={}):
7527  return ApplyResult(self.result, self.ctx)
7528 

◆ __getitem__()

def __getitem__ (   self,
  idx 
)
Return one of the subgoals stored in ApplyResult object `self`.

>>> a, b = Ints('a b')
>>> g = Goal()
>>> g.add(Or(a == 0, a == 1), Or(b == 0, b == 1), a > b)
>>> t = Tactic('split-clause')
>>> r = t(g)
>>> r[0]
[a == 0, Or(b == 0, b == 1), a > b]
>>> r[1]
[a == 1, Or(b == 0, b == 1), a > b]

Definition at line 7552 of file z3py.py.

7552  def __getitem__(self, idx):
7553  """Return one of the subgoals stored in ApplyResult object `self`.
7554 
7555  >>> a, b = Ints('a b')
7556  >>> g = Goal()
7557  >>> g.add(Or(a == 0, a == 1), Or(b == 0, b == 1), a > b)
7558  >>> t = Tactic('split-clause')
7559  >>> r = t(g)
7560  >>> r[0]
7561  [a == 0, Or(b == 0, b == 1), a > b]
7562  >>> r[1]
7563  [a == 1, Or(b == 0, b == 1), a > b]
7564  """
7565  if idx >= len(self):
7566  raise IndexError
7567  return Goal(goal=Z3_apply_result_get_subgoal(self.ctx.ref(), self.result, idx), ctx=self.ctx)
7568 
Z3_goal Z3_API Z3_apply_result_get_subgoal(Z3_context c, Z3_apply_result r, unsigned i)
Return one of the subgoals in the Z3_apply_result object returned by Z3_tactic_apply.

◆ __len__()

def __len__ (   self)
Return the number of subgoals in `self`.

>>> a, b = Ints('a b')
>>> g = Goal()
>>> g.add(Or(a == 0, a == 1), Or(b == 0, b == 1), a > b)
>>> t = Tactic('split-clause')
>>> r = t(g)
>>> len(r)
2
>>> t = Then(Tactic('split-clause'), Tactic('split-clause'))
>>> len(t(g))
4
>>> t = Then(Tactic('split-clause'), Tactic('split-clause'), Tactic('propagate-values'))
>>> len(t(g))
1

Definition at line 7533 of file z3py.py.

7533  def __len__(self):
7534  """Return the number of subgoals in `self`.
7535 
7536  >>> a, b = Ints('a b')
7537  >>> g = Goal()
7538  >>> g.add(Or(a == 0, a == 1), Or(b == 0, b == 1), a > b)
7539  >>> t = Tactic('split-clause')
7540  >>> r = t(g)
7541  >>> len(r)
7542  2
7543  >>> t = Then(Tactic('split-clause'), Tactic('split-clause'))
7544  >>> len(t(g))
7545  4
7546  >>> t = Then(Tactic('split-clause'), Tactic('split-clause'), Tactic('propagate-values'))
7547  >>> len(t(g))
7548  1
7549  """
7550  return int(Z3_apply_result_get_num_subgoals(self.ctx.ref(), self.result))
7551 
unsigned Z3_API Z3_apply_result_get_num_subgoals(Z3_context c, Z3_apply_result r)
Return the number of subgoals in the Z3_apply_result object returned by Z3_tactic_apply.

◆ __repr__()

def __repr__ (   self)

Definition at line 7569 of file z3py.py.

7569  def __repr__(self):
7570  return obj_to_string(self)
7571 

◆ as_expr()

def as_expr (   self)
Return a Z3 expression consisting of all subgoals.

>>> x = Int('x')
>>> g = Goal()
>>> g.add(x > 1)
>>> g.add(Or(x == 2, x == 3))
>>> r = Tactic('simplify')(g)
>>> r
[[Not(x <= 1), Or(x == 2, x == 3)]]
>>> r.as_expr()
And(Not(x <= 1), Or(x == 2, x == 3))
>>> r = Tactic('split-clause')(g)
>>> r
[[x > 1, x == 2], [x > 1, x == 3]]
>>> r.as_expr()
Or(And(x > 1, x == 2), And(x > 1, x == 3))

Definition at line 7577 of file z3py.py.

7577  def as_expr(self):
7578  """Return a Z3 expression consisting of all subgoals.
7579 
7580  >>> x = Int('x')
7581  >>> g = Goal()
7582  >>> g.add(x > 1)
7583  >>> g.add(Or(x == 2, x == 3))
7584  >>> r = Tactic('simplify')(g)
7585  >>> r
7586  [[Not(x <= 1), Or(x == 2, x == 3)]]
7587  >>> r.as_expr()
7588  And(Not(x <= 1), Or(x == 2, x == 3))
7589  >>> r = Tactic('split-clause')(g)
7590  >>> r
7591  [[x > 1, x == 2], [x > 1, x == 3]]
7592  >>> r.as_expr()
7593  Or(And(x > 1, x == 2), And(x > 1, x == 3))
7594  """
7595  sz = len(self)
7596  if sz == 0:
7597  return BoolVal(False, self.ctx)
7598  elif sz == 1:
7599  return self[0].as_expr()
7600  else:
7601  return Or([ self[i].as_expr() for i in range(len(self)) ])
7602 
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:3358
def Or(args)
Definition: z3py.py:1705
def BoolVal(val, ctx=None)
Definition: z3py.py:1540

◆ sexpr()

def sexpr (   self)
Return a textual representation of the s-expression representing the set of subgoals in `self`.

Definition at line 7572 of file z3py.py.

7572  def sexpr(self):
7573  """Return a textual representation of the s-expression representing the set of subgoals in `self`."""
7574  return Z3_apply_result_to_string(self.ctx.ref(), self.result)
7575 
7576 
Z3_string Z3_API Z3_apply_result_to_string(Z3_context c, Z3_apply_result r)
Convert the Z3_apply_result object returned by Z3_tactic_apply into a string.

Field Documentation

◆ ctx

ctx

◆ result

result