Bootstrapping theorems about arrays #
This file contains some theorems about Array
and List
needed for Init.Data.List.Impl
.
@[irreducible]
theorem
Array.foldlM_toList.aux
{m : Type u_1 → Type u_2}
{β : Type u_1}
{α : Type u_3}
[Monad m]
(f : β → α → m β)
(arr : Array α)
(i j : Nat)
(H : arr.size ≤ i + j)
(b : β)
:
Array.foldlM.loop f arr arr.size ⋯ i j b = List.foldlM f b (List.drop j arr.toList)
@[simp]
theorem
Array.foldlM_toList
{m : Type u_1 → Type u_2}
{β : Type u_1}
{α : Type u_3}
[Monad m]
(f : β → α → m β)
(init : β)
(arr : Array α)
:
List.foldlM f init arr.toList = Array.foldlM f init arr
@[simp]
theorem
Array.foldl_toList
{β : Type u_1}
{α : Type u_2}
(f : β → α → β)
(init : β)
(arr : Array α)
:
List.foldl f init arr.toList = Array.foldl f init arr
theorem
Array.foldrM_eq_reverse_foldlM_toList.aux
{m : Type u_1 → Type u_2}
{α : Type u_3}
{β : Type u_1}
[Monad m]
(f : α → β → m β)
(arr : Array α)
(init : β)
(i : Nat)
(h : i ≤ arr.size)
:
List.foldlM (fun (x : β) (y : α) => f y x) init (List.take i arr.toList).reverse = Array.foldrM.fold f arr 0 i h init
theorem
Array.foldrM_eq_reverse_foldlM_toList
{m : Type u_1 → Type u_2}
{α : Type u_3}
{β : Type u_1}
[Monad m]
(f : α → β → m β)
(init : β)
(arr : Array α)
:
Array.foldrM f init arr = List.foldlM (fun (x : β) (y : α) => f y x) init arr.toList.reverse
@[simp]
theorem
Array.foldrM_toList
{m : Type u_1 → Type u_2}
{α : Type u_3}
{β : Type u_1}
[Monad m]
(f : α → β → m β)
(init : β)
(arr : Array α)
:
List.foldrM f init arr.toList = Array.foldrM f init arr
@[simp]
theorem
Array.foldr_toList
{α : Type u_1}
{β : Type u_2}
(f : α → β → β)
(init : β)
(arr : Array α)
:
List.foldr f init arr.toList = Array.foldr f init arr
@[simp]
@[simp]
@[deprecated "Use the reverse direction of `foldrM_toList`." (since := "2024-11-13")]
theorem
Array.foldrM_eq_foldrM_toList
{m : Type u_1 → Type u_2}
{α : Type u_3}
{β : Type u_1}
[Monad m]
(f : α → β → m β)
(init : β)
(arr : Array α)
:
Array.foldrM f init arr = List.foldrM f init arr.toList
@[deprecated "Use the reverse direction of `foldlM_toList`." (since := "2024-11-13")]
theorem
Array.foldlM_eq_foldlM_toList
{m : Type u_1 → Type u_2}
{β : Type u_1}
{α : Type u_3}
[Monad m]
(f : β → α → m β)
(init : β)
(arr : Array α)
:
Array.foldlM f init arr = List.foldlM f init arr.toList
@[deprecated "Use the reverse direction of `foldr_toList`." (since := "2024-11-13")]
theorem
Array.foldr_eq_foldr_toList
{α : Type u_1}
{β : Type u_2}
(f : α → β → β)
(init : β)
(arr : Array α)
:
Array.foldr f init arr = List.foldr f init arr.toList
@[deprecated "Use the reverse direction of `foldl_toList`." (since := "2024-11-13")]
theorem
Array.foldl_eq_foldl_toList
{β : Type u_1}
{α : Type u_2}
(f : β → α → β)
(init : β)
(arr : Array α)
:
Array.foldl f init arr = List.foldl f init arr.toList
@[reducible, inline, deprecated Array.foldlM_toList (since := "2024-09-09")]
abbrev
Array.foldlM_eq_foldlM_data
{m : Type u_1 → Type u_2}
{β : Type u_1}
{α : Type u_3}
[Monad m]
(f : β → α → m β)
(init : β)
(arr : Array α)
:
List.foldlM f init arr.toList = Array.foldlM f init arr
Instances For
@[reducible, inline, deprecated Array.foldl_toList (since := "2024-09-09")]
abbrev
Array.foldl_eq_foldl_data
{β : Type u_1}
{α : Type u_2}
(f : β → α → β)
(init : β)
(arr : Array α)
:
List.foldl f init arr.toList = Array.foldl f init arr
Instances For
@[reducible, inline, deprecated Array.foldrM_eq_reverse_foldlM_toList (since := "2024-09-09")]
abbrev
Array.foldrM_eq_reverse_foldlM_data
{m : Type u_1 → Type u_2}
{α : Type u_3}
{β : Type u_1}
[Monad m]
(f : α → β → m β)
(init : β)
(arr : Array α)
:
Array.foldrM f init arr = List.foldlM (fun (x : β) (y : α) => f y x) init arr.toList.reverse
Instances For
@[reducible, inline, deprecated Array.foldrM_toList (since := "2024-09-09")]
abbrev
Array.foldrM_eq_foldrM_data
{m : Type u_1 → Type u_2}
{α : Type u_3}
{β : Type u_1}
[Monad m]
(f : α → β → m β)
(init : β)
(arr : Array α)
:
List.foldrM f init arr.toList = Array.foldrM f init arr
Instances For
@[reducible, inline, deprecated Array.foldr_toList (since := "2024-09-09")]
abbrev
Array.foldr_eq_foldr_data
{α : Type u_1}
{β : Type u_2}
(f : α → β → β)
(init : β)
(arr : Array α)
:
List.foldr f init arr.toList = Array.foldr f init arr
Instances For
@[reducible, inline, deprecated Array.push_toList (since := "2024-09-09")]
Equations
Instances For
@[reducible, inline, deprecated Array.toListImpl_eq (since := "2024-09-09")]
Equations
Instances For
@[reducible, inline, deprecated Array.pop_toList (since := "2024-09-09")]
Equations
Instances For
@[reducible, inline, deprecated Array.toList_append (since := "2024-09-09")]
Equations
Instances For
@[reducible, inline, deprecated Array.appendList_toList (since := "2024-09-09")]