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

refactor: redefine unsigned fixed width integers in terms of BitVec #5323

Merged
merged 38 commits into from
Oct 16, 2024

Conversation

hargoniX
Copy link
Contributor

@hargoniX hargoniX commented Sep 12, 2024

I made a few choices so far that can probably be discussed:

  • got rid of modn on UInt, nobody seems to use it apart from the definition of shift which can use normal mod
  • removed the previous defeq optimized definition of USize.size in favor for a normal one. The motivation was to allow OfNat to work which doesn't seem to be necessary anymore afaict.
  • Minimized uses of .val, should we maybe mark it deprecated?
  • Mostly got rid of .val in basically all theorems as the proper next level of API would now be .toBitVec. We could probably re-prove them but it would be more annoying given the change of definition.
  • Did not yet redefine log2 in terms of BitVec as this would require a log2 in BitVec as well, do we want this?
  • I added a couple of theorems around the relation of < on UInt and Nat. These were previously not needed because defeq was used all over the place to save us. I did not yet generalize these to all types as I wasn't sure if they are the appropriate lemma that we want to have.

@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc September 12, 2024 14:32 Inactive
@github-actions github-actions bot added the toolchain-available A toolchain is available for this PR, at leanprover/lean4-pr-releases:pr-release-NNNN label Sep 12, 2024
@leanprover-community-mathlib4-bot
Copy link
Collaborator

leanprover-community-mathlib4-bot commented Sep 12, 2024

Mathlib CI status (docs):

  • ❗ Batteries/Mathlib CI will not be attempted unless your PR branches off the nightly-with-mathlib branch. Try git rebase 273b7540b2ad6288344869a7e2324de376aada5a --onto adfd6c090ef7d6bdcc8f69c5dd6f919b1b71cab3. (2024-09-12 14:38:38)
  • 💥 Mathlib branch lean-pr-testing-5323 build failed against this PR. (2024-09-23 10:04:20) View Log
  • 💥 Mathlib branch lean-pr-testing-5323 build failed against this PR. (2024-09-23 10:36:03) View Log
  • 💥 Mathlib branch lean-pr-testing-5323 build failed against this PR. (2024-09-23 11:57:56) View Log
  • 🟡 Mathlib branch lean-pr-testing-5323 build against this PR was cancelled. (2024-09-23 13:23:04) View Log
  • 💥 Mathlib branch lean-pr-testing-5323 build failed against this PR. (2024-09-23 14:07:28) View Log
  • 💥 Mathlib branch lean-pr-testing-5323 build failed against this PR. (2024-09-23 14:33:59) View Log
  • 💥 Mathlib branch lean-pr-testing-5323 build failed against this PR. (2024-09-24 00:27:33) View Log
  • ❗ Batteries/Mathlib CI will not be attempted unless your PR branches off the nightly-with-mathlib branch. Try git rebase 5d2c7fc1d92a1049f04bba1b16c0a1cfae845e00 --onto e551a366a0bbb27d5f853cc8e87cbd381a76ffc0. (2024-09-24 10:32:27)

@hargoniX hargoniX force-pushed the hbv/uint-bitvec-redefine branch from 41413d4 to d0278ff Compare September 13, 2024 09:26
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc September 13, 2024 09:46 Inactive
@hargoniX hargoniX marked this pull request as ready for review September 13, 2024 09:51
@kim-em
Copy link
Collaborator

kim-em commented Sep 16, 2024

Looks great.

Could you leave a deprecation in place for modn, just in case there is a downstream user?

Agree to marking .val as deprecated, but it can also happen later.

BitVec.log2 sounds good, but probably deserves a different name, and can happen later.

Would you mind rebasing onto nightly-with-mathlib so we can check to see how much we have disturbed downstream. (Ideally nothing, but I'm be pleasantly surprised if that were the case.)

@kim-em
Copy link
Collaborator

kim-em commented Sep 16, 2024

(I'm keen to have this in, as I'm thinking about Fin refactors.)

@hargoniX hargoniX force-pushed the hbv/uint-bitvec-redefine branch 2 times, most recently from 91cb45d to 6373762 Compare September 23, 2024 09:40
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc September 23, 2024 09:58 Inactive
leanprover-community-mathlib4-bot added a commit to leanprover-community/batteries that referenced this pull request Sep 23, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/mathlib4 that referenced this pull request Sep 23, 2024
@leanprover-community-bot leanprover-community-bot added the breaks-mathlib This is not necessarily a blocker for merging: but there needs to be a plan label Sep 23, 2024
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc September 23, 2024 10:27 Inactive
leanprover-community-mathlib4-bot added a commit to leanprover-community/batteries that referenced this pull request Sep 23, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/mathlib4 that referenced this pull request Sep 23, 2024
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc September 23, 2024 11:46 Inactive
leanprover-community-mathlib4-bot added a commit to leanprover-community/batteries that referenced this pull request Sep 23, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/mathlib4 that referenced this pull request Sep 23, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/batteries that referenced this pull request Sep 23, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/mathlib4 that referenced this pull request Sep 23, 2024
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc September 23, 2024 13:20 Inactive
kim-em added a commit to leanprover-community/mathlib4 that referenced this pull request Sep 24, 2024
@hargoniX hargoniX force-pushed the hbv/uint-bitvec-redefine branch from a518e40 to 0f9eaa8 Compare September 24, 2024 08:09
@hargoniX hargoniX closed this Sep 24, 2024
@hargoniX hargoniX reopened this Sep 24, 2024
@hargoniX hargoniX force-pushed the hbv/uint-bitvec-redefine branch from 417e7f1 to e4b5f70 Compare October 15, 2024 08:45
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc October 15, 2024 08:59 Inactive
leanprover-community-mathlib4-bot added a commit to leanprover-community/batteries that referenced this pull request Oct 15, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/mathlib4 that referenced this pull request Oct 15, 2024
@hargoniX hargoniX force-pushed the hbv/uint-bitvec-redefine branch from e4b5f70 to 27a4f60 Compare October 15, 2024 09:43
@github-actions github-actions bot temporarily deployed to lean-lang.org/lean4/doc October 15, 2024 09:49 Inactive
leanprover-community-mathlib4-bot added a commit to leanprover-community/batteries that referenced this pull request Oct 15, 2024
leanprover-community-mathlib4-bot added a commit to leanprover-community/mathlib4 that referenced this pull request Oct 15, 2024
@hargoniX hargoniX added this pull request to the merge queue Oct 16, 2024
Merged via the queue into master with commit 19e06ac Oct 16, 2024
15 checks passed
@hargoniX hargoniX deleted the hbv/uint-bitvec-redefine branch October 16, 2024 07:58
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
builds-mathlib CI has verified that Mathlib builds against this PR toolchain-available A toolchain is available for this PR, at leanprover/lean4-pr-releases:pr-release-NNNN
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants