Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- instReprVector = { reprPrec := instReprVector.repr }
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
Custom eliminator for Vector α n through List α
Equations
- Vector.elimAsList mk (Vector.mk { toList := xs } ha) = mk xs ha
Instances For
Make an empty vector with pre-allocated capacity.
Equations
- Vector.emptyWithCapacity capacity = Vector.mk (Array.emptyWithCapacity capacity) ⋯
Instances For
Make an empty vector with pre-allocated capacity.
Equations
Instances For
Makes a vector of size n with all cells containing v.
Equations
- Vector.replicate n v = Vector.mk (Array.replicate n v) ⋯
Instances For
Equations
Instances For
Returns a vector of size 1 with element v.
Equations
Instances For
Equations
- Vector.instInhabited = { default := Vector.replicate n default }
Equations
- Vector.instMembership = { mem := Vector.Mem }
Set an element in a vector using a Nat index, with a tactic provided proof that the index is in
bounds.
This will perform the update destructively provided that the vector has a reference count of 1.
Instances For
Set an element in a vector using a Nat index. Returns the vector unchanged if the index is out of
bounds.
This will perform the update destructively provided that the vector has a reference count of 1.
Equations
- xs.setIfInBounds i x = Vector.mk (xs.toArray.setIfInBounds i x) ⋯
Instances For
Set an element in a vector using a Nat index. Panics if the index is out of bounds.
This will perform the update destructively provided that the vector has a reference count of 1.
Instances For
Equations
- Vector.foldlM f b xs = Array.foldlM f b xs.toArray
Instances For
Equations
- Vector.foldrM f b xs = Array.foldrM f b xs.toArray
Instances For
Equations
- Vector.foldl f b xs = Array.foldl f b xs.toArray
Instances For
Equations
- Vector.foldr f b xs = Array.foldr f b xs.toArray
Instances For
Equations
- Vector.instHAppendHAddNat = { hAppend := Vector.append }
Extracts the slice of a vector from indices start to stop (exclusive). If start ≥ stop, the
result is empty. If stop is greater than the size of the vector, the size is used instead.
Instances For
Extract the first i elements of a vector. If i is greater than or equal to the size of the
vector then the vector is returned unchanged.
We immediately simplify this to the extract operation, so there is no verification API for this function.
Instances For
Deletes the first i elements of a vector. If i is greater than or equal to the size of the
vector then the empty vector is returned.
We immediately simplify this to the extract operation, so there is no verification API for this function.
Instances For
Shrinks a vector to the first m elements, by repeatedly popping the last element.
We immediately simplify this to the extract operation, so there is no verification API for this function.
Instances For
Maps elements of a vector using the function f, which also receives the index of the element.
Equations
- Vector.mapIdx f xs = Vector.mk (Array.mapIdx f xs.toArray) ⋯
Instances For
Maps elements of a vector using the function f,
which also receives the index of the element, and the fact that the index is less than the size of the vector.
Equations
Instances For
Map a monadic function over a vector.
Equations
- Vector.mapM f xs = Vector.mapM.go✝ f xs 0 ⋯ #v[]
Instances For
Variant of mapIdxM which receives the index i along with the bound `i < n.
Equations
- xs.mapFinIdxM f = Vector.mapFinIdxM.map xs f n 0 ⋯ (Vector.cast ⋯ #v[])
Instances For
Equations
- Vector.mapFinIdxM.map xs f 0 j x ys_2 = pure ys_2
- Vector.mapFinIdxM.map xs f i_2.succ j inv_2 ys_2 = do let __do_lift ← f j xs[j] ⋯ Vector.mapFinIdxM.map xs f i_2 (j + 1) ⋯ (Vector.cast ⋯ (ys_2.push __do_lift))
Instances For
Equations
- Vector.firstM f xs = Array.firstM f xs.toArray
Instances For
Maps corresponding elements of two vectors of equal size using the function f.
Equations
- Vector.zipWith f as bs = Vector.mk (Array.zipWith f as.toArray bs.toArray) ⋯
Instances For
The vector of length n whose i-th element is f i.
Equations
- Vector.ofFn f = Vector.mk (Array.ofFn f) ⋯
Instances For
See also Vector.ofFnM defined in Init.Data.Vector.OfFn.
Swap two elements of a vector using Fin indices.
This will perform the update destructively provided that the vector has a reference count of 1.
Instances For
Swap two elements of a vector using Nat indices. Panics if either index is out of bounds.
This will perform the update destructively provided that the vector has a reference count of 1.
Equations
- xs.swapIfInBounds i j = Vector.mk (xs.toArray.swapIfInBounds i j) ⋯
Instances For
Swaps an element of a vector with a given value using a Fin index. The original value is returned
along with the updated vector.
This will perform the update destructively provided that the vector has a reference count of 1.
Equations
Instances For
Swaps an element of a vector with a given value using a Nat index. Panics if the index is out of
bounds. The original value is returned along with the updated vector.
This will perform the update destructively provided that the vector has a reference count of 1.
Instances For
The vector #v[0, 1, 2, ..., n-1].
Equations
- Vector.range n = Vector.mk (Array.range n) ⋯
Instances For
The vector #v[start, start + step, start + 2 * step, ..., start + (size - 1) * step].
Equations
- Vector.range' start size step = Vector.mk (Array.range' start size step) ⋯
Instances For
Compares two vectors of the same size using a given boolean relation r. isEqv v w r returns
true if and only if r v[i] w[i] is true for all indices i.
Instances For
Delete an element of a vector using a Nat index. Panics if the index is out of bounds.
Equations
Instances For
Delete the first element of a vector. Returns the empty vector if the input vector is empty.
We immediately simplify this to the extract operation, so there is no verification API for this function.
Equations
- xs.tail = Vector.cast ⋯ (xs.extract 1)
Instances For
Finds the first index of a given value in a vector using == for comparison. Returns none if the
no element of the index matches the given value.
Instances For
Finds the first index of a given value in a vector using a predicate. Returns none if the
no element of the index matches the given value.
Equations
- Vector.findFinIdx? p xs = Option.map (Fin.cast ⋯) (Array.findFinIdx? p xs.toArray)
Instances For
Note that the universe level is constrained to Type here,
to avoid having to have the predicate live in p : α → m (ULift Bool).
Equations
- Vector.findM? f as = Array.findM? f as.toArray
Instances For
Equations
- Vector.findSomeM? f as = Array.findSomeM? f as.toArray
Instances For
Note that the universe level is constrained to Type here,
to avoid having to have the predicate live in p : α → m (ULift Bool).
Equations
- Vector.findRevM? f as = Array.findRevM? f as.toArray
Instances For
Equations
- Vector.findSomeRevM? f as = Array.findSomeRevM? f as.toArray
Instances For
Equations
- Vector.findSome? f as = Array.findSome? f as.toArray
Instances For
Equations
- Vector.findSomeRev? f as = Array.findSomeRev? f as.toArray
Instances For
Returns true when xs is a prefix of the vector ys.
Equations
- xs.isPrefixOf ys = xs.toArray.isPrefixOf ys.toArray
Instances For
Returns true with the monad if p returns true for any element of the vector.
Equations
- Vector.anyM p xs = Array.anyM p xs.toArray
Instances For
Returns true with the monad if p returns true for all elements of the vector.
Equations
- Vector.allM p xs = Array.allM p xs.toArray
Instances For
Count the number of elements of a vector that satisfy the predicate p.
Equations
- Vector.countP p xs = Array.countP p xs.toArray
Instances For
Count the number of elements of a vector that are equal to a.
Equations
- Vector.count a xs = Array.count a xs.toArray
Instances For
Pad a vector on the left with a given element.
Note that we immediately simplify this to an ++ operation,
and do not provide separate verification theorems.
Equations
- Vector.leftpad n a xs = Vector.cast ⋯ (Vector.replicate (n - m) a ++ xs)
Instances For
Pad a vector on the right with a given element.
Note that we immediately simplify this to an ++ operation,
and do not provide separate verification theorems.
Equations
- Vector.rightpad n a xs = Vector.cast ⋯ (xs ++ Vector.replicate (n - m) a)
Instances For
ForIn instance #
Equations
- One or more equations did not get rendered due to their size.
ForM instance #
Equations
- Vector.instForM = { forM := fun [Monad m] => Vector.forM }
ToStream instance #
Equations
- Vector.instToStreamSubarray = { toStream := fun (xs : Vector α n) => Std.Slice.Sliceable.mkSlice xs.toArray *...* }
Lexicographic ordering #
Lexicographic comparator for vectors.
lex v w lt is true if
- vis pairwise equivalent via- ==to- w, or
- there is an index isuch thatlt v[i] w[i], and for allj < i,v[j] == w[j].
Equations
- One or more equations did not get rendered due to their size.