Documentation

Mathlib.SetTheory.Cardinal.Aleph

Omega, aleph, and beth functions #

Notation #

The following notations are scoped to the Ordinal namespace.

The following notations are scoped to the Cardinal namespace.

Omega ordinals #

An ordinal is initial when it is the first ordinal with a given cardinality.

This is written as o.card.ord = o, i.e. o is the smallest ordinal with cardinality o.card.

Equations
  • o.IsInitial = (o.card.ord = o)
Instances For
    theorem Ordinal.IsInitial.ord_card {o : Ordinal.{u_1}} (h : o.IsInitial) :
    o.card.ord = o
    theorem Ordinal.IsInitial.card_le_card {a b : Ordinal.{u_1}} (ha : a.IsInitial) :
    a.card b.card a b
    theorem Ordinal.IsInitial.card_lt_card {a b : Ordinal.{u_1}} (hb : b.IsInitial) :
    a.card < b.card a < b
    theorem Ordinal.isInitial_ord (c : Cardinal.{u_1}) :
    c.ord.IsInitial
    theorem Ordinal.isInitial_natCast (n : ) :
    (↑n).IsInitial

    Initial ordinals are order-isomorphic to the cardinals.

    Equations
    • One or more equations did not get rendered due to their size.
    Instances For
      @[simp]
      theorem Ordinal.isInitialIso_apply (x : { x : Ordinal.{u_1} // x.IsInitial }) :
      Ordinal.isInitialIso x = (↑x).card

      The "pre-omega" function gives the initial ordinals listed by their ordinal index. preOmega n = n, preOmega ω = ω, preOmega (ω + 1) = ω₁, etc.

      For the more common omega function skipping over finite ordinals, see Ordinal.omega.

      Equations
      Instances For
        @[simp]
        @[simp]
        theorem Ordinal.preOmega_ofNat (n : ) [n.AtLeastTwo] :
        theorem Ordinal.preOmega_le_of_forall_lt {o a : Ordinal.{u_1}} (ha : a.IsInitial) (H : b < o, Ordinal.preOmega b < a) :

        The omega function gives the infinite initial ordinals listed by their ordinal index. omega 0 = ω, omega 1 = ω₁ is the first uncountable ordinal, and so on.

        This is not to be confused with the first infinite ordinal Ordinal.omega0.

        For a version including finite ordinals, see Ordinal.preOmega.

        Equations
        Instances For

          The omega function gives the infinite initial ordinals listed by their ordinal index. omega 0 = ω, omega 1 = ω₁ is the first uncountable ordinal, and so on.

          This is not to be confused with the first infinite ordinal Ordinal.omega0.

          For a version including finite ordinals, see Ordinal.preOmega.

          Equations
          Instances For

            ω₁ is the first uncountable ordinal.

            Equations
            Instances For
              theorem Ordinal.omega_lt_omega {o₁ o₂ : Ordinal.{u_1}} :
              Ordinal.omega o₁ < Ordinal.omega o₂ o₁ < o₂

              For the theorem 0 < ω, see omega0_pos.

              @[deprecated Ordinal.omega0_lt_omega1 (since := "2024-10-11")]

              Alias of Ordinal.omega0_lt_omega1.

              Aleph cardinals #

              The "pre-aleph" function gives the cardinals listed by their ordinal index. preAleph n = n, preAleph ω = ℵ₀, preAleph (ω + 1) = succ ℵ₀, etc.

              For the more common aleph function skipping over finite cardinals, see Cardinal.aleph.

              Equations
              Instances For
                @[simp]
                theorem Cardinal.preAleph_nat (n : ) :
                theorem Cardinal.preAleph_limit {o : Ordinal.{u_1}} (ho : o.IsLimit) :
                Cardinal.preAleph o = ⨆ (a : (Set.Iio o)), Cardinal.preAleph a

                The aleph function gives the infinite cardinals listed by their ordinal index. aleph 0 = ℵ₀, aleph 1 = succ ℵ₀ is the first uncountable cardinal, and so on.

                For a version including finite cardinals, see Cardinal.aleph'.

                Equations
                Instances For

                  The aleph function gives the infinite cardinals listed by their ordinal index. aleph 0 = ℵ₀, aleph 1 = succ ℵ₀ is the first uncountable cardinal, and so on.

                  For a version including finite cardinals, see Cardinal.aleph'.

                  Equations
                  Instances For

                    ℵ₁ is the first uncountable cardinal.

                    Equations
                    Instances For
                      @[deprecated Cardinal.aleph_lt_aleph (since := "2024-10-22")]
                      theorem Cardinal.aleph_lt {o₁ o₂ : Ordinal.{u_1}} :
                      Cardinal.aleph o₁ < Cardinal.aleph o₂ o₁ < o₂

                      Alias of Cardinal.aleph_lt_aleph.

                      @[deprecated Cardinal.aleph_le_aleph (since := "2024-10-22")]
                      theorem Cardinal.aleph_le {o₁ o₂ : Ordinal.{u_1}} :

                      Alias of Cardinal.aleph_le_aleph.

                      @[deprecated Cardinal.aleph_max (since := "2024-08-28")]
                      @[simp]

                      For the theorem lift ω = ω, see lift_omega0.

                      theorem Cardinal.aleph_limit {o : Ordinal.{u_1}} (ho : o.IsLimit) :
                      Cardinal.aleph o = ⨆ (a : (Set.Iio o)), Cardinal.aleph a
                      @[deprecated Cardinal.isLimit_omega (since := "2024-10-24")]
                      @[deprecated Cardinal.mem_range_aleph_iff (since := "2024-10-24")]
                      @[deprecated Ordinal.isNormal_preOmega (since := "2024-10-11")]
                      @[deprecated Ordinal.isNormal_omega (since := "2024-10-11")]
                      theorem Cardinal.countable_iff_lt_aleph_one {α : Type u_1} (s : Set α) :
                      s.Countable Cardinal.mk s < Cardinal.aleph 1
                      @[deprecated Cardinal.preAleph (since := "2024-10-22")]

                      Alias of Cardinal.preAleph.


                      The "pre-aleph" function gives the cardinals listed by their ordinal index. preAleph n = n, preAleph ω = ℵ₀, preAleph (ω + 1) = succ ℵ₀, etc.

                      For the more common aleph function skipping over finite cardinals, see Cardinal.aleph.

                      Equations
                      Instances For
                        @[deprecated Cardinal.preAleph (since := "2024-08-28")]
                        def Cardinal.alephIdx.initialSeg :
                        (fun (x1 x2 : Cardinal.{u_1}) => x1 < x2) ≼i fun (x1 x2 : Ordinal.{u_1}) => x1 < x2

                        The aleph' index function, which gives the ordinal index of a cardinal. (The aleph' part is because unlike aleph this counts also the finite stages. So alephIdx n = n, alephIdx ω = ω, alephIdx ℵ₁ = ω + 1 and so on.) In this definition, we register additionally that this function is an initial segment, i.e., it is order preserving and its range is an initial segment of the ordinals. For the basic function version, see alephIdx. For an upgraded version stating that the range is everything, see AlephIdx.rel_iso.

                        Equations
                        Instances For
                          @[deprecated Cardinal.preAleph (since := "2024-08-28")]
                          def Cardinal.alephIdx.relIso :
                          (fun (x1 x2 : Cardinal.{u}) => x1 < x2) ≃r fun (x1 x2 : Ordinal.{u}) => x1 < x2

                          The aleph' index function, which gives the ordinal index of a cardinal. (The aleph' part is because unlike aleph this counts also the finite stages. So alephIdx n = n, alephIdx ℵ₀ = ω, alephIdx ℵ₁ = ω + 1 and so on.) In this version, we register additionally that this function is an order isomorphism between cardinals and ordinals. For the basic function version, see alephIdx.

                          Equations
                          Instances For
                            @[deprecated Cardinal.aleph' (since := "2024-08-28")]

                            The aleph' index function, which gives the ordinal index of a cardinal. (The aleph' part is because unlike aleph this counts also the finite stages. So alephIdx n = n, alephIdx ω = ω, alephIdx ℵ₁ = ω + 1 and so on.) For an upgraded version stating that the range is everything, see AlephIdx.rel_iso.

                            Equations
                            Instances For
                              @[deprecated "No deprecation message was provided." (since := "2024-08-28")]
                              @[deprecated Cardinal.aleph' (since := "2024-08-28")]

                              The aleph' function gives the cardinals listed by their ordinal index, and is the inverse of aleph_idx. aleph' n = n, aleph' ω = ω, aleph' (ω + 1) = succ ℵ₀, etc. In this version, we register additionally that this function is an order isomorphism between ordinals and cardinals. For the basic function version, see aleph'.

                              Equations
                              Instances For
                                @[deprecated "No deprecation message was provided." (since := "2024-08-28")]
                                @[deprecated Cardinal.preAleph_lt_preAleph (since := "2024-10-22")]
                                theorem Cardinal.aleph'_lt {o₁ o₂ : Ordinal.{u_1}} :
                                Cardinal.aleph' o₁ < Cardinal.aleph' o₂ o₁ < o₂
                                @[deprecated Cardinal.preAleph_le_preAleph (since := "2024-10-22")]
                                theorem Cardinal.aleph'_le {o₁ o₂ : Ordinal.{u_1}} :
                                @[deprecated Cardinal.preAleph_max (since := "2024-10-22")]
                                @[deprecated "No deprecation message was provided." (since := "2024-08-28")]
                                @[deprecated "No deprecation message was provided." (since := "2024-08-28")]
                                @[deprecated Cardinal.preAleph_zero (since := "2024-10-22")]
                                @[deprecated Cardinal.preAleph_succ (since := "2024-10-22")]
                                @[deprecated Cardinal.preAleph_nat (since := "2024-10-22")]
                                theorem Cardinal.aleph'_nat (n : ) :
                                Cardinal.aleph' n = n
                                @[deprecated Cardinal.lift_preAleph (since := "2024-10-22")]
                                @[deprecated Cardinal.preAleph_le_of_isLimit (since := "2024-10-22")]
                                theorem Cardinal.aleph'_le_of_limit {o : Ordinal.{u_1}} (l : o.IsLimit) {c : Cardinal.{u_1}} :
                                @[deprecated Cardinal.preAleph_limit (since := "2024-10-22")]
                                theorem Cardinal.aleph'_limit {o : Ordinal.{u_1}} (ho : o.IsLimit) :
                                Cardinal.aleph' o = ⨆ (a : (Set.Iio o)), Cardinal.aleph' a
                                @[deprecated Cardinal.preAleph_omega0 (since := "2024-10-22")]
                                @[deprecated Cardinal.aleph'_omega0 "No deprecation message was provided." (since := "2024-09-30")]

                                Alias of Cardinal.aleph'_omega0.

                                @[deprecated Cardinal.aleph' (since := "2024-08-28")]

                                aleph' and aleph_idx form an equivalence between Ordinal and Cardinal

                                Equations
                                Instances For
                                  @[deprecated Cardinal.aleph_eq_preAleph (since := "2024-10-22")]
                                  @[deprecated Cardinal.aleph0_le_preAleph (since := "2024-10-22")]
                                  @[deprecated Cardinal.preAleph_pos (since := "2024-10-22")]
                                  theorem Cardinal.aleph'_pos {o : Ordinal.{u_1}} (ho : 0 < o) :
                                  @[deprecated Cardinal.preAleph_isNormal (since := "2024-10-22")]
                                  @[deprecated "No deprecation message was provided." (since := "2024-09-24")]
                                  theorem Cardinal.ord_card_unbounded :
                                  Set.Unbounded (fun (x1 x2 : Ordinal.{u_1}) => x1 < x2) {b : Ordinal.{u_1} | b.card.ord = b}

                                  Ordinals that are cardinals are unbounded.

                                  @[deprecated "No deprecation message was provided." (since := "2024-09-24")]
                                  theorem Cardinal.eq_aleph'_of_eq_card_ord {o : Ordinal.{u_1}} (ho : o.card.ord = o) :
                                  ∃ (a : Ordinal.{u_1}), (Cardinal.aleph' a).ord = o
                                  @[deprecated "No deprecation message was provided." (since := "2024-09-24")]
                                  theorem Cardinal.ord_card_unbounded' :
                                  Set.Unbounded (fun (x1 x2 : Ordinal.{u_1}) => x1 < x2) {b : Ordinal.{u_1} | b.card.ord = b Ordinal.omega0 b}

                                  Infinite ordinals that are cardinals are unbounded.

                                  @[deprecated "No deprecation message was provided." (since := "2024-09-24")]
                                  theorem Cardinal.eq_aleph_of_eq_card_ord {o : Ordinal.{u_1}} (ho : o.card.ord = o) (ho' : Ordinal.omega0 o) :
                                  ∃ (a : Ordinal.{u_1}), (Cardinal.aleph a).ord = o

                                  Beth cardinals #

                                  Beth numbers are defined so that beth 0 = ℵ₀, beth (succ o) = 2 ^ beth o, and when o is a limit ordinal, beth o is the supremum of beth o' for o' < o.

                                  Assuming the generalized continuum hypothesis, which is undecidable in ZFC, beth o = aleph o for every o.

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

                                    Beth numbers are defined so that beth 0 = ℵ₀, beth (succ o) = 2 ^ beth o, and when o is a limit ordinal, beth o is the supremum of beth o' for o' < o.

                                    Assuming the generalized continuum hypothesis, which is undecidable in ZFC, beth o = aleph o for every o.

                                    Equations
                                    Instances For
                                      theorem Cardinal.beth_limit {o : Ordinal.{u_1}} :
                                      o.IsLimitCardinal.beth o = ⨆ (a : (Set.Iio o)), Cardinal.beth a
                                      @[simp]
                                      theorem Cardinal.beth_lt {o₁ o₂ : Ordinal.{u_1}} :
                                      Cardinal.beth o₁ < Cardinal.beth o₂ o₁ < o₂
                                      @[simp]
                                      theorem Cardinal.beth_le {o₁ o₂ : Ordinal.{u_1}} :
                                      Cardinal.beth o₁ Cardinal.beth o₂ o₁ o₂
                                      @[deprecated Cardinal.isNormal_beth (since := "2024-10-11")]