Equations
- Std.Sat.AIG.RefVec.empty = { refs := #[], hlen := Std.Sat.AIG.RefVec.empty.proof_1, hrefs := ⋯ }
Instances For
@[inline]
def
Std.Sat.AIG.RefVec.push
{α : Type}
[Hashable α]
[DecidableEq α]
{aig : AIG α}
{len : Nat}
(s : aig.RefVec len)
(ref : aig.Ref)
:
Equations
- { refs := refs, hlen := hlen, hrefs := hrefs }.push ref = { refs := refs.push ref.gate, hlen := ⋯, hrefs := ⋯ }
Instances For
@[simp]
theorem
Std.Sat.AIG.RefVec.get_push_ref_eq
{α : Type}
[Hashable α]
[DecidableEq α]
{aig : AIG α}
{len : Nat}
(s : aig.RefVec len)
(ref : aig.Ref)
:
@[inline]
def
Std.Sat.AIG.RefVec.append
{α : Type}
[Hashable α]
[DecidableEq α]
{aig : AIG α}
{lw rw : Nat}
(lhs : aig.RefVec lw)
(rhs : aig.RefVec rw)
:
Equations
- { refs := refs, hlen := hlen, hrefs := hrefs }.append { refs := refs_1, hlen := hlen_1, hrefs := hrefs_1 } = { refs := refs ++ refs_1, hlen := ⋯, hrefs := ⋯ }
Instances For
def
Std.Sat.AIG.RefVec.countKnown
{α : Type}
[Hashable α]
[DecidableEq α]
{len : Nat}
[Inhabited α]
(aig : AIG α)
(s : aig.RefVec len)
:
Equations
- One or more equations did not get rendered due to their size.
Instances For
structure
Std.Sat.AIG.BinaryRefVec
{α : Type}
[Hashable α]
[DecidableEq α]
(aig : AIG α)
(len : Nat)
:
Instances For
@[inline]
def
Std.Sat.AIG.BinaryRefVec.cast
{α : Type}
[Hashable α]
[DecidableEq α]
{len : Nat}
{aig1 aig2 : AIG α}
(s : aig1.BinaryRefVec len)
(h : aig1.decls.size ≤ aig2.decls.size)
:
aig2.BinaryRefVec len
Equations
- { lhs := lhs, rhs := rhs }.cast h = { lhs := lhs.cast h, rhs := rhs.cast h }
Instances For
@[simp]
theorem
Std.Sat.AIG.BinaryRefVec.lhs_get_cast
{α : Type}
[Hashable α]
[DecidableEq α]
{len : Nat}
{aig1 aig2 : AIG α}
(s : aig1.BinaryRefVec len)
(idx : Nat)
(hidx : idx < len)
(hcast : aig1.decls.size ≤ aig2.decls.size)
:
@[simp]
theorem
Std.Sat.AIG.BinaryRefVec.rhs_get_cast
{α : Type}
[Hashable α]
[DecidableEq α]
{len : Nat}
{aig1 aig2 : AIG α}
(s : aig1.BinaryRefVec len)
(idx : Nat)
(hidx : idx < len)
(hcast : aig1.decls.size ≤ aig2.decls.size)
: