3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2026-03-02 03:36:53 +00:00

expose a status flag for clauses but every single one is being coded as an assumption...

This commit is contained in:
Ilana Shapiro 2025-10-20 20:04:12 -07:00
parent f520e6875b
commit 43197f52d8
10 changed files with 39 additions and 24 deletions

View file

@ -1,9 +1,15 @@
import os
from more_itertools import iterate
from z3 import *
from multiprocessing import Process
import math, random
import sys, os
sys.path.insert(0, os.path.abspath("build/python"))
os.environ["Z3_LIBRARY_PATH"] = os.path.abspath("build")
# import z3
# print("Using z3 from:", z3.__file__)
from z3 import *
MAX_CONFLICTS = 100
MAX_EXAMPLES = 5
bench_dir = "../z3-poly-testing/inputs/QF_NIA_small"
@ -68,7 +74,8 @@ def stats_tuple(st):
def run_prefix_step(S, K, clause_limit):
clauses = []
def on_clause(premises, deps, clause):
def on_clause(premises, deps, clause, status):
print(f" [OnClause] collected clause status: {status}, clause: {clause}")
if len(clauses) < clause_limit:
clauses.append(clause)
@ -87,10 +94,7 @@ def replay_prefix_on_pps(PPS_solver, clauses, param_state, budget):
# For each learned clause Cj = [l1, l2, ...], check ¬(l1 l2 ...)
for idx, Cj in enumerate(clauses):
if isinstance(Cj, AstVector):
lits = [Cj[i].translate(PPS_solver.ctx) for i in range(len(Cj))]
else:
lits = [l.translate(PPS_solver.ctx) for l in Cj]
lits = [l.translate(PPS_solver.ctx) for l in Cj]
negated_lits = []
for l in lits: