Skip to content

Commit

Permalink
feat: getLsb_replicate
Browse files Browse the repository at this point in the history
  • Loading branch information
bollu committed Jul 23, 2024
1 parent 92cca5e commit c09007f
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 4 deletions.
6 changes: 2 additions & 4 deletions src/Init/Data/BitVec/Basic.lean
Original file line number Diff line number Diff line change
Expand Up @@ -583,11 +583,9 @@ instance : HAppend (BitVec w) (BitVec v) (BitVec (w + v)) := ⟨.append⟩
-- TODO: write this using multiplication
/-- `replicate i x` concatenates `i` copies of `x` into a new vector of length `w*i`. -/
def replicate : (i : Nat) → BitVec w → BitVec (w*i)
| 0, _ => 0
| 0, _ => 0#0
| n+1, x =>
have hEq : w + w*n = w*(n + 1) := by
rw [Nat.mul_add, Nat.add_comm, Nat.mul_one]
hEq ▸ (x ++ replicate n x)
(x ++ replicate n x).cast (by rw [Nat.mul_succ]; omega)

/-!
### Cons and Concat
Expand Down
42 changes: 42 additions & 0 deletions src/Init/Data/BitVec/Lemmas.lean
Original file line number Diff line number Diff line change
Expand Up @@ -1504,4 +1504,46 @@ theorem zeroExtend_truncate_succ_eq_zeroExtend_truncate_or_twoPow_of_getLsb_true
simp [hx]
· by_cases hik' : k < i + 1 <;> simp [hik, hik'] <;> omega

@[simp]
theorem replicate_zero_eq {x : BitVec w} : x.replicate 0 = 0#0 := by
simp [replicate]

@[simp]
theorem replicate_succ_eq {x : BitVec w} :
x.replicate (n + 1) =
(x ++ replicate n x).cast (by rw [Nat.mul_succ]; omega) := by
simp [replicate]

theorem getLsb_replicate {n w : Nat} (x : BitVec w) :
(x.replicate n).getLsb i = ((decide (i < w * n)) && (x.getLsb (i % w))) := by
induction n generalizing x
case zero =>
rw [replicate_zero_eq]
simp
case succ n ih =>
rw [replicate_succ_eq]
simp only [getLsb_cast, getLsb_append]
by_cases hi : i < w * n
· simp [hi, ih]
intros _
rw [Nat.mul_succ]
omega
· simp [hi, ih]
by_cases hi' : i < w * (n + 1)
· simp [hi']
congr
rw [Nat.sub_eq_of_eq_add]
have hi : i / w = n := by
apply Nat.div_eq_of_lt_le (m := i) (k := n)
(by simp at hi; rw[Nat.mul_comm]; assumption)
(by rw [Nat.mul_comm]; assumption)
rw [← hi]
rw [Nat.add_comm]
rw [Nat.div_add_mod]
· simp [hi']
apply getLsb_ge
apply Nat.le_sub_of_add_le
simp [Nat.mul_succ] at hi'
rw [Nat.add_comm]
assumption
end BitVec

0 comments on commit c09007f

Please sign in to comment.