Documentation

Batteries.Data.Vector.Basic

Vectors #

Vector α n is a thin wrapper around Array α for arrays of fixed size n.

@[deprecated Vector.size_toArray (since := "2024-10-15")]
theorem Vector.size_eq {α : Type u} {n : Nat} (self : Vector α n) :
self.size = n

Alias of Vector.size_toArray.


Array size.

@[deprecated Vector.set (since := "2024-11-25")]
def Vector.setN {α : Type u_1} {n : Nat} (v : Vector α n) (i : Nat) (x : α) (h : i < n := by get_elem_tactic) :
Vector α n

Alias of Vector.set.


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.

Equations
Instances For
    @[deprecated Vector.setIfInBounds (since := "2024-11-25")]
    def Vector.setD {α : Type u_1} {n : Nat} (v : Vector α n) (i : Nat) (x : α) :
    Vector α n

    Alias of Vector.setIfInBounds.


    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
    Instances For
      @[deprecated Vector.swap (since := "2024-11-24")]
      def Vector.swapN {α : Type u_1} {n : Nat} (v : Vector α n) (i j : Nat) (hi : i < n := by get_elem_tactic) (hj : j < n := by get_elem_tactic) :
      Vector α n

      Alias of Vector.swap.


      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.

      Equations
      Instances For
        @[deprecated Vector.swapIfInBounds (since := "2024-11-24")]
        def Vector.swap! {α : Type u_1} {n : Nat} (v : Vector α n) (i j : Nat) :
        Vector α n

        Alias of Vector.swapIfInBounds.


        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
        Instances For
          @[deprecated Vector.swapAt (since := "2024-11-24")]
          def Vector.swapAtN {α : Type u_1} {n : Nat} (v : Vector α n) (i : Nat) (x : α) (hi : i < n := by get_elem_tactic) :
          α × Vector α n

          Alias of Vector.swapAt.


          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
            @[deprecated Vector.take (since := "2024-10-22")]
            def Vector.shrink {α : Type u_1} {n : Nat} (v : Vector α n) (m : Nat) :
            Vector α (min m n)

            Alias of Vector.take.


            Extract the first m elements of a vector. If m is greater than or equal to the size of the vector then the vector is returned unchanged.

            Equations
            Instances For
              @[deprecated Vector.eraseIdx (since := "2024-11-20")]
              def Vector.eraseIdxN {α : Type u_1} {n : Nat} (v : Vector α n) (i : Nat) (h : i < n := by get_elem_tactic) :
              Vector α (n - 1)

              Alias of Vector.eraseIdx.


              Delete an element of a vector using a Nat index and a tactic provided proof.

              Equations
              Instances For
                @[deprecated "Use `#v[]`." (since := "2024-11-27")]
                def Vector.empty (α : Type u) :
                Vector α 0

                Use #v[] instead.

                Equations
                Instances For
                  @[inline]
                  def Vector.allDiff {α : Type u_1} {n : Nat} [BEq α] (as : Vector α n) :

                  Returns true when all elements of the vector are pairwise distinct using == for comparison.

                  Equations
                  • as.allDiff = as.allDiff
                  Instances For