Lemmas about List.toArray
. #
We prefer to pull List.toArray
outwards.
Unapplied variant of push_toArray
, useful for monadic reasoning.
Variant of foldrM_toArray
with a side condition for the start
argument.
Variant of foldlM_toArray
with a side condition for the stop
argument.
Variant of foldr_toArray
with a side condition for the start
argument.
Variant of foldl_toArray
with a side condition for the stop
argument.
Variant of foldrM_push
with the start := arr.size + 1
rather than (arr.push a).size
.
Variant of foldr_push
with the start := arr.size + 1
rather than (arr.push a).size
.
A more efficient version of arr.toList.reverse
.
Equations
- arr.toListRev = Array.foldl (fun (l : List α) (t : α) => t :: l) [] arr
Instances For
uset #
get #
set #
setD #
ofFn #
foldl / foldr #
map #
modify #
filter #
filterMap #
empty #
append #
flatten #
extract #
any #
all #
contains #
Equations
- Array.instDecidableMemOfDecidableEq a as = decidable_of_iff (as.contains a = true) ⋯
swap #
More theorems about List.toArray
, followed by an Array
operation. #
Our goal is to have simp
"pull List.toArray
outwards" as much as possible.
Variant of anyM_toArray
with a side condition on stop
.
Variant of any_toArray
with a side condition on stop
.
Variant of allM_toArray
with a side condition on stop
.
Variant of all_toArray
with a side condition on stop
.