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) :
α (Fin.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) :
    Fin.take m h v i = v (Fin.castLE h i)
    @[simp]
    theorem Fin.take_zero {n : } {α : Fin nSort u_1} (v : (i : Fin n) → α i) :
    Fin.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) :
    Fin.take 1 v = fun (i : Fin 1) => v (Fin.castLE i)
    @[simp]
    theorem Fin.take_eq_init {n : } {α : Fin (n + 1)Sort u_2} (v : (i : Fin (n + 1)) → α i) :
    Fin.take n v = Fin.init v
    @[simp]
    theorem Fin.take_eq_self {n : } {α : Fin nSort u_1} (v : (i : Fin n) → α i) :
    Fin.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) :
    Fin.take m h (Fin.take n' h' v) = Fin.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) :
    Fin.take m h (Fin.init v) = Fin.take m v
    theorem Fin.take_repeat {n : } {α : Type u_2} {n' : } (m : ) (h : m n) (a : Fin n'α) :
    Fin.take (m * n') (Fin.repeat n a) = Fin.repeat m a
    theorem Fin.take_succ_eq_snoc {n : } {α : Fin nSort u_1} (m : ) (h : m < n) (v : (i : Fin n) → α i) :
    Fin.take m.succ h v = Fin.snoc (Fin.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 : α (Fin.castLE h i)) :

    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 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 (Fin.castAdd n' i)) (v : (i : Fin n') → motive (Fin.natAdd n i)) :
    (Fin.take m fun (i : Fin (n + n')) => Fin.addCases u v i) = Fin.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'α) :
    Fin.take m (Fin.append u v) = Fin.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 (Fin.castAdd n' i)) (v : (i : Fin n') → motive (Fin.natAdd n i)) :
    (Fin.take (n + m) fun (i : Fin (n + n')) => Fin.addCases u v i) = fun (i : Fin (n + m)) => Fin.addCases u (Fin.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'α) :
    Fin.take (n + m) (Fin.append u v) = Fin.append u (Fin.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) :
    List.ofFn (Fin.take m h l.get) = List.take m l

    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 = Fin.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) :
    (List.take m (List.ofFn v)).get = Fin.take m h v Fin.cast

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