Documentation

Std.Tactic.BVDecide.LRAT.Internal.Formula.RupAddSound

This module contains the verification of RUP-based clause adding for the default LRAT checker implementation.

theorem Std.Tactic.BVDecide.LRAT.Internal.DefaultFormula.contradiction_of_insertUnit_success {n : Nat} (assignments : Array Assignment) (assignments_size : assignments.size = n) (units : Array (Sat.Literal (PosFin n))) (foundContradiction : Bool) (l : Sat.Literal (PosFin n)) :
theorem Std.Tactic.BVDecide.LRAT.Internal.DefaultFormula.mem_insertUnit_units {n : Nat} (units : Array (Sat.Literal (PosFin n))) (assignments : Array Assignment) (foundContradiction : Bool) (l : Sat.Literal (PosFin n)) :
let insertUnit_res := insertUnit (units, assignments, foundContradiction) l; ∀ (l' : Sat.Literal (PosFin n)), l' insertUnit_res.fst.toListl' = l l' units.toList
theorem Std.Tactic.BVDecide.LRAT.Internal.DefaultFormula.mem_insertUnit_fold_units {n : Nat} (units : Array (Sat.Literal (PosFin n))) (assignments : Array Assignment) (foundContradiction : Bool) (l : Sat.CNF.Clause (PosFin n)) :
let insertUnit_fold_res := List.foldl insertUnit (units, assignments, foundContradiction) l; ∀ (l' : Sat.Literal (PosFin n)), l' insertUnit_fold_res.fst.toListl' l l' units.toList
Equations
  • One or more equations did not get rendered due to their size.
Instances For
    Equations
    • One or more equations did not get rendered due to their size.
    Instances For
      theorem Std.Tactic.BVDecide.LRAT.Internal.DefaultFormula.rupAdd_sound {n : Nat} (f : DefaultFormula n) (c : DefaultClause n) (rupHints : Array Nat) (f' : DefaultFormula n) (f_readyForRupAdd : f.ReadyForRupAdd) (rupAddSuccess : f.performRupAdd c rupHints = (f', true)) :
      Liff (PosFin n) f f'