From daf24ff6aab7fa1a43e97c5559d0eb71fe356aab Mon Sep 17 00:00:00 2001 From: Tobias Grosser Date: Wed, 18 Sep 2024 22:59:09 +0100 Subject: [PATCH] feat: add BitVec.ofBool_[and|or|xor]_ofBool theorems (#5385) ... and use them to simplify some proofs. --- src/Init/Data/BitVec/Lemmas.lean | 18 +++++++++++--- .../completionPrv.lean.expected.out | 24 +++++++++++++++++++ 2 files changed, 39 insertions(+), 3 deletions(-) diff --git a/src/Init/Data/BitVec/Lemmas.lean b/src/Init/Data/BitVec/Lemmas.lean index 1fa84de8d846..54355070f1f3 100644 --- a/src/Init/Data/BitVec/Lemmas.lean +++ b/src/Init/Data/BitVec/Lemmas.lean @@ -234,6 +234,15 @@ theorem ofBool_eq_iff_eq : ∀ {b b' : Bool}, BitVec.ofBool b = BitVec.ofBool b' @[simp] theorem not_ofBool : ~~~ (ofBool b) = ofBool (!b) := by cases b <;> rfl +@[simp] theorem ofBool_and_ofBool : ofBool b &&& ofBool b' = ofBool (b && b') := by + cases b <;> cases b' <;> rfl + +@[simp] theorem ofBool_or_ofBool : ofBool b ||| ofBool b' = ofBool (b || b') := by + cases b <;> cases b' <;> rfl + +@[simp] theorem ofBool_xor_ofBool : ofBool b ^^^ ofBool b' = ofBool (b ^^ b') := by + cases b <;> cases b' <;> rfl + @[simp, bv_toNat] theorem toNat_ofFin (x : Fin (2^n)) : (BitVec.ofFin x).toNat = x.val := rfl @[simp] theorem toNat_ofNatLt (x : Nat) (p : x < 2^w) : (x#'p).toNat = x := rfl @@ -1421,15 +1430,18 @@ theorem eq_msb_cons_setWidth (x : BitVec (w+1)) : x = (cons x.msb (x.setWidth w) @[simp] theorem cons_or_cons (x y : BitVec w) (a b : Bool) : (cons a x) ||| (cons b y) = cons (a || b) (x ||| y) := by - ext i; cases i using Fin.succRecOn <;> simp <;> split <;> rfl + ext i + simp [cons] @[simp] theorem cons_and_cons (x y : BitVec w) (a b : Bool) : (cons a x) &&& (cons b y) = cons (a && b) (x &&& y) := by - ext i; cases i using Fin.succRecOn <;> simp <;> split <;> rfl + ext i + simp [cons] @[simp] theorem cons_xor_cons (x y : BitVec w) (a b : Bool) : (cons a x) ^^^ (cons b y) = cons (a ^^ b) (x ^^^ y) := by - ext i; cases i using Fin.succRecOn <;> simp <;> split <;> rfl + ext i + simp [cons] /-! ### concat -/ diff --git a/tests/lean/interactive/completionPrv.lean.expected.out b/tests/lean/interactive/completionPrv.lean.expected.out index 3dff7f4398fa..aaa1f429ac26 100644 --- a/tests/lean/interactive/completionPrv.lean.expected.out +++ b/tests/lean/interactive/completionPrv.lean.expected.out @@ -46,6 +46,30 @@ "position": {"line": 9, "character": 11}}, "id": {"const": {"declName": "BitVec.getMsbD_ofBoolListBE"}}}}, {"sortText": "4", + "label": "BitVec.ofBool_and_ofBool", + "kind": 3, + "data": + {"params": + {"textDocument": {"uri": "file:///completionPrv.lean"}, + "position": {"line": 9, "character": 11}}, + "id": {"const": {"declName": "BitVec.ofBool_and_ofBool"}}}}, + {"sortText": "5", + "label": "BitVec.ofBool_or_ofBool", + "kind": 3, + "data": + {"params": + {"textDocument": {"uri": "file:///completionPrv.lean"}, + "position": {"line": 9, "character": 11}}, + "id": {"const": {"declName": "BitVec.ofBool_or_ofBool"}}}}, + {"sortText": "6", + "label": "BitVec.ofBool_xor_ofBool", + "kind": 3, + "data": + {"params": + {"textDocument": {"uri": "file:///completionPrv.lean"}, + "position": {"line": 9, "character": 11}}, + "id": {"const": {"declName": "BitVec.ofBool_xor_ofBool"}}}}, + {"sortText": "7", "label": "BitVec.ofBoolListBE", "kind": 3, "documentation":