Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: recurrence for BitVec.mul as repeated shifts for bitblasting #6

Closed
wants to merge 64 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
247349c
chore: start writing recurrences for mul
bollu Jun 3, 2024
55cfc6d
chore: write udiv recursion eqn
bollu Jun 3, 2024
2e5ea9f
chore: add mul verified statement from z3
bollu Jun 3, 2024
910ce3b
chore: check in WIP
bollu Jun 4, 2024
5ae0995
chore: make progress
bollu Jun 4, 2024
203b34b
chore: continue writing theorems
bollu Jun 4, 2024
6df5fd5
chore: push
bollu Jun 4, 2024
bec5b36
chore: finish proof of recurrence
bollu Jun 4, 2024
e6cba22
chore: rejigger files, move to bitvec/bitblast
bollu Jun 8, 2024
2f0cb91
chore: cleaup proofs, move them to the right locations
bollu Jun 8, 2024
8632849
chore: drop large z3 comment
bollu Jun 8, 2024
351a7ce
chore: move theorems around to proper location
bollu Jun 8, 2024
75867dd
chore: more cleanup
bollu Jun 8, 2024
bea6a61
chore: move twoPow into bitwise
bollu Jun 8, 2024
33be7e5
Apply suggestions from code review
bollu Jun 8, 2024
9bc8d7d
chore: delete more parens around 0#w, 1#w
bollu Jun 8, 2024
fc67256
chore: drop newline
bollu Jun 8, 2024
71a6c23
Apply suggestions from code review
bollu Jun 8, 2024
c91edf1
chore: drop paren
bollu Jun 8, 2024
ecde706
wip: bitblast shifts
bollu Jun 10, 2024
a61c43e
chore: start shift right
bollu Jun 15, 2024
5cba64a
chore: update shift left to different widths
bollu Jun 26, 2024
0b4a59f
chore: more bitblast
bollu Jun 27, 2024
cbf80f8
chore: fixup final theorem
bollu Jun 27, 2024
b14ba43
chore: shiftRight recurrence theorem
bollu Jun 27, 2024
2e6ff6f
chore: that was logical shift right. Skip arithmetic shift right for now
bollu Jun 27, 2024
af5b90d
feat: characterize div and mod via arithmetic
bollu Jun 28, 2024
f967caf
chore: cleanup hypotheses
bollu Jun 28, 2024
b9f78b5
chore: prove another equivalence given an lt hypothesis
bollu Jun 28, 2024
904a01b
chore: prove necessary equivalence with sufficiently weak hypothesis …
bollu Jun 28, 2024
36711b0
chore: write theorem statement for DivRem recurrence
bollu Jun 28, 2024
f267fe3
chore: cleanup theorem statement to be cripser
bollu Jun 28, 2024
0ed0d44
chore: write proof sketch of why the div, rem sorries are true. Now f…
bollu Jun 28, 2024
0e23bbd
chore: I believe the proof, now I need to encode it
bollu Jun 28, 2024
211fe3e
chore: see that we have an overflow, can't write it this way.
bollu Jun 28, 2024
5b3bbc1
chore: write udiv proof, need to prove the other branch of the proof …
bollu Jun 29, 2024
949c9b6
chore: stash
bollu Jul 1, 2024
5c10b83
chore: comment out broken impl
bollu Jul 1, 2024
5beb72b
chore: start implement sshiftRight' and arith shift right recurrence.
bollu Jul 1, 2024
9720ab5
chore: stash sshiftRight that hargonix wants next
bollu Jul 2, 2024
cc6817d
chore: add division invariant
bollu Jul 2, 2024
89f6087
chore: add div invariant
bollu Jul 3, 2024
44127be
chore: add one impl of div_invariant
bollu Jul 3, 2024
a2c3576
chore: add new division invariant that should be easier to prove
bollu Jul 4, 2024
56ea083
chore: prove remiander property, still a sorry left
bollu Jul 4, 2024
9ca69d4
chore: add new invariant code. This is more subtle than I thought for…
bollu Jul 4, 2024
89ce200
chore: stash
bollu Jul 4, 2024
53fbd3a
chore: one half of base case
bollu Jul 4, 2024
ac92331
chore: second half of base case, half done
bollu Jul 4, 2024
80dedc2
chore: base case done
bollu Jul 4, 2024
c9b1227
chore: show how to derive final theorem from recurrence
bollu Jul 5, 2024
0b6e2e8
chore: delete dead code
bollu Jul 5, 2024
8ad944a
feat: I now understand why the remainder is wr and dividend is wn, th…
bollu Jul 5, 2024
f1559cd
chore: lay everything out as a large structure with all preconditions
bollu Jul 5, 2024
809263c
chore: more progress, first settle on using Bool.toNat everywhere
bollu Jul 5, 2024
25fa2b4
wrap up one branch of proof, now have second branch left
bollu Jul 5, 2024
f9f8b09
feat: finish then branch, now do else branch
bollu Jul 5, 2024
e15e05c
chore: finish another sorry on the else branch
bollu Jul 5, 2024
faea676
feat: finish udiv/urem bitblast
bollu Jul 5, 2024
ccf7628
chore: throw away incorrect implementations
bollu Jul 5, 2024
935d35f
chore: establish correctness of non-dependent statement
bollu Jul 5, 2024
c83cf03
chore: write _zero and _succ theorems for @hargonix to be able to bit…
bollu Jul 5, 2024
a20b14d
chore: delete new file
bollu Jul 10, 2024
09016e7
chore: added sshiftRight as well
bollu Jul 10, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions src/Init/Data/BitVec/Basic.lean
Original file line number Diff line number Diff line change
Expand Up @@ -531,6 +531,8 @@ SMT-Lib name: `bvashr` except this operator uses a `Nat` shift value.
-/
def sshiftRight (a : BitVec n) (s : Nat) : BitVec n := .ofInt n (a.toInt >>> s)

def sshiftRight' (a : BitVec n) (s : BitVec m) : BitVec n := a.sshiftRight s.toNat

instance {n} : HShiftLeft (BitVec m) (BitVec n) (BitVec m) := ⟨fun x y => x <<< y.toNat⟩
instance {n} : HShiftRight (BitVec m) (BitVec n) (BitVec m) := ⟨fun x y => x >>> y.toNat⟩

Expand Down Expand Up @@ -614,6 +616,13 @@ theorem ofBool_append (msb : Bool) (lsbs : BitVec w) :
ofBool msb ++ lsbs = (cons msb lsbs).cast (Nat.add_comm ..) :=
rfl

/--
`twoPow i` is the bitvector `2^i` if `i < w`, and `0` otherwise.
That is, 2 to the power `i`.
For the bitwise point of view, it has the `i`th bit as `1` and all other bits as `0`.
-/
def twoPow (w : Nat) (i : Nat) : BitVec w := 1#w <<< i

end bitwise

section normalization_eqs
Expand Down
Loading