Cardinal arithmetic #
Arithmetic operations on cardinals are defined in SetTheory/Cardinal/Basic.lean
. However, proving
the important theorem c * c = c
for infinite cardinals and its corollaries requires the use of
ordinal numbers. This is done within this file.
Main statements #
Cardinal.mul_eq_max
andCardinal.add_eq_max
state that the product (resp. sum) of two infinite cardinals is just their maximum. Several variations around this fact are also given.Cardinal.mk_list_eq_mk
: whenα
is infinite,α
andList α
have the same cardinality.
Tags #
cardinal arithmetic (for infinite cardinals)
Properties of mul
#
If α
is an infinite type, then α × α
and α
have the same cardinality.
Properties of add
#
If α
is an infinite type, then α ⊕ α
and α
have the same cardinality.
If α
is an infinite type, then the cardinality of α ⊕ β
is the maximum
of the cardinalities of α
and β
.
Properties of ciSup
#
theorem
Cardinal.ciSup_add
{ι : Type u}
(f : ι → Cardinal.{v})
[Nonempty ι]
(hf : BddAbove (Set.range f))
(c : Cardinal.{v})
:
theorem
Cardinal.add_ciSup
{ι : Type u}
(f : ι → Cardinal.{v})
[Nonempty ι]
(hf : BddAbove (Set.range f))
(c : Cardinal.{v})
:
theorem
Cardinal.ciSup_add_ciSup
{ι : Type u}
{ι' : Type w}
(f : ι → Cardinal.{v})
[Nonempty ι]
[Nonempty ι']
(hf : BddAbove (Set.range f))
(g : ι' → Cardinal.{v})
(hg : BddAbove (Set.range g))
:
theorem
Cardinal.ciSup_mul_ciSup
{ι : Type u}
{ι' : Type w}
(f : ι → Cardinal.{v})
(g : ι' → Cardinal.{v})
:
theorem
Cardinal.sum_eq_iSup_lift
{ι : Type u}
{f : ι → Cardinal.{max u v}}
(hι : aleph0 ≤ mk ι)
(h : lift.{v, u} (mk ι) ≤ iSup f)
:
Properties of aleph
#
Properties about power
#
theorem
Cardinal.prod_eq_two_power
{ι : Type u}
[Infinite ι]
{c : ι → Cardinal.{v}}
(h₁ : ∀ (i : ι), 2 ≤ c i)
(h₂ : ∀ (i : ι), lift.{u, v} (c i) ≤ lift.{v, u} (mk ι))
:
Computing cardinality of various types #
theorem
Cardinal.mk_equiv_eq_arrow_of_lift_eq
{α : Type u}
{β' : Type v}
[Infinite α]
(leq : lift.{v, u} (mk α) = lift.{u, v} (mk β'))
:
theorem
Cardinal.mk_equiv_of_lift_eq
{α : Type u}
{β' : Type v}
[Infinite α]
(leq : lift.{v, u} (mk α) = lift.{u, v} (mk β'))
:
theorem
Cardinal.mk_embedding_eq_arrow_of_lift_le
{α : Type u}
{β' : Type v}
[Infinite α]
(lle : lift.{u, v} (mk β') ≤ lift.{v, u} (mk α))
:
@[simp]
Properties of compl
#
Extending an injection to an equiv #
Cardinal operations with ordinal indices #
theorem
Cardinal.mk_iUnion_Ordinal_lift_le_of_le
{β : Type v}
{o : Ordinal.{u}}
{c : Cardinal.{v}}
(ho : lift.{v, u} o.card ≤ lift.{u, v} c)
(hc : aleph0 ≤ c)
(A : Ordinal.{u} → Set β)
(hA : ∀ j < o, mk ↑(A j) ≤ c)
:
Bounds the cardinal of an ordinal-indexed union of sets.
theorem
Cardinal.mk_iUnion_Ordinal_le_of_le
{β : Type u_1}
{o : Ordinal.{u_1}}
{c : Cardinal.{u_1}}
(ho : o.card ≤ c)
(hc : aleph0 ≤ c)
(A : Ordinal.{u_1} → Set β)
(hA : ∀ j < o, mk ↑(A j) ≤ c)
:
@[deprecated Cardinal.mk_iUnion_Ordinal_le_of_le (since := "2024-11-02")]
theorem
Ordinal.Cardinal.mk_iUnion_Ordinal_le_of_le
{β : Type u_1}
{o : Ordinal.{u_1}}
{c : Cardinal.{u_1}}
(ho : o.card ≤ c)
(hc : Cardinal.aleph0 ≤ c)
(A : Ordinal.{u_1} → Set β)
(hA : ∀ j < o, Cardinal.mk ↑(A j) ≤ c)
:
Alias of Cardinal.mk_iUnion_Ordinal_le_of_le
.
Cardinality of ordinals #
theorem
Ordinal.card_iSup_Iio_le_sum_card
{o : Ordinal.{u}}
(f : ↑(Set.Iio o) → Ordinal.{max u v})
:
theorem
Ordinal.card_opow_le_of_omega0_le_left
{a : Ordinal.{u_1}}
(ha : omega0 ≤ a)
(b : Ordinal.{u_1})
:
theorem
Ordinal.card_opow_le_of_omega0_le_right
(a : Ordinal.{u_1})
{b : Ordinal.{u_1}}
(hb : omega0 ≤ b)
:
theorem
Ordinal.principal_opow_omega
(o : Ordinal.{u_1})
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 ^ x2) (omega o)
theorem
Ordinal.IsInitial.principal_opow
{o : Ordinal.{u_1}}
(h : o.IsInitial)
(ho : omega0 ≤ o)
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 ^ x2) o
theorem
Ordinal.principal_opow_ord
{c : Cardinal.{u_1}}
(hc : Cardinal.aleph0 ≤ c)
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 ^ x2) c.ord
Initial ordinals are principal #
theorem
Ordinal.principal_add_ord
{c : Cardinal.{u_1}}
(hc : Cardinal.aleph0 ≤ c)
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 + x2) c.ord
theorem
Ordinal.IsInitial.principal_add
{o : Ordinal.{u_1}}
(h : o.IsInitial)
(ho : omega0 ≤ o)
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 + x2) o
theorem
Ordinal.principal_add_omega
(o : Ordinal.{u_1})
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 + x2) (omega o)
theorem
Ordinal.principal_mul_ord
{c : Cardinal.{u_1}}
(hc : Cardinal.aleph0 ≤ c)
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 * x2) c.ord
theorem
Ordinal.IsInitial.principal_mul
{o : Ordinal.{u_1}}
(h : o.IsInitial)
(ho : omega0 ≤ o)
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 * x2) o
theorem
Ordinal.principal_mul_omega
(o : Ordinal.{u_1})
:
Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 * x2) (omega o)
@[deprecated Ordinal.principal_add_omega (since := "2024-11-08")]
theorem
Cardinal.principal_add_aleph
(o : Ordinal.{u_1})
:
Ordinal.Principal (fun (x1 x2 : Ordinal.{u_1}) => x1 + x2) (aleph o).ord