Skip to content

Commit

Permalink
Trigger CI for leanprover/lean4#5020
Browse files Browse the repository at this point in the history
  • Loading branch information
leanprover-community-mathlib4-bot committed Aug 23, 2024
2 parents c5bbef3 + 14eda6b commit d7ab32e
Show file tree
Hide file tree
Showing 19 changed files with 795 additions and 531 deletions.
3 changes: 3 additions & 0 deletions Batteries.lean
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import Batteries.Data.BinomialHeap
import Batteries.Data.BitVec
import Batteries.Data.Bool
import Batteries.Data.ByteArray
import Batteries.Data.ByteSubarray
import Batteries.Data.Char
import Batteries.Data.DList
import Batteries.Data.Fin
Expand All @@ -37,6 +38,7 @@ import Batteries.Data.String
import Batteries.Data.Sum
import Batteries.Data.UInt
import Batteries.Data.UnionFind
import Batteries.Data.Vector
import Batteries.Lean.AttributeExtra
import Batteries.Lean.Delaborator
import Batteries.Lean.Except
Expand Down Expand Up @@ -79,6 +81,7 @@ import Batteries.Tactic.Congr
import Batteries.Tactic.Exact
import Batteries.Tactic.Init
import Batteries.Tactic.Instances
import Batteries.Tactic.Lemma
import Batteries.Tactic.Lint
import Batteries.Tactic.Lint.Basic
import Batteries.Tactic.Lint.Frontend
Expand Down
5 changes: 1 addition & 4 deletions Batteries/Classes/Order.lean
Original file line number Diff line number Diff line change
Expand Up @@ -278,11 +278,8 @@ instance [Ord β] [OrientedOrd β] (f : α → β) : OrientedCmp (compareOn f) w
instance [Ord β] [TransOrd β] (f : α → β) : TransCmp (compareOn f) where
le_trans := TransCmp.le_trans (α := β)

-- FIXME: remove after lean4#3882 is merged
theorem _root_.lexOrd_def [Ord α] [Ord β] :
(lexOrd : Ord (α × β)).compare = compareLex (compareOn (·.1)) (compareOn (·.2)) := by
funext a b
simp [lexOrd, compareLex, compareOn]
(lexOrd : Ord (α × β)).compare = compareLex (compareOn (·.1)) (compareOn (·.2)) := rfl

section «non-canonical instances»
-- Note: the following instances seem to cause lean to fail, see:
Expand Down
20 changes: 12 additions & 8 deletions Batteries/Data/Array/Lemmas.lean
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import Batteries.Util.ProofWanted

namespace Array

theorem forIn_eq_data_forIn [Monad m]
theorem forIn_eq_forIn_data [Monad m]
(as : Array α) (b : β) (f : α → β → m (ForInStep β)) :
forIn as b f = forIn as.data b f := by
let rec loop : ∀ {i h b j}, j + i = as.size →
Expand All @@ -27,10 +27,11 @@ theorem forIn_eq_data_forIn [Monad m]
rw [loop (i := i)]; rw [← ij, Nat.succ_add]; rfl
conv => lhs; simp only [forIn, Array.forIn]
rw [loop (Nat.zero_add _)]; rfl
@[deprecated (since := "2024-08-13")] alias forIn_eq_data_forIn := forIn_eq_forIn_data

/-! ### zipWith / zip -/

theorem zipWith_eq_zipWith_data (f : α → β → γ) (as : Array α) (bs : Array β) :
theorem data_zipWith (f : α → β → γ) (as : Array α) (bs : Array β) :
(as.zipWith bs f).data = as.data.zipWith f bs.data := by
let rec loop : ∀ (i : Nat) cs, i ≤ as.size → i ≤ bs.size →
(zipWithAux f as bs i cs).data = cs.data ++ (as.data.drop i).zipWith f (bs.data.drop i) := by
Expand Down Expand Up @@ -70,14 +71,16 @@ theorem zipWith_eq_zipWith_data (f : α → β → γ) (as : Array α) (bs : Arr
List.zipWith f (List.drop i as.data) (List.drop i bs.data)
simp only [data_length, Fin.getElem_fin, List.getElem_cons_drop, List.get_eq_getElem]
simp [zipWith, loop 0 #[] (by simp) (by simp)]
@[deprecated (since := "2024-08-13")] alias zipWith_eq_zipWith_data := data_zipWith

theorem size_zipWith (as : Array α) (bs : Array β) (f : α → β → γ) :
(as.zipWith bs f).size = min as.size bs.size := by
rw [size_eq_length_data, zipWith_eq_zipWith_data, List.length_zipWith]
rw [size_eq_length_data, data_zipWith, List.length_zipWith]

theorem zip_eq_zip_data (as : Array α) (bs : Array β) :
theorem data_zip (as : Array α) (bs : Array β) :
(as.zip bs).data = as.data.zip bs.data :=
zipWith_eq_zipWith_data Prod.mk as bs
data_zipWith Prod.mk as bs
@[deprecated (since := "2024-08-13")] alias zip_eq_zip_data := data_zip

theorem size_zip (as : Array α) (bs : Array β) :
(as.zip bs).size = min as.size bs.size :=
Expand All @@ -92,7 +95,7 @@ theorem size_filter_le (p : α → Bool) (l : Array α) :

/-! ### join -/

@[simp] theorem join_data {l : Array (Array α)} : l.join.data = (l.data.map data).join := by
@[simp] theorem data_join {l : Array (Array α)} : l.join.data = (l.data.map data).join := by
dsimp [join]
simp only [foldl_eq_foldl_data]
generalize l.data = l
Expand All @@ -101,9 +104,10 @@ theorem size_filter_le (p : α → Bool) (l : Array α) :
induction l with
| nil => simp
| cons h => induction h.data <;> simp [*]
@[deprecated (since := "2024-08-13")] alias join_data := data_join

theorem mem_join : ∀ {L : Array (Array α)}, a ∈ L.join ↔ ∃ l, l ∈ L ∧ a ∈ l := by
simp only [mem_def, join_data, List.mem_join, List.mem_map]
simp only [mem_def, data_join, List.mem_join, List.mem_map]
intro l
constructor
· rintro ⟨_, ⟨s, m, rfl⟩, h⟩
Expand All @@ -113,7 +117,7 @@ theorem mem_join : ∀ {L : Array (Array α)}, a ∈ L.join ↔ ∃ l, l ∈ L

/-! ### erase -/

@[simp] proof_wanted erase_data [BEq α] {l : Array α} {a : α} : (l.erase a).data = l.data.erase a
@[simp] proof_wanted data_erase [BEq α] {l : Array α} {a : α} : (l.erase a).data = l.data.erase a

/-! ### shrink -/

Expand Down
33 changes: 21 additions & 12 deletions Batteries/Data/ByteArray.lean
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ Copyright (c) 2023 François G. Dorais. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Authors: François G. Dorais
-/
import Batteries.Tactic.Alias

namespace ByteArray

Expand All @@ -18,15 +19,18 @@ theorem getElem_eq_data_getElem (a : ByteArray) (h : i < a.size) : a[i] = a.data

/-! ### empty -/

@[simp] theorem mkEmpty_data (cap) : (mkEmpty cap).data = #[] := rfl
@[simp] theorem data_mkEmpty (cap) : (mkEmpty cap).data = #[] := rfl
@[deprecated (since := "2024-08-13")] alias mkEmpty_data := data_mkEmpty

@[simp] theorem empty_data : empty.data = #[] := rfl
@[simp] theorem data_empty : empty.data = #[] := rfl
@[deprecated (since := "2024-08-13")] alias empty_data := data_empty

@[simp] theorem size_empty : empty.size = 0 := rfl

/-! ### push -/

@[simp] theorem push_data (a : ByteArray) (b : UInt8) : (a.push b).data = a.data.push b := rfl
@[simp] theorem data_push (a : ByteArray) (b : UInt8) : (a.push b).data = a.data.push b := rfl
@[deprecated (since := "2024-08-13")] alias push_data := data_push

@[simp] theorem size_push (a : ByteArray) (b : UInt8) : (a.push b).size = a.size + 1 :=
Array.size_push ..
Expand All @@ -40,8 +44,9 @@ theorem get_push_lt (a : ByteArray) (x : UInt8) (i : Nat) (h : i < a.size) :

/-! ### set -/

@[simp] theorem set_data (a : ByteArray) (i : Fin a.size) (v : UInt8) :
@[simp] theorem data_set (a : ByteArray) (i : Fin a.size) (v : UInt8) :
(a.set i v).data = a.data.set i v := rfl
@[deprecated (since := "2024-08-13")] alias set_data := data_set

@[simp] theorem size_set (a : ByteArray) (i : Fin a.size) (v : UInt8) :
(a.set i v).size = a.size :=
Expand All @@ -60,20 +65,22 @@ theorem set_set (a : ByteArray) (i : Fin a.size) (v v' : UInt8) :

/-! ### copySlice -/

@[simp] theorem copySlice_data (a i b j len exact) :
@[simp] theorem data_copySlice (a i b j len exact) :
(copySlice a i b j len exact).data = b.data.extract 0 j ++ a.data.extract i (i + len)
++ b.data.extract (j + min len (a.data.size - i)) b.data.size := rfl
@[deprecated (since := "2024-08-13")] alias copySlice_data := data_copySlice

/-! ### append -/

@[simp] theorem append_eq (a b) : ByteArray.append a b = a ++ b := rfl

@[simp] theorem append_data (a b : ByteArray) : (a ++ b).data = a.data ++ b.data := by
@[simp] theorem data_append (a b : ByteArray) : (a ++ b).data = a.data ++ b.data := by
rw [←append_eq]; simp [ByteArray.append, size]
rw [Array.extract_empty_of_stop_le_start (h:=Nat.le_add_right ..), Array.append_nil]
@[deprecated (since := "2024-08-13")] alias append_data := data_append

theorem size_append (a b : ByteArray) : (a ++ b).size = a.size + b.size := by
simp only [size, append_eq, append_data]; exact Array.size_append ..
simp only [size, append_eq, data_append]; exact Array.size_append ..

theorem get_append_left {a b : ByteArray} (hlt : i < a.size)
(h : i < (a ++ b).size := size_append .. ▸ Nat.lt_of_lt_of_le hlt (Nat.le_add_right ..)) :
Expand All @@ -87,12 +94,13 @@ theorem get_append_right {a b : ByteArray} (hle : a.size ≤ i) (h : i < (a ++ b

/-! ### extract -/

@[simp] theorem extract_data (a : ByteArray) (start stop) :
@[simp] theorem data_extract (a : ByteArray) (start stop) :
(a.extract start stop).data = a.data.extract start stop := by
simp [extract]
match Nat.le_total start stop with
| .inl h => simp [h, Nat.add_sub_cancel']
| .inr h => simp [h, Nat.sub_eq_zero_of_le, Array.extract_empty_of_stop_le_start]
@[deprecated (since := "2024-08-13")] alias extract_data := data_extract

@[simp] theorem size_extract (a : ByteArray) (start stop) :
(a.extract start stop).size = min stop a.size - start := by
Expand All @@ -113,7 +121,8 @@ theorem get_extract_aux {a : ByteArray} {start stop} (h : i < (a.extract start s
def ofFn (f : Fin n → UInt8) : ByteArray where
data := .ofFn f

@[simp] theorem ofFn_data (f : Fin n → UInt8) : (ofFn f).data = .ofFn f := rfl
@[simp] theorem data_ofFn (f : Fin n → UInt8) : (ofFn f).data = .ofFn f := rfl
@[deprecated (since := "2024-08-13")] alias ofFn_data := data_ofFn

@[simp] theorem size_ofFn (f : Fin n → UInt8) : (ofFn f).size = n := by
simp [size]
Expand All @@ -131,9 +140,9 @@ private def ofFnAux (f : Fin n → UInt8) : ByteArray := go 0 (mkEmpty n) where
termination_by n - i

@[csimp] private theorem ofFn_eq_ofFnAux : @ofFn = @ofFnAux := by
funext n f; ext1; simp [ofFnAux, Array.ofFn, ofFnAux_data, mkEmpty]
funext n f; ext1; simp [ofFnAux, Array.ofFn, data_ofFnAux, mkEmpty]
where
ofFnAux_data {n} (f : Fin n → UInt8) (i) {acc} :
data_ofFnAux {n} (f : Fin n → UInt8) (i) {acc} :
(ofFnAux.go f i acc).data = Array.ofFn.go f i acc.data := by
rw [ofFnAux.go, Array.ofFn.go]; split; rw [ofFnAux_data f (i+1), push_data]; rfl
rw [ofFnAux.go, Array.ofFn.go]; split; rw [data_ofFnAux f (i+1), data_push]; rfl
termination_by n - i
105 changes: 105 additions & 0 deletions Batteries/Data/ByteSubarray.lean
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@

/-
Copyright (c) 2021 Mario Carneiro. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Authors: Mario Carneiro, François G. Dorais
-/

namespace Batteries

/-- A subarray of a `ByteArray`. -/
structure ByteSubarray where
/-- `O(1)`. Get data array of a `ByteSubarray`. -/
array : ByteArray
/-- `O(1)`. Get start index of a `ByteSubarray`. -/
start : Nat
/-- `O(1)`. Get stop index of a `ByteSubarray`. -/
stop : Nat
/-- Start index is before stop index. -/
start_le_stop : start ≤ stop
/-- Stop index is before end of data array. -/
stop_le_array_size : stop ≤ array.size

namespace ByteSubarray

/-- `O(1)`. Get the size of a `ByteSubarray`. -/
protected def size (self : ByteSubarray) := self.stop - self.start

/-- `O(1)`. Test if a `ByteSubarray` is empty. -/
protected def isEmpty (self : ByteSubarray) := self.start != self.stop

theorem stop_eq_start_add_size (self : ByteSubarray) : self.stop = self.start + self.size := by
rw [ByteSubarray.size, Nat.add_sub_cancel' self.start_le_stop]

/-- `O(n)`. Extract a `ByteSubarray` to a `ByteArray`. -/
def toByteArray (self : ByteSubarray) : ByteArray :=
self.array.extract self.start self.stop

/-- `O(1)`. Get the element at index `i` from the start of a `ByteSubarray`. -/
@[inline] def get (self : ByteSubarray) (i : Fin self.size) : UInt8 :=
have : self.start + i.1 < self.array.size := by
apply Nat.lt_of_lt_of_le _ self.stop_le_array_size
rw [stop_eq_start_add_size]
apply Nat.add_lt_add_left i.is_lt self.start
self.array[self.start + i.1]

instance : GetElem ByteSubarray Nat UInt8 fun self i => i < self.size where
getElem self i h := self.get ⟨i, h⟩

/-- `O(1)`. Pop the last element of a `ByteSubarray`. -/
@[inline] def pop (self : ByteSubarray) : ByteSubarray :=
if h : self.start = self.stop then self else
{self with
stop := self.stop - 1
start_le_stop := Nat.le_pred_of_lt (Nat.lt_of_le_of_ne self.start_le_stop h)
stop_le_array_size := Nat.le_trans (Nat.pred_le _) self.stop_le_array_size
}

/-- `O(1)`. Pop the first element of a `ByteSubarray`. -/
@[inline] def popFront (self : ByteSubarray) : ByteSubarray :=
if h : self.start = self.stop then self else
{self with
start := self.start + 1
start_le_stop := Nat.succ_le_of_lt (Nat.lt_of_le_of_ne self.start_le_stop h)
}

/-- Folds a monadic function over a `ByteSubarray` from left to right. -/
@[inline] def foldlM [Monad m] (self : ByteSubarray) (f : β → UInt8 → m β) (init : β) : m β :=
self.array.foldlM f init self.start self.stop

/-- Folds a function over a `ByteSubarray` from left to right. -/
@[inline] def foldl (self : ByteSubarray) (f : β → UInt8 → β) (init : β) : β :=
self.foldlM (m:=Id) f init

/-- Implementation of `forIn` for a `ByteSubarray`. -/
@[specialize]
protected def forIn [Monad m] (self : ByteSubarray) (init : β) (f : UInt8 → β → m (ForInStep β)) :
m β := loop self.size (Nat.le_refl _) init
where
/-- Inner loop of the `forIn` implementation for `ByteSubarray`. -/
loop (i : Nat) (h : i ≤ self.size) (b : β) : m β := do
match i, h with
| 0, _ => pure b
| i+1, h =>
match (← f self[self.size - 1 - i] b) with
| ForInStep.done b => pure b
| ForInStep.yield b => loop i (Nat.le_of_succ_le h) b

instance : ForIn m ByteSubarray UInt8 where
forIn := ByteSubarray.forIn

instance : Stream ByteSubarray UInt8 where
next? s := s[0]? >>= fun x => (x, s.popFront)

end Batteries.ByteSubarray

/-- `O(1)`. Coerce a byte array into a byte slice. -/
def ByteArray.toByteSubarray (array : ByteArray) : Batteries.ByteSubarray where
array := array
start := 0
stop := array.size
start_le_stop := Nat.zero_le _
stop_le_array_size := Nat.le_refl _

instance : Coe ByteArray Batteries.ByteSubarray where
coe := ByteArray.toByteSubarray
Loading

0 comments on commit d7ab32e

Please sign in to comment.