Basic Theorems About Bitvectors #
This file contains theorems about bitvectors which can only be stated in Mathlib or downstream because they refer to other notions defined in Mathlib.
Please do not extend this file further: material about BitVec needed in downstream projects can either be PR'd to Lean, or kept downstream if it also relies on Mathlib.
Injectivity #
Scalar Multiplication and Powers #
Having instance of SMul ℕ
, SMul ℤ
and Pow
are prerequisites for a CommRing
instance
Ring #
Equations
- BitVec.instCommSemiring = Function.Injective.commSemiring BitVec.toFin ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯
Equations
- BitVec.instCommRing = Function.Injective.commRing BitVec.toFin ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ ⋯
@[simp]
theorem
BitVec.equivFin_symm_apply_toFin
{m : ℕ}
(a : Fin (2 ^ m))
:
(BitVec.equivFin.symm a).toFin = a