Locally finite orders #
This file defines locally finite orders.
A locally finite order is an order for which all bounded intervals are finite. This allows to make
sense of Icc/Ico/Ioc/Ioo as lists, multisets, or finsets.
Further, if the order is bounded above (resp. below), then we can also make sense of the
"unbounded" intervals Ici/Ioi (resp. Iic/Iio).
Many theorems about these intervals can be found in Mathlib/Order/Interval/Finset/Basic.lean.
Examples #
Naturally occurring locally finite orders are ℕ, ℤ, ℕ+, Fin n, α × β the product of two
locally finite orders, α →₀ β the finitely supported functions to a locally finite order β...
Main declarations #
In a LocallyFiniteOrder,
- Finset.Icc: Closed-closed interval as a finset.
- Finset.Ico: Closed-open interval as a finset.
- Finset.Ioc: Open-closed interval as a finset.
- Finset.Ioo: Open-open interval as a finset.
- Finset.uIcc: Unordered closed interval as a finset.
In a LocallyFiniteOrderTop,
- Finset.Ici: Closed-infinite interval as a finset.
- Finset.Ioi: Open-infinite interval as a finset.
In a LocallyFiniteOrderBot,
- Finset.Iic: Infinite-open interval as a finset.
- Finset.Iio: Infinite-closed interval as a finset.
Instances #
A LocallyFiniteOrder instance can be built
- for a subtype of a locally finite order. See Subtype.locallyFiniteOrder.
- for the product of two locally finite orders. See Prod.locallyFiniteOrder.
- for any fintype (but not as an instance). See Fintype.toLocallyFiniteOrder.
- from a definition of Finset.Iccalone. SeeLocallyFiniteOrder.ofIcc.
- by pulling back LocallyFiniteOrder βthrough an order embeddingf : α →o β. SeeOrderEmbedding.locallyFiniteOrder.
Instances for concrete types are proved in their respective files:
- ℕis in- Order.Interval.Finset.Nat
- ℤis in- Data.Int.Interval
- ℕ+is in- Data.PNat.Interval
- Fin nis in- Order.Interval.Finset.Fin
- Finset αis in- Data.Finset.Interval
- Σ i, α iis in- Data.Sigma.IntervalAlong, you will find lemmas about the cardinality of those finite intervals.
TODO #
Provide the LocallyFiniteOrder instance for α ×ₗ β where LocallyFiniteOrder α and
Fintype β.
Provide the LocallyFiniteOrder instance for α →₀ β where β is locally finite. Provide the
LocallyFiniteOrder instance for Π₀ i, β i where all the β i are locally finite.
From LinearOrder α, NoMaxOrder α, LocallyFiniteOrder α, we can also define an
order isomorphism α ≃ ℕ or α ≃ ℤ, depending on whether we have OrderBot α or
NoMinOrder α and Nonempty α. When OrderBot α, we can match a : α to #(Iio a).
We can provide SuccOrder α from LinearOrder α and LocallyFiniteOrder α using
lemma exists_min_greater [LinearOrder α] [LocallyFiniteOrder α] {x ub : α} (hx : x < ub) :
    ∃ lub, x < lub ∧ ∀ y, x < y → lub ≤ y := by
  -- very non golfed
  have h : (Finset.Ioc x ub).Nonempty := ⟨ub, Finset.mem_Ioc.2 ⟨hx, le_rfl⟩⟩
  use Finset.min' (Finset.Ioc x ub) h
  constructor
  · exact (Finset.mem_Ioc.mp <| Finset.min'_mem _ h).1
  rintro y hxy
  obtain hy | hy := le_total y ub
  · refine Finset.min'_le (Ioc x ub) y ?_
    simp [*] at *
  · exact (Finset.min'_le _ _ (Finset.mem_Ioc.2 ⟨hx, le_rfl⟩)).trans hy
Note that the converse is not true. Consider {-2^z | z : ℤ} ∪ {2^z | z : ℤ}. Any element has a
successor (and actually a predecessor as well), so it is a SuccOrder, but it's not locally finite
as Icc (-1) 1 is infinite.
This is a mixin class describing a locally finite order,
that is, is an order where bounded intervals are finite.
When you don't care too much about definitional equality, you can use LocallyFiniteOrder.ofIcc or
LocallyFiniteOrder.ofFiniteIcc to build a locally finite order from just Finset.Icc.
- finsetIcc : α → α → Finset αLeft-closed right-closed interval 
- finsetIco : α → α → Finset αLeft-closed right-open interval 
- finsetIoc : α → α → Finset αLeft-open right-closed interval 
- finsetIoo : α → α → Finset αLeft-open right-open interval 
- x ∈ finsetIcc a b ↔ a ≤ x ∧ x ≤ b
- x ∈ finsetIco a b ↔ a ≤ x ∧ x < b
- x ∈ finsetIoc a b ↔ a < x ∧ x ≤ b
- x ∈ finsetIoo a b ↔ a < x ∧ x < b
Instances
This mixin class describes an order where all intervals bounded below are finite. This is
slightly weaker than LocallyFiniteOrder + OrderTop as it allows empty types.
- finsetIoi : α → Finset αLeft-open right-infinite interval 
- finsetIci : α → Finset αLeft-closed right-infinite interval 
- x ∈ finsetIci a ↔ a ≤ x
- x ∈ finsetIoi a ↔ a < x
Instances
This mixin class describes an order where all intervals bounded above are finite. This is
slightly weaker than LocallyFiniteOrder + OrderBot as it allows empty types.
- finsetIio : α → Finset αLeft-infinite right-open interval 
- finsetIic : α → Finset αLeft-infinite right-closed interval 
- x ∈ finsetIic a ↔ x ≤ a
- x ∈ finsetIio a ↔ x < a
Instances
A constructor from a definition of Finset.Icc alone, the other ones being derived by removing
the ends. As opposed to LocallyFiniteOrder.ofIcc, this one requires DecidableLE but
only Preorder.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A constructor from a definition of Finset.Icc alone, the other ones being derived by removing
the ends. As opposed to LocallyFiniteOrder.ofIcc', this one requires PartialOrder but only
DecidableEq.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A constructor from a definition of Finset.Ici alone, the other ones being derived by removing
the ends. As opposed to LocallyFiniteOrderTop.ofIci, this one requires DecidableLE but
only Preorder.
Equations
Instances For
A constructor from a definition of Finset.Ici alone, the other ones being derived by removing
the ends. As opposed to LocallyFiniteOrderTop.ofIci', this one requires PartialOrder but
only DecidableEq.
Equations
- LocallyFiniteOrderTop.ofIci α finsetIci mem_Ici = { finsetIoi := fun (a : α) => {x ∈ finsetIci a | a ≠ x}, finsetIci := finsetIci, finset_mem_Ici := mem_Ici, finset_mem_Ioi := ⋯ }
Instances For
A constructor from a definition of Finset.Iic alone, the other ones being derived by removing
the ends. As opposed to LocallyFiniteOrderBot.ofIic, this one requires DecidableLE but
only Preorder.
Equations
Instances For
A constructor from a definition of Finset.Iic alone, the other ones being derived by removing
the ends. As opposed to LocallyFiniteOrderBot.ofIic', this one requires PartialOrder but
only DecidableEq.
Equations
- LocallyFiniteOrderBot.ofIic α finsetIic mem_Iic = { finsetIio := fun (a : α) => {x ∈ finsetIic a | x ≠ a}, finsetIic := finsetIic, finset_mem_Iic := mem_Iic, finset_mem_Iio := ⋯ }
Instances For
An empty type is locally finite.
This is not an instance as it would not be defeq to more specific instances.
Equations
- One or more equations did not get rendered due to their size.
Instances For
An empty type is locally finite.
This is not an instance as it would not be defeq to more specific instances.
Equations
- IsEmpty.toLocallyFiniteOrderTop = { finsetIoi := fun (a : α) => isEmptyElim a, finsetIci := fun (a : α) => isEmptyElim a, finset_mem_Ici := ⋯, finset_mem_Ioi := ⋯ }
Instances For
An empty type is locally finite.
This is not an instance as it would not be defeq to more specific instances.
Equations
- IsEmpty.toLocallyFiniteOrderBot = { finsetIio := fun (a : α) => isEmptyElim a, finsetIic := fun (a : α) => isEmptyElim a, finset_mem_Iic := ⋯, finset_mem_Iio := ⋯ }
Instances For
Intervals as finsets #
The finset $[a, b]$ of elements x such that a ≤ x and x ≤ b. Basically Set.Icc a b as a
finset.
Equations
- Finset.Icc a b = LocallyFiniteOrder.finsetIcc a b
Instances For
The finset $[a, b)$ of elements x such that a ≤ x and x < b. Basically Set.Ico a b as a
finset.
Equations
- Finset.Ico a b = LocallyFiniteOrder.finsetIco a b
Instances For
The finset $(a, b]$ of elements x such that a < x and x ≤ b. Basically Set.Ioc a b as a
finset.
Equations
- Finset.Ioc a b = LocallyFiniteOrder.finsetIoc a b
Instances For
The finset $(a, b)$ of elements x such that a < x and x < b. Basically Set.Ioo a b as a
finset.
Equations
- Finset.Ioo a b = LocallyFiniteOrder.finsetIoo a b
Instances For
The finset $[a, ∞)$ of elements x such that a ≤ x. Basically Set.Ici a as a finset.
Equations
Instances For
The finset $(a, ∞)$ of elements x such that a < x. Basically Set.Ioi a as a finset.
Equations
Instances For
The finset $(-∞, b]$ of elements x such that x ≤ b. Basically Set.Iic b as a finset.
Equations
Instances For
The finset $(-∞, b)$ of elements x such that x < b. Basically Set.Iio b as a finset.
Equations
Instances For
Equations
- LocallyFiniteOrder.toLocallyFiniteOrderTop = { finsetIoi := fun (b : α) => Finset.Ioc b ⊤, finsetIci := fun (b : α) => Finset.Icc b ⊤, finset_mem_Ici := ⋯, finset_mem_Ioi := ⋯ }
Equations
- LocallyFiniteOrder.toLocallyFiniteOrderBot = { finsetIio := Finset.Ico ⊥, finsetIic := Finset.Icc ⊥, finset_mem_Iic := ⋯, finset_mem_Iio := ⋯ }
Finset.uIcc a b is the set of elements lying between a and b, with a and b included.
Note that we define it more generally in a lattice as Finset.Icc (a ⊓ b) (a ⊔ b). In a
product type, Finset.uIcc corresponds to the bounding box of the two elements.
Equations
- Finset.uIcc a b = Finset.Icc (a ⊓ b) (a ⊔ b)
Instances For
Finset.uIcc a b is the set of elements lying between a and b, with a and b included.
Note that we define it more generally in a lattice as Finset.Icc (a ⊓ b) (a ⊔ b). In a
product type, Finset.uIcc corresponds to the bounding box of the two elements.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Elaborate set builder notation for Finset.
- {x ≤ a | p x}is elaborated as- Finset.filter (fun x ↦ p x) (Finset.Iic a)if the expected type is- Finset ?α.
- {x ≥ a | p x}is elaborated as- Finset.filter (fun x ↦ p x) (Finset.Ici a)if the expected type is- Finset ?α.
- {x < a | p x}is elaborated as- Finset.filter (fun x ↦ p x) (Finset.Iio a)if the expected type is- Finset ?α.
- {x > a | p x}is elaborated as- Finset.filter (fun x ↦ p x) (Finset.Ioi a)if the expected type is- Finset ?α.
See also
- Data.Set.Defsfor the- Setbuilder notation elaborator that this elaborator partly overrides.
- Data.Finset.Basicfor the- Finsetbuilder notation elaborator partly overriding this one for syntax of the form- {x ∈ s | p x}.
- Data.Fintype.Basicfor the- Finsetbuilder notation elaborator handling syntax of the form- {x | p x},- {x : α | p x},- {x ∉ s | p x},- {x ≠ a | p x}.
TODO: Write a delaborator
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Set.instFintypeIcc a b = Fintype.ofFinset (Finset.Icc a b) ⋯
Equations
- Set.instFintypeIco a b = Fintype.ofFinset (Finset.Ico a b) ⋯
Equations
- Set.instFintypeIoc a b = Fintype.ofFinset (Finset.Ioc a b) ⋯
Equations
- Set.instFintypeIoo a b = Fintype.ofFinset (Finset.Ioo a b) ⋯
Equations
Equations
Equations
Equations
Equations
- Set.fintypeUIcc a b = Fintype.ofFinset (Finset.uIcc a b) ⋯
Instances #
A noncomputable constructor from the finiteness of all closed intervals.
Equations
- LocallyFiniteOrder.ofFiniteIcc h = LocallyFiniteOrder.ofIcc' α (fun (a b : α) => ⋯.toFinset) ⋯
Instances For
A fintype is a locally finite order.
This is not an instance as it would not be defeq to better instances such as
Fin.locallyFiniteOrder.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Given an order embedding α ↪o β, pulls back the LocallyFiniteOrder on β to α.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Note we define Icc (toDual a) (toDual b) as Icc α _ _ b a (which has type Finset α not
Finset αᵒᵈ!) instead of (Icc b a).map toDual.toEmbedding as this means the
following is defeq:
lemma this : (Icc (toDual (toDual a)) (toDual (toDual b)) :) = (Icc a b :) := rfl
Equations
- One or more equations did not get rendered due to their size.
Note we define Iic (toDual a) as Ici a (which has type Finset α not Finset αᵒᵈ!)
instead of (Ici a).map toDual.toEmbedding as this means the following is defeq:
lemma this : (Iic (toDual (toDual a)) :) = (Iic a :) := rfl
Equations
- One or more equations did not get rendered due to their size.
Note we define Ici (toDual a) as Iic a (which has type Finset α not Finset αᵒᵈ!)
instead of (Iic a).map toDual.toEmbedding as this means the following is defeq:
lemma this : (Ici (toDual (toDual a)) :) = (Ici a :) := rfl
Equations
- One or more equations did not get rendered due to their size.
Equations
- Prod.instLocallyFiniteOrder = LocallyFiniteOrder.ofIcc' (α × β) (fun (x y : α × β) => Finset.Icc x.1 y.1 ×ˢ Finset.Icc x.2 y.2) ⋯
Equations
- Prod.instLocallyFiniteOrderTop = LocallyFiniteOrderTop.ofIci' (α × β) (fun (x : α × β) => Finset.Ici x.1 ×ˢ Finset.Ici x.2) ⋯
Equations
- Prod.instLocallyFiniteOrderBot = LocallyFiniteOrderBot.ofIic' (α × β) (fun (x : α × β) => Finset.Iic x.1 ×ˢ Finset.Iic x.2) ⋯
WithTop, WithBot #
Adding a ⊤ to a locally finite OrderTop keeps it locally finite.
Adding a ⊥ to a locally finite OrderBot keeps it locally finite.
Given a finset on α, lift it to being a finset on WithTop α
using WithTop.some and then insert ⊤.
Equations
- WithTop.insertTop = OrderEmbedding.ofMapLEIff (fun (s : Finset α) => Finset.cons ⊤ (Finset.map Function.Embedding.coeWithTop s) ⋯) ⋯
Instances For
Equations
- One or more equations did not get rendered due to their size.
Given a finset on α, lift it to being a finset on WithBot α
using WithBot.some and then insert ⊥.
Equations
- WithBot.insertBot = OrderEmbedding.ofMapLEIff (fun (s : Finset α) => Finset.cons ⊥ (Finset.map Function.Embedding.coeWithBot s) ⋯) ⋯
Instances For
Transfer locally finite orders across order isomorphisms #
Transfer LocallyFiniteOrder across an OrderIso.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Transfer LocallyFiniteOrderTop across an OrderIso.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Transfer LocallyFiniteOrderBot across an OrderIso.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Subtype of a locally finite order #
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
We make the instances below low priority so when alternative constructions are available they are preferred.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
A LocallyFiniteOrder can be transferred across an order isomorphism.
Equations
- One or more equations did not get rendered due to their size.