Documentation

Mathlib.Logic.Equiv.List

Equivalences involving List-like types #

This file defines some additional constructive equivalences using Encodable and the pairing function on .

def Encodable.encodeList {α : Type u_1} [Encodable α] :
List α

Explicit encoding function for List α

Equations
@[irreducible]
def Encodable.decodeList {α : Type u_1} [Encodable α] :
Option (List α)

Explicit decoding function for List α

Equations
instance List.encodable {α : Type u_1} [Encodable α] :

If α is encodable, then so is List α. This uses the pair and unpair functions from Data.Nat.Pairing.

Equations
instance List.countable {α : Type u_2} [Countable α] :
@[simp]
theorem Encodable.encode_list_nil {α : Type u_1} [Encodable α] :
@[simp]
theorem Encodable.encode_list_cons {α : Type u_1} [Encodable α] (a : α) (l : List α) :
@[simp]
def Encodable.decodeMultiset {α : Type u_1} [Encodable α] (n : ) :

Explicit decoding function for Multiset α

Equations
instance Multiset.encodable {α : Type u_1} [Encodable α] :

If α is encodable, then so is Multiset α.

Equations
instance Multiset.countable {α : Type u_2} [Countable α] :

If α is countable, then so is Multiset α.

def Encodable.encodableOfList {α : Type u_1} [DecidableEq α] (l : List α) (H : ∀ (x : α), x l) :

A listable type with decidable equality is encodable.

Equations

A finite type is encodable. Because the encoding is not unique, we wrap it in Trunc to preserve computability.

Equations
  • One or more equations did not get rendered due to their size.
noncomputable def Fintype.toEncodable (α : Type u_2) [Fintype α] :

A noncomputable way to arbitrarily choose an ordering on a finite type. It is not made into a global instance, since it involves an arbitrary choice. This can be locally made into an instance with attribute [local instance] Fintype.toEncodable.

Equations

If α is encodable, then so is Vector α n.

Equations

If α is countable, then so is Vector α n.

instance Encodable.finArrow {α : Type u_1} [Encodable α] {n : } :
Encodable (Fin nα)

If α is encodable, then so is Fin n → α.

Equations
instance Encodable.finPi (n : ) (π : Fin nType u_2) [(i : Fin n) → Encodable (π i)] :
Encodable ((i : Fin n) → π i)
Equations
instance Finset.encodable {α : Type u_1} [Encodable α] :

If α is encodable, then so is Finset α.

Equations
  • One or more equations did not get rendered due to their size.
instance Finset.countable {α : Type u_1} [Countable α] :

If α is countable, then so is Finset α.

def Encodable.fintypeArrow (α : Type u_2) (β : Type u_3) [DecidableEq α] [Fintype α] [Encodable β] :
Trunc (Encodable (αβ))

When α is finite and β is encodable, α → β is encodable too. Because the encoding is not unique, we wrap it in Trunc to preserve computability.

Equations
def Encodable.fintypePi (α : Type u_2) (π : αType u_3) [DecidableEq α] [Fintype α] [(a : α) → Encodable (π a)] :
Trunc (Encodable ((a : α) → π a))

When α is finite and all π a are encodable, Π a, π a is encodable too. Because the encoding is not unique, we wrap it in Trunc to preserve computability.

Equations
  • One or more equations did not get rendered due to their size.
def Encodable.sortedUniv (α : Type u_2) [Fintype α] [Encodable α] :
List α

The elements of a Fintype as a sorted list.

Equations
@[simp]
theorem Encodable.mem_sortedUniv {α : Type u_2} [Fintype α] [Encodable α] (x : α) :
@[simp]
instance Encodable.fintypeArrowOfEncodable {α : Type u_2} {β : Type u_3} [Encodable α] [Fintype α] [Encodable β] :
Encodable (αβ)

If α and β are encodable and α is a fintype, then α → β is encodable as well.

Equations
@[irreducible]

If α is denumerable, then so is List α.

Equations
@[simp]
theorem Denumerable.list_ofNat_zero {α : Type u_1} [Denumerable α] :
ofNat (List α) 0 = []
@[simp]
theorem Denumerable.list_ofNat_succ {α : Type u_1} [Denumerable α] (v : ) :
ofNat (List α) v.succ = ofNat α (Nat.unpair v).1 :: ofNat (List α) (Nat.unpair v).2

Outputs the list of differences of the input list, that is lower [a₁, a₂, ...] n = [a₁ - n, a₂ - a₁, ...]

Equations

Outputs the list of partial sums of the input list, that is raise [a₁, a₂, ...] n = [n + a₁, n + a₁ + a₂, ...]

Equations
theorem Denumerable.lower_raise (l : List ) (n : ) :
lower (raise l n) n = l
theorem Denumerable.raise_lower {l : List } {n : } :
List.Sorted (fun (x1 x2 : ) => x1 x2) (n :: l)raise (lower l n) n = l
theorem Denumerable.raise_chain (l : List ) (n : ) :
List.Chain (fun (x1 x2 : ) => x1 x2) n (raise l n)
theorem Denumerable.raise_sorted (l : List ) (n : ) :
List.Sorted (fun (x1 x2 : ) => x1 x2) (raise l n)

raise l n is a non-decreasing sequence.

If α is denumerable, then so is Multiset α. Warning: this is not the same encoding as used in Multiset.encodable.

Equations
  • One or more equations did not get rendered due to their size.

Outputs the list of differences minus one of the input list, that is lower' [a₁, a₂, a₃, ...] n = [a₁ - n, a₂ - a₁ - 1, a₃ - a₂ - 1, ...].

Equations

Outputs the list of partial sums plus one of the input list, that is raise [a₁, a₂, a₃, ...] n = [n + a₁, n + a₁ + a₂ + 1, n + a₁ + a₂ + a₃ + 2, ...]. Adding one each time ensures the elements are distinct.

Equations
theorem Denumerable.lower_raise' (l : List ) (n : ) :
lower' (raise' l n) n = l
theorem Denumerable.raise_lower' {l : List } {n : } :
(∀ ml, n m)List.Sorted (fun (x1 x2 : ) => x1 < x2) lraise' (lower' l n) n = l
theorem Denumerable.raise'_chain (l : List ) {m n : } :
m < nList.Chain (fun (x1 x2 : ) => x1 < x2) m (raise' l n)
theorem Denumerable.raise'_sorted (l : List ) (n : ) :
List.Sorted (fun (x1 x2 : ) => x1 < x2) (raise' l n)

raise' l n is a strictly increasing sequence.

Makes raise' l n into a finset. Elements are distinct thanks to raise'_sorted.

Equations
instance Denumerable.finset {α : Type u_1} [Denumerable α] :

If α is denumerable, then so is Finset α. Warning: this is not the same encoding as used in Finset.encodable.

Equations
  • One or more equations did not get rendered due to their size.

The type lists on unit is canonically equivalent to the natural numbers.

Equations
def Equiv.listEquivSelfOfEquivNat {α : Type u_1} (e : α ) :
List α α

If α is equivalent to , then List α is equivalent to α.

Equations