clamp #
enum/list #
foldlM #
theorem
Fin.foldlM_loop_lt
{m : Type u_1 → Type u_2}
{α : Type u_1}
{n i : Nat}
[Monad m]
(f : α → Fin n → m α)
(x : α)
(h : i < n)
:
Fin.foldlM.loop n f x i = do
let x ← f x ⟨i, h⟩
Fin.foldlM.loop n f x (i + 1)
@[simp]
theorem
Fin.foldlM_zero
{m : Type u_1 → Type u_2}
{α : Type u_1}
[Monad m]
(f : α → Fin 0 → m α)
(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 n → m α)
(x : α)
:
Fin.foldlM n f x = List.foldlM f x (Fin.list n)
foldrM #
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, ⋯⟩
@[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 : α)
:
Fin.foldrM n f x = List.foldrM f x (Fin.list n)
foldl #
theorem
Fin.foldl_loop_lt
{α : Sort u_1}
{n 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 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
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 : α)
:
Fin.foldl n f x = List.foldl f x (Fin.list n)
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_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 : α)
:
Fin.foldr n f x = List.foldr f x (Fin.list n)