mirror of
https://github.com/Z3Prover/z3
synced 2025-04-30 04:15:51 +00:00
wip - updates to proof logging and self-checking
move self-checking functionality to inside sat/smt so it can be used on-line and not just off-line. when self-validation fails, use vs, not clause, to check. It allows self-validation without checking and maintaining RUP validation. new options sat.smt.proof.check_rup, sat.smt.proof.check for online validation. z3 sat.smt.proof.check=true sat.euf=true /v:1 sat.smt.proof.check_rup=true /st file.smt2 sat.smt.proof=p.smt2
This commit is contained in:
parent
993ff40826
commit
ac1552d194
40 changed files with 539 additions and 419 deletions
|
@ -722,7 +722,8 @@ namespace pb {
|
|||
auto* ext = sat::constraint_base::to_extension(cindex);
|
||||
if (ext != this) {
|
||||
m_lemma.reset();
|
||||
ext->get_antecedents(consequent, idx, m_lemma, false);
|
||||
sat::proof_hint* ph = nullptr;
|
||||
ext->get_antecedents(consequent, idx, m_lemma, false, ph);
|
||||
for (literal l : m_lemma) process_antecedent(~l, offset);
|
||||
break;
|
||||
}
|
||||
|
@ -1052,7 +1053,8 @@ namespace pb {
|
|||
auto* ext = sat::constraint_base::to_extension(index);
|
||||
if (ext != this) {
|
||||
m_lemma.reset();
|
||||
ext->get_antecedents(consequent, index, m_lemma, false);
|
||||
sat::proof_hint* ph = nullptr;
|
||||
ext->get_antecedents(consequent, index, m_lemma, false, ph);
|
||||
for (literal l : m_lemma)
|
||||
process_antecedent(~l, 1);
|
||||
break;
|
||||
|
@ -1688,7 +1690,7 @@ namespace pb {
|
|||
// ----------------------------
|
||||
// constraint generic methods
|
||||
|
||||
void solver::get_antecedents(literal l, sat::ext_justification_idx idx, literal_vector & r, bool probing) {
|
||||
void solver::get_antecedents(literal l, sat::ext_justification_idx idx, literal_vector & r, bool probing, sat::proof_hint*& ph) {
|
||||
get_antecedents(l, index2constraint(idx), r, probing);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue