Nikolaj Bjørner and Mikoláš Janota
Microsoft Research
nbjorner@microsoft.com, mikolas.janota@gmail.com |
def sign(M,a): if M(a) return a else return
a
def level(j,a): return max level of bound variable in atom a of parity j
def strategy(M,j): return data:image/s3,"s3://crabby-images/97edc/97edcba75253be0a6321c5c37d4736958a64dfab" alt="$\bigwedge_{M \neq null, a \in Atoms, level(j, a) < j} sign(M,a) $"
def tailv(j): return data:image/s3,"s3://crabby-images/2bdce/2bdcebdec2dd2131d8a795cebf3525a0cd26d4fc" alt="$x_{j-1},x_j,x_{j+1},\ldots$"
j = 1
M = null
while True:
if
strategy(M, j) is unsat:
if j == 1:
return F is unsat
if j == 2:
return F is sat
C = Core(
, strategy(M, j))
J = Mbp(tailv(j), C)
j = index of max variable in J
of same parity as j
=
J
M = null
else:
M = current model
j = j + 1
Note: core for is implicant of
.
Extends to Quantifier Elimination.
Enumerate literals that imply
by tracking clauses asserted at level 2.
Our base strategy uses limited look-ahead.
It is possible to formulate stronger strategies (based on models)
|
|