Documentation

Mathlib.Data.Fin.Tuple.Take

Take operations on tuples #

We define the take operation on n-tuples, which restricts a tuple to its first m elements.

def Fin.take {n : } {α : Fin nSort u_1} (m : ) (h : m n) (v : (i : Fin n) → α i) (i : Fin m) :
α (castLE h i)

Take the first m elements of an n-tuple where m ≤ n, returning an m-tuple.

Equations
    Instances For
      @[simp]
      theorem Fin.take_apply {n : } {α : Fin nSort u_1} (m : ) (h : m n) (v : (i : Fin n) → α i) (i : Fin m) :
      take m h v i = v (castLE h i)
      @[simp]
      theorem Fin.take_zero {n : } {α : Fin nSort u_1} (v : (i : Fin n) → α i) :
      take 0 v = fun (i : Fin 0) => i.elim0
      @[simp]
      theorem Fin.take_one {n : } {α : Fin (n + 1)Sort u_2} (v : (i : Fin (n + 1)) → α i) :
      take 1 v = fun (i : Fin 1) => v (castLE i)
      @[simp]
      theorem Fin.take_eq_init {n : } {α : Fin (n + 1)Sort u_2} (v : (i : Fin (n + 1)) → α i) :
      take n v = init v
      @[simp]
      theorem Fin.take_eq_self {n : } {α : Fin nSort u_1} (v : (i : Fin n) → α i) :
      take n v = v
      @[simp]
      theorem Fin.take_take {n : } {α : Fin nSort u_1} {m n' : } (h : m n') (h' : n' n) (v : (i : Fin n) → α i) :
      take m h (take n' h' v) = take m v
      @[simp]
      theorem Fin.take_init {n : } {α : Fin (n + 1)Sort u_2} (m : ) (h : m n) (v : (i : Fin (n + 1)) → α i) :
      take m h (init v) = take m v
      theorem Fin.take_repeat {n : } {α : Type u_2} {n' : } (m : ) (h : m n) (a : Fin n'α) :
      take (m * n') («repeat» n a) = «repeat» m a
      theorem Fin.take_succ_eq_snoc {n : } {α : Fin nSort u_1} (m : ) (h : m < n) (v : (i : Fin n) → α i) :
      take m.succ h v = snoc (take m v) (v m, h)

      Taking m + 1 elements is equal to taking m elements and adding the (m + 1)th one.

      @[simp]
      theorem Fin.take_update_of_lt {n : } {α : Fin nSort u_1} (m : ) (h : m n) (v : (i : Fin n) → α i) (i : Fin m) (x : α (castLE h i)) :
      take m h (Function.update v (castLE h i) x) = Function.update (take m h v) i x

      take commutes with update for indices in the range of take.

      @[simp]
      theorem Fin.take_update_of_ge {n : } {α : Fin nSort u_1} (m : ) (h : m n) (v : (i : Fin n) → α i) (i : Fin n) (hi : i m) (x : α i) :
      take m h (Function.update v i x) = take m h v

      take is the same after update for indices outside the range of take.

      theorem Fin.take_addCases_left {n n' : } {motive : Fin (n + n')Sort u_2} (m : ) (h : m n) (u : (i : Fin n) → motive (castAdd n' i)) (v : (i : Fin n') → motive (natAdd n i)) :
      (take m fun (i : Fin (n + n')) => addCases u v i) = take m h u

      Taking the first m ≤ n elements of an addCases u v, where u is a n-tuple, is the same as taking the first m elements of u.

      theorem Fin.take_append_left {n n' : } {α : Sort u_2} (m : ) (h : m n) (u : Fin nα) (v : Fin n'α) :
      take m (append u v) = take m h u

      Version of take_addCases_left that specializes addCases to append.

      theorem Fin.take_addCases_right {n n' : } {motive : Fin (n + n')Sort u_2} (m : ) (h : m n') (u : (i : Fin n) → motive (castAdd n' i)) (v : (i : Fin n') → motive (natAdd n i)) :
      (take (n + m) fun (i : Fin (n + n')) => addCases u v i) = fun (i : Fin (n + m)) => addCases u (take m h v) i

      Taking the first n + m elements of an addCases u v, where v is a n'-tuple and m ≤ n', is the same as appending u with the first m elements of v.

      theorem Fin.take_append_right {n n' : } {α : Sort u_2} (m : ) (h : m n') (u : Fin nα) (v : Fin n'α) :
      take (n + m) (append u v) = append u (take m h v)

      Version of take_addCases_right that specializes addCases to append.

      theorem Fin.ofFn_take_eq_take_ofFn {n : } {α : Type u_2} {m : } (h : m n) (v : Fin nα) :

      Fin.take intertwines with List.take via List.ofFn.

      theorem Fin.ofFn_take_get {α : Type u_2} {m : } (l : List α) (h : m l.length) :

      Alternative version of take_eq_take_list_ofFn with l : List α instead of v : Fin n → α.

      theorem Fin.get_take_eq_take_get_comp_cast {α : Type u_2} {m : } (l : List α) (h : m l.length) :
      (List.take m l).get = take m h l.get Fin.cast

      Fin.take intertwines with List.take via List.get.

      theorem Fin.get_take_ofFn_eq_take_comp_cast {n : } {α : Type u_2} {m : } (v : Fin nα) (h : m n) :

      Alternative version of take_eq_take_list_get with v : Fin n → α instead of l : List α.