Operation on tuples #
We interpret maps ∀ i : Fin n, α i as n-tuples of elements of possibly varying type α i,
(α 0, …, α (n-1)). A particular case is Fin n → α of elements with all the same type.
In this case when α i is a constant map, then tuples are isomorphic (but not definitionally equal)
to Vectors.
Main declarations #
There are three (main) ways to consider Fin n as a subtype of Fin (n + 1), hence three (main)
ways to move between tuples of length n and of length n + 1 by adding/removing an entry.
Adding at the start #
- Fin.succ: Send- i : Fin nto- i + 1 : Fin (n + 1). This is defined in Core.
- Fin.cases: Induction/recursion principle for- Fin: To prove a property/define a function for all- Fin (n + 1), it is enough to prove/define it for- 0and for- i.succfor all- i : Fin n. This is defined in Core.
- Fin.cons: Turn a tuple- f : Fin n → αand an entry- a : αinto a tuple- Fin.cons a f : Fin (n + 1) → αby adding- aat the start. In general, tuples can be dependent functions, in which case- f : ∀ i : Fin n, α i.succand- a : α 0. This is a special case of- Fin.cases.
- Fin.tail: Turn a tuple- f : Fin (n + 1) → αinto a tuple- Fin.tail f : Fin n → αby forgetting the start. In general, tuples can be dependent functions, in which case- Fin.tail f : ∀ i : Fin n, α i.succ.
Adding at the end #
- Fin.castSucc: Send- i : Fin nto- i : Fin (n + 1). This is defined in Core.
- Fin.lastCases: Induction/recursion principle for- Fin: To prove a property/define a function for all- Fin (n + 1), it is enough to prove/define it for- last nand for- i.castSuccfor all- i : Fin n. This is defined in Core.
- Fin.snoc: Turn a tuple- f : Fin n → αand an entry- a : αinto a tuple- Fin.snoc f a : Fin (n + 1) → αby adding- aat the end. In general, tuples can be dependent functions, in which case- f : ∀ i : Fin n, α i.castSuccand- a : α (last n). This is a special case of- Fin.lastCases.
- Fin.init: Turn a tuple- f : Fin (n + 1) → αinto a tuple- Fin.init f : Fin n → αby forgetting the start. In general, tuples can be dependent functions, in which case- Fin.init f : ∀ i : Fin n, α i.castSucc.
Adding in the middle #
For a pivot p : Fin (n + 1),
- Fin.succAbove: Send- i : Fin nto
- Fin.succAboveCases: Induction/recursion principle for- Fin: To prove a property/define a function for all- Fin (n + 1), it is enough to prove/define it for- pand for- p.succAbove ifor all- i : Fin n.
- Fin.insertNth: Turn a tuple- f : Fin n → αand an entry- a : αinto a tuple- Fin.insertNth f a : Fin (n + 1) → αby adding- ain position- p. In general, tuples can be dependent functions, in which case- f : ∀ i : Fin n, α (p.succAbove i)and- a : α p. This is a special case of- Fin.succAboveCases.
- Fin.removeNth: Turn a tuple- f : Fin (n + 1) → αinto a tuple- Fin.removeNth p f : Fin n → αby forgetting the- p-th value. In general, tuples can be dependent functions, in which case- Fin.removeNth f : ∀ i : Fin n, α (succAbove p i).
p = 0 means we add at the start. p = last n means we add at the end.
Miscellaneous #
- Fin.find p: returns the first index- nwhere- p nis satisfied, and- noneif it is never satisfied.
- Fin.append a b: append two tuples.
- Fin.repeat n a: repeat a tuple- ntimes.
As a binary function, Fin.cons is injective.
Equivalence between tuples of length n + 1 and pairs of an element and a tuple of length n
given by separating out the first element of the tuple.
Equations
Instances For
Recurse on an n+1-tuple by splitting it into a single element and an n-tuple.
Equations
- Fin.consCases h x = cast ⋯ (h (x 0) (Fin.tail x))
Instances For
Recurse on a tuple by splitting into Fin.elim0 and Fin.cons.
Equations
- Fin.consInduction h0 h x_2 = ⋯.mpr h0
- Fin.consInduction h0 h x_2 = Fin.consCases (fun (x : α) (x_1 : Fin n → α) => h x x_1 (Fin.consInduction h0 (fun {n : ℕ} => h) x_1)) x_2
Instances For
Append a tuple of length m to a tuple of length n to get a tuple of length m + n.
This is a non-dependent version of Fin.add_cases.
Equations
- Fin.append a b = Fin.addCases a b
Instances For
Repeat a m times. For example Fin.repeat 2 ![0, 3, 7] = ![0, 3, 7, 0, 3, 7].
Equations
- Fin.repeat m a x✝ = a x✝.modNat
Instances For
In the previous section, we have discussed inserting or removing elements on the left of a
tuple. In this section, we do the same on the right. A difference is that Fin (n+1) is constructed
inductively from Fin n starting from the left, not from the right. This implies that Lean needs
more help to realize that elements belong to the right types, i.e., we need to insert casts at
several places.
Adding an element at the end of an n-tuple, to get an n+1-tuple. The name snoc comes from
cons (i.e., adding an element to the left of a tuple) read in reverse order.
Instances For
As a binary function, Fin.snoc is injective.
Equivalence between tuples of length n + 1 and pairs of an element and a tuple of length n
given by separating out the last element of the tuple.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Recurse on an n+1-tuple by splitting it its initial n-tuple and its last element.
Equations
- Fin.snocCases h x = cast ⋯ (h (Fin.init x) (x (Fin.last n)))
Instances For
Recurse on a tuple by splitting into Fin.elim0 and Fin.snoc.
Equations
- Fin.snocInduction h0 h x_2 = ⋯.mpr h0
- Fin.snocInduction h0 h x_2 = Fin.snocCases (fun (x : Fin n → α) (x_1 : α) => h x x_1 (Fin.snocInduction h0 (fun {n : ℕ} => h) x)) x_2
Instances For
Define a function on Fin (n + 1) from a value on i : Fin (n + 1) and values on each
Fin.succAbove i j, j : Fin n. This version is elaborated as eliminator and works for
propositions, see also Fin.insertNth for a version without an @[elab_as_elim]
attribute.
Equations
Instances For
Insert an element into a tuple at a given position. For i = 0 see Fin.cons,
for i = Fin.last n see Fin.snoc. See also Fin.succAboveCases for a version elaborated
as an eliminator.
Equations
- i.insertNth x p j = i.succAboveCases x p j
Instances For
As a binary function, Fin.insertNth is injective.
Equivalence between tuples of length n + 1 and pairs of an element and a tuple of length n
given by separating out the p-th element of the tuple.
This is Fin.insertNth as an Equiv.
Equations
- One or more equations did not get rendered due to their size.
Instances For
find p returns the first index n where p n is satisfied, and none if it is never
satisfied.
Equations
Instances For
If find p = some i, then p i holds
Π i : Fin 2, α i is equivalent to α 0 × α 1. See also finTwoArrowEquiv for a
non-dependent version and prodEquivPiFinTwo for a version with inputs α β : Type u.