Cantor’s theorem
Content created by Egbert Rijke and Fredrik Bakke.
Created on 2024-09-23.
Last modified on 2025-01-07.
module foundation.cantors-theorem where
Imports
open import foundation.action-on-identifications-functions open import foundation.decidable-propositions open import foundation.decidable-subtypes open import foundation.dependent-pair-types open import foundation.double-negation-stable-propositions open import foundation.function-extensionality open import foundation.logical-equivalences open import foundation.negation open import foundation.powersets open import foundation.propositional-truncations open import foundation.surjective-maps open import foundation.universe-levels open import foundation-core.empty-types open import foundation-core.fibers-of-maps open import foundation-core.propositions open import logic.de-morgan-propositions open import logic.de-morgan-subtypes open import logic.double-negation-stable-subtypes
Idea
Cantor’s theorem¶ shows that there is no surjective map from a type onto its powerset.
¬ (A ↠ 𝒫(A))
Theorem
Proof. The proof is an instance of an argument by diagonalization. Given a
function f : A → 𝒫(A)
we may define an element of the powerset 𝒫(A)
that f
cannot possibly hit. This subtype is defined by
B := {x ∈ A | x ∉ f(x)}
which is given formally by the predicate x ↦ ¬ (f x x)
. If this subtype were
to be hit by f
, that would mean there is a ξ ∈ A
such that f(ξ) = B
. This
would have to be a fixed point of the negation operation, since
f(ξ)(ξ) = B(ξ) = ¬ (f(ξ)(ξ)),
but negation has no fixed points.
Cantor’s theorem is the 63rd theorem on Freek Wiedijk’s list of 100 theorems [Wie].
module _ {l1 l2 : Level} {X : UU l1} (f : X → powerset l2 X) where subtype-theorem-Cantor : powerset l2 X subtype-theorem-Cantor x = neg-Prop (f x x) abstract not-in-image-subtype-theorem-Cantor : ¬ (fiber f subtype-theorem-Cantor) not-in-image-subtype-theorem-Cantor (ξ , α) = no-fixed-points-neg-Prop (f ξ ξ) (iff-eq (htpy-eq α ξ)) abstract theorem-Cantor : ¬ (is-surjective f) theorem-Cantor H = apply-universal-property-trunc-Prop ( H subtype-theorem-Cantor) ( empty-Prop) ( not-in-image-subtype-theorem-Cantor)
Cantor’s theorem for the set of decidable subtypes
Statement. There is no surjective map from a type X
to its set of
decidable subtypes 𝒫ᵈ(X)
.
module _ {l1 l2 : Level} {X : UU l1} (f : X → decidable-subtype l2 X) where map-theorem-decidable-Cantor : decidable-subtype l2 X map-theorem-decidable-Cantor x = neg-Decidable-Prop (f x x) abstract not-in-image-map-theorem-decidable-Cantor : ¬ (fiber f map-theorem-decidable-Cantor) not-in-image-map-theorem-decidable-Cantor (x , α) = no-fixed-points-neg-Decidable-Prop ( f x x) ( iff-eq (ap prop-Decidable-Prop (htpy-eq α x))) abstract theorem-decidable-Cantor : ¬ (is-surjective f) theorem-decidable-Cantor H = apply-universal-property-trunc-Prop ( H map-theorem-decidable-Cantor) ( empty-Prop) ( not-in-image-map-theorem-decidable-Cantor)
Cantor’s theorem for the set of double negation stable subtypes
Statement. There is no surjective map from a type X
to its set of double
negation stable subtypes 𝒫^¬¬(X)
.
module _ {l1 l2 : Level} {X : UU l1} (f : X → double-negation-stable-subtype l2 X) where map-theorem-double-negation-stable-Cantor : double-negation-stable-subtype l2 X map-theorem-double-negation-stable-Cantor x = neg-Double-Negation-Stable-Prop (f x x) abstract not-in-image-map-theorem-double-negation-stable-Cantor : ¬ (fiber f map-theorem-double-negation-stable-Cantor) not-in-image-map-theorem-double-negation-stable-Cantor (x , α) = no-fixed-points-neg-Double-Negation-Stable-Prop ( f x x) ( iff-eq (ap prop-Double-Negation-Stable-Prop (htpy-eq α x))) abstract theorem-double-negation-stable-Cantor : ¬ (is-surjective f) theorem-double-negation-stable-Cantor H = apply-universal-property-trunc-Prop ( H map-theorem-double-negation-stable-Cantor) ( empty-Prop) ( not-in-image-map-theorem-double-negation-stable-Cantor)
Cantor’s theorem for the set of De Morgan subtypes
Statement. There is no surjective map from a type X
to its set of De
Morgan subtypes 𝒫ᵈᵐ(X)
.
module _ {l1 l2 : Level} {X : UU l1} (f : X → de-morgan-subtype l2 X) where map-theorem-de-morgan-Cantor : de-morgan-subtype l2 X map-theorem-de-morgan-Cantor x = neg-De-Morgan-Prop (f x x) abstract not-in-image-map-theorem-de-morgan-Cantor : ¬ (fiber f map-theorem-de-morgan-Cantor) not-in-image-map-theorem-de-morgan-Cantor (x , α) = no-fixed-points-neg-De-Morgan-Prop ( f x x) ( iff-eq (ap prop-De-Morgan-Prop (htpy-eq α x))) abstract theorem-de-morgan-Cantor : ¬ (is-surjective f) theorem-de-morgan-Cantor H = apply-universal-property-trunc-Prop ( H map-theorem-de-morgan-Cantor) ( empty-Prop) ( not-in-image-map-theorem-de-morgan-Cantor)
References
A proof of Cantor’s theorem first appeared in [Can91] where it was considered in the context of infinite sets.
- [Can91]
- Georg Cantor. Über eine elementare frage der mannigfaltigketislehre. Jahresbericht der Deutschen Mathematiker-Vereinigung, 1:72–78, 1890/91. URL: http://eudml.org/doc/144383.
- [Wie]
- Freek Wiedijk. Formalizing 100 theorems. URL: https://www.cs.ru.nl/~freek/100/.
See also
- Cantor’s theorem generalizes Cantor’s diagonal argument, which shows that the set of infinite sequences on a set with at least two distinct elements is uncountable.
- Cantor’s theorem is generalized by Lawvere’s fixed point theorem.
External links
- Cantor’s theorem at Mathswitch
- Cantor’s theorem at Lab
- Cantor’s theorem at Wikipedia
- Cantor’s theorem at Britannica
Recent changes
- 2025-01-07. Fredrik Bakke. Logic (#1226).
- 2024-10-29. Egbert Rijke. Linked names (#1216).
- 2024-10-28. Egbert Rijke. Formula for the number of combinations (#1213).
- 2024-09-23. Fredrik Bakke. Cantor’s theorem and diagonal argument (#1185).