HepLean Documentation

Batteries.Data.Fin.Lemmas

clamp #

@[simp]
theorem Fin.coe_clamp (n : Nat) (m : Nat) :
(Fin.clamp n m) = min n m

enum/list #

@[simp]
theorem Fin.size_enum (n : Nat) :
(Fin.enum n).size = n
@[simp]
theorem Fin.enum_zero :
Fin.enum 0 = #[]
@[simp]
theorem Fin.getElem_enum {n : Nat} (i : Nat) (h : i < (Fin.enum n).size) :
(Fin.enum n)[i] = i,
@[simp]
theorem Fin.length_list (n : Nat) :
(Fin.list n).length = n
@[simp]
theorem Fin.getElem_list {n : Nat} (i : Nat) (h : i < (Fin.list n).length) :
(Fin.list n)[i] = Fin.cast i, h
@[deprecated Fin.getElem_list]
theorem Fin.get_list {n : Nat} (i : Fin (Fin.list n).length) :
(Fin.list n).get i = Fin.cast i
@[simp]
theorem Fin.list_zero :
Fin.list 0 = []
theorem Fin.list_succ (n : Nat) :
Fin.list (n + 1) = 0 :: List.map Fin.succ (Fin.list n)
theorem Fin.list_succ_last (n : Nat) :
Fin.list (n + 1) = List.map Fin.castSucc (Fin.list n) ++ [Fin.last n]
theorem Fin.list_reverse (n : Nat) :
(Fin.list n).reverse = List.map Fin.rev (Fin.list n)

foldlM #

theorem Fin.foldlM_loop_lt {m : Type u_1 → Type u_2} {α : Type u_1} {n : Nat} {i : Nat} [Monad m] (f : αFin nm α) (x : α) (h : i < n) :
Fin.foldlM.loop n f x i = do let xf x i, h Fin.foldlM.loop n f x (i + 1)
theorem Fin.foldlM_loop_eq {m : Type u_1 → Type u_2} {α : Type u_1} {n : Nat} [Monad m] (f : αFin nm α) (x : α) :
@[irreducible]
theorem Fin.foldlM_loop {m : Type u_1 → Type u_2} {α : Type u_1} {n : Nat} {i : Nat} [Monad m] (f : αFin (n + 1)m α) (x : α) (h : i < n + 1) :
Fin.foldlM.loop (n + 1) f x i = do let xf x i, h Fin.foldlM.loop n (fun (x : α) (j : Fin n) => f x j.succ) x i
@[simp]
theorem Fin.foldlM_zero {m : Type u_1 → Type u_2} {α : Type u_1} [Monad m] (f : αFin 0m α) (x : α) :
Fin.foldlM 0 f x = pure x
theorem Fin.foldlM_succ {m : Type u_1 → Type u_2} {α : Type u_1} {n : Nat} [Monad m] (f : αFin (n + 1)m α) (x : α) :
Fin.foldlM (n + 1) f x = f x 0 >>= Fin.foldlM n fun (x : α) (j : Fin n) => f x j.succ
theorem Fin.foldlM_eq_foldlM_list {m : Type u_1 → Type u_2} {α : Type u_1} {n : Nat} [Monad m] (f : αFin nm α) (x : α) :

foldrM #

theorem Fin.foldrM_loop_zero {m : Type u_1 → Type u_2} {n : Nat} {α : Type u_1} [Monad m] (f : Fin nαm α) (x : α) :
Fin.foldrM.loop n f 0, x = pure x
theorem Fin.foldrM_loop_succ {m : Type u_1 → Type u_2} {n : Nat} {α : Type u_1} {i : Nat} [Monad m] (f : Fin nαm α) (x : α) (h : i < n) :
Fin.foldrM.loop n f i + 1, h x = f i, h x >>= Fin.foldrM.loop n f i,
theorem Fin.foldrM_loop {m : Type u_1 → Type u_2} {n : Nat} {α : Type u_1} {i : Nat} [Monad m] [LawfulMonad m] (f : Fin (n + 1)αm α) (x : α) (h : i + 1 n + 1) :
Fin.foldrM.loop (n + 1) f i + 1, h x = Fin.foldrM.loop n (fun (j : Fin n) => f j.succ) i, x >>= f 0
@[simp]
theorem Fin.foldrM_zero {m : Type u_1 → Type u_2} {α : Type u_1} [Monad m] (f : Fin 0αm α) (x : α) :
Fin.foldrM 0 f x = pure x
theorem Fin.foldrM_succ {m : Type u_1 → Type u_2} {n : Nat} {α : Type u_1} [Monad m] [LawfulMonad m] (f : Fin (n + 1)αm α) (x : α) :
Fin.foldrM (n + 1) f x = Fin.foldrM n (fun (i : Fin n) => f i.succ) x >>= f 0
theorem Fin.foldrM_eq_foldrM_list {m : Type u_1 → Type u_2} {n : Nat} {α : Type u_1} [Monad m] [LawfulMonad m] (f : Fin nαm α) (x : α) :

foldl #

theorem Fin.foldl_loop_lt {α : Sort u_1} {n : Nat} {i : Nat} (f : αFin nα) (x : α) (h : i < n) :
Fin.foldl.loop n f x i = Fin.foldl.loop n f (f x i, h) (i + 1)
theorem Fin.foldl_loop_eq {α : Sort u_1} {n : Nat} (f : αFin nα) (x : α) :
Fin.foldl.loop n f x n = x
@[irreducible]
theorem Fin.foldl_loop {α : Sort u_1} {n : Nat} {i : Nat} (f : αFin (n + 1)α) (x : α) (h : i < n + 1) :
Fin.foldl.loop (n + 1) f x i = Fin.foldl.loop n (fun (x : α) (j : Fin n) => f x j.succ) (f x i, h) i
@[simp]
theorem Fin.foldl_zero {α : Sort u_1} (f : αFin 0α) (x : α) :
Fin.foldl 0 f x = x
theorem Fin.foldl_succ {α : Sort u_1} {n : Nat} (f : αFin (n + 1)α) (x : α) :
Fin.foldl (n + 1) f x = Fin.foldl n (fun (x : α) (i : Fin n) => f x i.succ) (f x 0)
theorem Fin.foldl_succ_last {α : Sort u_1} {n : Nat} (f : αFin (n + 1)α) (x : α) :
Fin.foldl (n + 1) f x = f (Fin.foldl n (fun (x1 : α) (x2 : Fin n) => f x1 x2.castSucc) x) (Fin.last n)
theorem Fin.foldl_eq_foldlM {α : Type u_1} {n : Nat} (f : αFin nα) (x : α) :
Fin.foldl n f x = Fin.foldlM n f x
theorem Fin.foldl_eq_foldl_list {α : Type u_1} {n : Nat} (f : αFin nα) (x : α) :

foldr #

theorem Fin.foldr_loop_zero {n : Nat} {α : Sort u_1} (f : Fin nαα) (x : α) :
Fin.foldr.loop n f 0, x = x
theorem Fin.foldr_loop_succ {n : Nat} {α : Sort u_1} {i : Nat} (f : Fin nαα) (x : α) (h : i < n) :
Fin.foldr.loop n f i + 1, h x = Fin.foldr.loop n f i, (f i, h x)
theorem Fin.foldr_loop {n : Nat} {α : Sort u_1} {i : Nat} (f : Fin (n + 1)αα) (x : α) (h : i + 1 n + 1) :
Fin.foldr.loop (n + 1) f i + 1, h x = f 0 (Fin.foldr.loop n (fun (j : Fin n) => f j.succ) i, x)
@[simp]
theorem Fin.foldr_zero {α : Sort u_1} (f : Fin 0αα) (x : α) :
Fin.foldr 0 f x = x
theorem Fin.foldr_succ {n : Nat} {α : Sort u_1} (f : Fin (n + 1)αα) (x : α) :
Fin.foldr (n + 1) f x = f 0 (Fin.foldr n (fun (i : Fin n) => f i.succ) x)
theorem Fin.foldr_succ_last {n : Nat} {α : Sort u_1} (f : Fin (n + 1)αα) (x : α) :
Fin.foldr (n + 1) f x = Fin.foldr n (fun (x : Fin n) => f x.castSucc) (f (Fin.last n) x)
theorem Fin.foldr_eq_foldrM {n : Nat} {α : Type u_1} (f : Fin nαα) (x : α) :
Fin.foldr n f x = Fin.foldrM n f x
theorem Fin.foldr_eq_foldr_list {n : Nat} {α : Type u_1} (f : Fin nαα) (x : α) :
theorem Fin.foldl_rev {n : Nat} {α : Sort u_1} (f : Fin nαα) (x : α) :
Fin.foldl n (fun (x : α) (i : Fin n) => f i.rev x) x = Fin.foldr n f x
theorem Fin.foldr_rev {α : Sort u_1} {n : Nat} (f : αFin nα) (x : α) :
Fin.foldr n (fun (i : Fin n) (x : α) => f x i.rev) x = Fin.foldl n f x