Ordinals #
Ordinals are defined as equivalences of well-ordered sets under order isomorphism. They are endowed with a total order, where an ordinal is smaller than another one if it embeds into it as an initial segment (or, equivalently, in any way). This total order is well founded.
Main definitions #
-
Ordinal
: the type of ordinals (in a given universe) -
Ordinal.type r
: given a well-founded orderr
, this is the corresponding ordinal -
Ordinal.typein r a
: given a well-founded orderr
on a typeα
, anda : α
, the ordinal corresponding to all elements smaller thana
. -
enum r o h
: given a well-orderr
on a typeα
, and an ordinalo
strictly smaller than the ordinal corresponding tor
(this is the assumptionh
), returns theo
-th element ofα
. In other words, the elements ofα
can be enumerated using ordinals up totype r
. -
Ordinal.card o
: the cardinality of an ordinalo
. -
Ordinal.lift
lifts an ordinal in universeu
to an ordinal in universemax u v
. For a version registering additionally that this is an initial segment embedding, seeOrdinal.lift.initialSeg
. For a version registering that it is a principal segment embedding ifu < v
, seeOrdinal.lift.principalSeg
. -
Ordinal.omega
orω
is the order type ofℕ
. This definition is universe polymorphic:Ordinal.omega.{u} : Ordinal.{u}
(contrast withℕ : Type
, which lives in a specific universe). In some cases the universe level has to be given explicitly. -
o₁ + o₂
is the order on the disjoint union ofo₁
ando₂
obtained by declaring that every element ofo₁
is smaller than every element ofo₂
. The main properties of addition (and the other operations on ordinals) are stated and proved inOrdinalArithmetic.lean
. Here, we only introduce it and prove its basic properties to deduce the fact that the order on ordinals is total (and well founded). -
succ o
is the successor of the ordinalo
. -
Cardinal.ord c
: whenc
is a cardinal,ord c
is the smallest ordinal with this cardinality. It is the canonical way to represent a cardinal with an ordinal.
A conditionally complete linear order with bot structure is registered on ordinals, where ⊥
is
0
, the ordinal corresponding to the empty type, and Inf
is the minimum for nonempty sets and 0
for the empty set by convention.
Notations #
ω
is a notation for the first infinite ordinal in the localeOrdinal
.
Well order on an arbitrary type #
An embedding of any type to the set of cardinals.
Equations
- embeddingToCardinal = Classical.choice (_ : Nonempty (σ ↪ Cardinal.{u}))
Instances For
Any type can be endowed with a well order, obtained by pulling back the well order over cardinals by some embedding.
Equations
- WellOrderingRel = ⇑embeddingToCardinal ⁻¹'o fun (x x_1 : Cardinal.{u}) => x < x_1
Instances For
Equations
- (_ : IsWellOrder σ WellOrderingRel) = (_ : IsWellOrder σ (⇑embeddingToCardinal ⁻¹'o fun (x x_1 : Cardinal.{u}) => x < x_1))
Equations
- (_ : Nonempty { r : σ → σ → Prop // IsWellOrder σ r }) = (_ : Nonempty { r : σ → σ → Prop // IsWellOrder σ r })
Definition of ordinals #
Bundled structure registering a well order on a type. Ordinals will be defined as a quotient of this type.
- α : Type u
The underlying type of the order.
- r : s.α → s.α → Prop
The underlying relation of the order.
- wo : IsWellOrder s.α s.r
Instances For
Equations
- WellOrder.inhabited = { default := { α := PEmpty.{u_3 + 1} , r := EmptyRelation, wo := WellOrder.inhabited.proof_1 } }
Equivalence relation on well orders on arbitrary types in universe u
, given by order
isomorphism.
Equations
- One or more equations did not get rendered due to their size.
Ordinal.{u}
is the type of well orders in Type u
, up to order isomorphism.
Equations
Instances For
Equations
- hasWellFoundedOut o = { rel := (Quotient.out o).r, wf := (_ : WellFounded (Quotient.out o).r) }
Equations
Equations
- (_ : IsWellOrder (Quotient.out o).α fun (x x_1 : (Quotient.out o).α) => x < x_1) = (_ : IsWellOrder (Quotient.out o).α (Quotient.out o).r)
Basic properties of the order type #
The order type of a well order is an ordinal.
Equations
- Ordinal.type r = ⟦{ α := α, r := r, wo := wo }⟧
Instances For
Equations
- Ordinal.zero = { zero := Ordinal.type EmptyRelation }
Equations
- Ordinal.inhabited = { default := 0 }
Equations
- Ordinal.one = { one := Ordinal.type EmptyRelation }
The order type of an element inside a well order. For the embedding as a principal segment, see
typein.principalSeg
.
Equations
- Ordinal.typein r a = Ordinal.type (Subrel r {b : α | r b a})
Instances For
Equations
- Ordinal.isEmpty_out_zero = (_ : IsEmpty (Quotient.out 0).α)
Equations
The order on ordinals #
Equations
Equations
Given two ordinals α ≤ β
, then initialSegOut α β
is the initial segment embedding
of α
to β
, as map from a model type for α
to a model type for β
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Given two ordinals α < β
, then principalSegOut α β
is the principal segment embedding
of α
to β
, as map from a model type for α
to a model type for β
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Principal segment version of the typein
function, embedding a well order into
ordinals as a principal segment.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Enumerating elements in a well-order with ordinals. #
enum r o h
is the o
-th element of α
ordered by r
.
That is, enum
maps an initial segment of the ordinals, those
less than the order type of r
, to the elements of α
.
Equations
- Ordinal.enum r o h = (PrincipalSeg.subrelIso (Ordinal.typein.principalSeg r)) { val := o, property := h }
Instances For
Equations
- Ordinal.wellFoundedRelation = { rel := fun (x x_1 : Ordinal.{u_3}) => x < x_1, wf := Ordinal.lt_wf }
Reformulation of well founded induction on ordinals as a lemma that works with the
induction
tactic, as in induction i using Ordinal.induction with | h i IH => ?_
.
Cardinality of ordinals #
The cardinal of an ordinal is the cardinality of any type on which a relation with that order type is defined.
Instances For
Lifting ordinals to a higher universe #
The universe lift operation for ordinals, which embeds Ordinal.{u}
as
a proper initial segment of Ordinal.{v}
for v > u
. For the initial segment version,
see lift.initialSeg
.
Equations
- Ordinal.lift.{u, v} o = Quotient.liftOn o (fun (w : WellOrder) => Ordinal.type (ULift.down ⁻¹'o w.r)) Ordinal.lift.proof_2
Instances For
lift.{max u v, u}
equals lift.{v, u}
.
lift.{max v u, u}
equals lift.{v, u}
.
An ordinal lifted to a lower or equal universe equals itself.
An ordinal lifted to the same universe equals itself.
An ordinal lifted to the zero universe equals itself.
Initial segment version of the lift operation on ordinals, embedding ordinal.{u}
in
ordinal.{v}
as an initial segment when u ≤ v
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
ω
is the first infinite ordinal, defined as the order type of ℕ
.
Equations
- Ordinal.omega = Ordinal.lift.{u, 0} (Ordinal.type fun (x x_1 : ℕ) => x < x_1)
Instances For
ω
is the first infinite ordinal, defined as the order type of ℕ
.
Equations
- Ordinal.termω = Lean.ParserDescr.node `Ordinal.termω 1024 (Lean.ParserDescr.symbol "ω")
Instances For
Note that the presence of this lemma makes simp [omega]
form a loop.
Definition and first properties of addition on ordinals #
In this paragraph, we introduce the addition on ordinals, and prove just enough properties to
deduce that the order on ordinals is total (and therefore well-founded). Further properties of
the addition, together with properties of the other operations, are proved in
OrdinalArithmetic.lean
.
o₁ + o₂
is the order on the disjoint union of o₁
and o₂
obtained by declaring that
every element of o₁
is smaller than every element of o₂
.
Equations
- One or more equations did not get rendered due to their size.
Equations
- Ordinal.addMonoidWithOne = AddMonoidWithOne.mk
Equations
- Ordinal.add_covariantClass_le = (_ : CovariantClass Ordinal.{u} Ordinal.{u} (fun (x x_1 : Ordinal.{u}) => x + x_1) fun (x x_1 : Ordinal.{u}) => x ≤ x_1)
Equations
- Ordinal.add_swap_covariantClass_le = (_ : CovariantClass Ordinal.{u} Ordinal.{u} (Function.swap fun (x x_1 : Ordinal.{u}) => x + x_1) fun (x x_1 : Ordinal.{u}) => x ≤ x_1)
Equations
- One or more equations did not get rendered due to their size.
Equations
- Ordinal.wellFoundedLT = (_ : IsWellFounded Ordinal.{u_3} fun (x x_1 : Ordinal.{u_3}) => x < x_1)
Equations
- Ordinal.isWellOrder = (_ : IsWellOrder Ordinal.{u_3} fun (x x_1 : Ordinal.{u_3}) => x < x_1)
Successor order properties #
Equations
Equations
- Ordinal.succOrder = SuccOrder.ofSuccLeIff (fun (o : Ordinal.{u}) => o + 1) (_ : ∀ {a b : Ordinal.{u}}, a + 1 ≤ b ↔ a < b)
Equations
- Ordinal.uniqueIioOne = { toInhabited := { default := { val := 0, property := Ordinal.uniqueIioOne.proof_1 } }, uniq := Ordinal.uniqueIioOne.proof_2 }
Equations
- One or more equations did not get rendered due to their size.
Extra properties of typein and enum #
A well order r
is order isomorphic to the set of ordinals smaller than type r
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
The order isomorphism between ordinals less than o
and o.out.α
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Universal ordinal #
univ.{u v}
is the order type of the ordinals of Type u
as a member
of Ordinal.{v}
(when u < v
). It is an inaccessible cardinal.
Equations
- Ordinal.univ.{u, v} = Ordinal.lift.{v, u + 1} (Ordinal.type fun (x x_1 : Ordinal.{u}) => x < x_1)
Instances For
Principal segment version of the lift operation on ordinals, embedding ordinal.{u}
in
ordinal.{v}
as a principal segment when u < v
.
Equations
- Ordinal.lift.principalSeg = { toRelEmbedding := Ordinal.lift.initialSeg.toRelEmbedding, top := Ordinal.univ.{u, v} , down' := Ordinal.lift.principalSeg.proof_1 }
Instances For
Representing a cardinal with an ordinal #
The ordinal corresponding to a cardinal c
is the least ordinal
whose cardinal is c
. For the order-embedding version, see ord.order_embedding
.
Equations
- Cardinal.ord c = let F := fun (α : Type u) => ⨅ (r : { r : α → α → Prop // IsWellOrder α r }), Ordinal.type ↑r; Quot.liftOn c F Cardinal.ord.proof_2
Instances For
A variation on Cardinal.lt_ord
using ≤
: If o
is no greater than the
initial ordinal of cardinality c
, then its cardinal is no greater than c
.
The converse, however, is false (for instance, o = ω+1
and c = ℵ₀
).
The ordinal corresponding to a cardinal c
is the least ordinal
whose cardinal is c
. This is the order-embedding version. For the regular function, see ord
.