# Cantor's diagonal argument

# Cantor's diagonal argument

In set theory, **Cantor's diagonal argument**, also called the **diagonalisation argument**, the **diagonal slash argument** or the **diagonal method**, was published in 1891 by Georg Cantor as a mathematical proof that there are infinite sets which cannot be put into one-to-one correspondence with the infinite set of natural numbers.^{[1]}^{[2]} ^{[]} ^{[3]}
Such sets are now known as uncountable sets, and the size of infinite sets is now treated by the theory of cardinal numbers which Cantor began.

The diagonal argument was not Cantor's first proof of the uncountability of the real numbers, which appeared in 1874.^{[4]}^{[5]}
However, it demonstrates a general technique that has since been used in a wide range of proofs,^{[6]} including the first of Gödel's incompleteness theorems^{[2]} and Turing's answer to the *Entscheidungsproblem*. Diagonalization arguments are often also the source of contradictions like Russell's paradox^{[7]}^{[8]} and Richard's paradox.^{[2]} ^{[]}

Uncountable set

In his 1891 article, Cantor considered the set *T* of all infinite sequences of binary digits (i.e. each digit is zero or one).
He begins with a constructive proof of the following theorem:

- If

*s*

_{1},

*s*

_{2}, … ,

*s*

_{n}, … is any enumeration of elements from

*T*, then there is always an element

*s*of

*T*which corresponds to no

*s*

_{n}in the enumeration.

The proof starts with an enumeration of elements from *T*, for example:

s_{1}= | (0, | 0, | 0, | 0, | 0, | 0, | 0, | ...) |

s_{2}= | (1, | 1, | 1, | 1, | 1, | 1, | 1, | ...) |

s_{3}= | (0, | 1, | 0, | 1, | 0, | 1, | 0, | ...) |

s_{4}= | (1, | 0, | 1, | 0, | 1, | 0, | 1, | ...) |

s_{5}= | (1, | 1, | 0, | 1, | 0, | 1, | 1, | ...) |

s_{6}= | (0, | 0, | 1, | 1, | 0, | 1, | 1, | ...) |

s_{7}= | (1, | 0, | 0, | 0, | 1, | 0, | 0, | ...) |

... |

Next, a sequence *s* is constructed by choosing the 1st digit as complementary to the 1st digit of *s**1* (swapping **0**s for **1**s and vice versa), the 2nd digit as complementary to the 2nd digit of *s**2*, the 3rd digit as complementary to the 3rd digit of *s**3*, and generally for every *n*, the *n*th digit as complementary to the *n*th digit of *s**n*. For the example above, this yields:

s_{1} | = | (,0 | 0, | 0, | 0, | 0, | 0, | 0, | ...) |

s_{2} | = | (1, | ,1 | 1, | 1, | 1, | 1, | 1, | ...) |

s_{3} | = | (0, | 1, | ,0 | 1, | 0, | 1, | 0, | ...) |

s_{4} | = | (1, | 0, | 1, | ,0 | 1, | 0, | 1, | ...) |

s_{5} | = | (1, | 1, | 0, | 1, | ,0 | 1, | 1, | ...) |

s_{6} | = | (0, | 0, | 1, | 1, | 0, | ,1 | 1, | ...) |

s_{7} | = | (1, | 0, | 0, | 0, | 1, | 0, | ,0 | ...) |

... | |||||||||

s | = | (,1 | ,0 | ,1 | ,1 | ,1 | ,0 | ,1 | ...) |

By construction, *s* differs from each *s**n*, since their *n*th digits differ (highlighted in the example).
Hence, *s* cannot occur in the enumeration.

Based on this theorem, Cantor then uses a proof by contradiction to show that:

- The set

*T*is uncountable.

The proof starts by assuming that *T* is countable.
Then all its elements can be written as an enumeration *s*1, *s*2, ... , *s**n*, ... .
Applying the previous theorem to this enumeration produces a sequence *s* not belonging to the enumeration. However, this contradicts *s* being an element of *T* and therefore belonging to the enumeration. This contradiction implies that the original assumption is false. Therefore, *T* is uncountable.

Interpretation

The interpretation of Cantor's result will depend upon one's view of mathematics. To constructivists, the argument shows no more than that there is no bijection between the natural numbers and *T*. It does not rule out the possibility that the latter are subcountable. In the context of classical mathematics, this is impossible, and the diagonal argument establishes that, although both sets are infinite, there are actually *more* infinite sequences of ones and zeros than there are natural numbers.

Real numbers

`The uncountability of thereal numberswas already established byCantor's first uncountability proof, but it also follows from the above result. To prove this, aninjectionwill be constructed from the set`

*T*of infinite binary strings to the set**R**of real numbers. Since*T*is uncountable, theimageof this function, which is a subset of**R**, is uncountable. Therefore,**R**is uncountable. Also, by using a method of construction devised by Cantor, abijectionwill be constructed between*T*and**R**. Therefore,*T*and**R**have the same cardinality, which is called the "cardinality of the continuum" and is usually denoted byor.An injection from *T* to **R** is given by mapping strings in *T* to decimals, such as mapping *t* = 0111... to the decimal 0.0111.... This function, defined by *f* (*t*) = 0.*t*, is an injection because it maps different strings to different numbers.

Constructing a bijection between *T* and **R** is slightly more complicated.
Instead of mapping 0111... to the decimal 0.0111..., it can be mapped to the base *b* number: 0.0111...*b*. This leads to the family of functions: *f**b* (*t*) = 0.*t**b*. The functions *f* *b*(*t*) are injections, except for *f* 2(*t*). This function will be modified to produce a bijection between *T* and **R**.

Construction of a bijection between T and R |
---|

This construction uses a method devised by Cantor that was published in 1878. He used it to construct a bijection between the closed interval [0, 1] and the irrationals in the open interval (0, 1). He first removed a countably infinite subset from each of these sets so that there is a bijection between the remaining uncountable sets. Since there is a bijection between the countably infinite subsets that have been removed, combining the two bijections produces a bijection between the original sets.^{[9]}Cantor's method can be used to modify the functionf_{2}(t) = 0.t_{2}to produce a bijection from T to (0, 1). Because some numbers have two binary expansions,f_{2}(t)is not even injective. For example,f_{2}(1000…) =0.1000..._{2} = 1/2 andf_{2}(0111…) =0.0111..._{2} =1/4 + 1/8 + 1/16 + … =1/2, so both 1000... and 0111... map to the same number, 1/2.
To modifyf_{2}(t), observe that it is a bijection except for a countably infinite subset of (0, 1) and a countably infinite subset of T. It is not a bijection for the numbers in (0, 1) that have two binary expansions. These are called dyadic numbers and have the formm/2^{n}where m is an odd integer and n is a natural number. Put these numbers in the sequence: r = (1/2, 1/4, 3/4, 1/8, 3/8, 5/8, 7/8, ...). Also,f_{2}(t)is not a bijection to (0, 1) for the strings in T appearing after the binary point in the binary expansions of 0, 1, and the numbers in sequence r. Put these eventually-constant strings in the sequence: s = (000...,111..., 1000..., 0111..., 01000..., 00111..., 11000..., 10111..., ...). Define the bijection g(t) from T to (0, 1): If t is the n^{th}string in sequence s, let g(t) be the n^{th}number in sequence r; otherwise, g(t) = 0.t_{2}.
To construct a bijection from T to R, start with the tangent function tan(x), which is a bijection from (−π/2, π/2) to R (see the figure shown on the right). Next observe that the linear function h(x) =πx – π/2is a bijection from (0, 1) to (−π/2, π/2) (see the figure shown on the left). The composite function tan(h(x)) =tan(πx – π/2)is a bijection from (0, 1) to R. Composing this function with g(t) produces the function tan(h(g(t))) =tan(πg(t) – π/2), which is a bijection from T to R. |

General sets

Illustration of the generalized diagonal argument: The set *T* = {*n*∈ℕ: *n*∉*f*(*n*)} at the bottom cannot occur anywhere in the range of *f*:ℕ→* P*(ℕ). The example mapping

*f*happens to correspond to the example enumeration

*s*in the above picture.

A generalized form of the diagonal argument was used by Cantor to prove Cantor's theorem: for every set *S*, the power set of *S*—that is, the set of all subsets of *S* (here written as * P*(

*S*))—has a larger cardinality than

*S*itself. This proof proceeds as follows:

Let *f* be any function from *S* to * P*(

*S*). It suffices to prove

*f*cannot be surjective. That means that some member

*T*of

*(*

**P***S*), i.e. some subset of

*S*, is not in the image of

*f*. As a candidate consider the set:

*T*= {

*s*∈

*S*:

*s*∉

*f*(

*s*) }.

For every *s* in *S*, either *s* is in *T* or not. If *s* is in *T*, then by definition of *T*, *s* is not in *f*(*s*), so *T* is not equal to *f*(*s*). On the other hand, if *s* is not in *T*, then by definition of *T*, *s* is in *f*(*s*), so again *T* is not equal to *f*(*s*); cf. picture.
For a more complete account of this proof, see Cantor's theorem.

Consequences

This result implies that the notion of the set of all sets is an inconsistent notion. If *S* were the set of all sets then * P*(

*S*) would at the same time be bigger than

*S*and a subset of

*S*.

Russell's Paradox has shown us that naive set theory, based on an unrestricted comprehension scheme, is contradictory. Note that there is a similarity between the construction of *T* and the set in Russell's paradox. Therefore, depending on how we modify the axiom scheme of comprehension in order to avoid Russell's paradox, arguments such as the non-existence of a set of all sets may or may not remain valid.

The diagonal argument shows that the set of real numbers is "bigger" than the set of natural numbers (and therefore, the integers and rationals as well). Therefore, we can ask if there is a set whose cardinality is "between" that of the integers and that of the reals. This question leads to the famous continuum hypothesis. Similarly, the question of whether there exists a set whose cardinality is between |*S*| and |* P*(

*S*)| for some infinite

*S*leads to the generalized continuum hypothesis.

Analogues of the diagonal argument are widely used in mathematics to prove the existence or nonexistence of certain objects. For example, the conventional proof of the unsolvability of the halting problem is essentially a diagonal argument. Also, diagonalization was originally used to show the existence of arbitrarily hard complexity classes and played a key role in early attempts to prove P does not equal NP.

Version for Quine's New Foundations

The above proof fails for W. V. Quine's "New Foundations" set theory (NF). In NF, the naive axiom scheme of comprehension is modified to avoid the paradoxes by introducing a kind of "local" type theory. In this axiom scheme,

- {

*s*∈

*S*:

*s*∉

*f*(

*s*) }

is *not* a set — i.e., does not satisfy the axiom scheme. On the other hand, we might try to create a modified diagonal argument by noticing that

- {

*s*∈

*S*:

*s*∉

*f*({

*s*}) }

*is* a set in NF. In which case, if * P*1(

*S*) is the set of one-element subsets of

*S*and

*f*is a proposed bijection from

*1(*

**P***S*) to

*(*

**P***S*), one is able to use proof by contradiction to prove that |

*1(*

**P***S*)| < |

*(*

**P***S*)|.

The proof follows by the fact that if *f* were indeed a map *onto* * P*(

*S*), then we could find

*r*in

*S*, such that

*f*({

*r*}) coincides with the modified diagonal set, above. We would conclude that if

*r*is not in

*f*({

*r*}), then

*r*is in

*f*({

*r*}) and vice versa.

It is *not* possible to put * P*1(

*S*) in a one-to-one relation with

*S*, as the two have different types, and so any function so defined would violate the typing rules for the comprehension scheme.

See also

Cantor's first uncountability proof

Controversy over Cantor's theory

Diagonal lemma

## References

*Jahresbericht der Deutschen Mathematiker-Vereinigung*.

**1**: 75–78. English translation: Ewald, William B. (ed.) (1996).

*From Immanuel Kant to David Hilbert: A Source Book in the Foundations of Mathematics, Volume 2*. Oxford University Press. pp. 920–922. ISBN 0-19-850536-1.CS1 maint: extra text: authors list (link)

*Universality and the Liar: An Essay on Truth and the Diagonal Argument*. Cambridge University Press. ISBN 978-0-521-43069-2.

*Principles of Mathematical Analysis*(3rd ed.). New York: McGraw-Hill. p. 30. ISBN 0070856133.

*American Mathematical Monthly*,

**101**(9): 819–832, doi:10.2307/2975129, JSTOR 2975129

*The Real Numbers and Real Analysis*. New York: Springer. p. 429. ISBN 978-0-387-72176-7.

*The Logic of Infinity*(illustrated ed.). Cambridge University Press. p. 73. ISBN 978-1-107-05831-6. Extract of page 73

*Principles of mathematics*. Norton. pp. 363–366.

*Journal für die Reine und Angewandte Mathematik*,

**84**: 242–258. This proof is discussed in Joseph Dauben (1979),

*Georg Cantor: His Mathematics and Philosophy of the Infinite*, Harvard University Press, ISBN 0-674-34871-0, pp. 61–62, 65. On page 65, Dauben proves a result that is stronger than Cantor's. He lets "

*φν*denote any sequence of rationals in [0, 1]." Cantor lets

*φν*denote a sequence enumerating the rationals in [0, 1], which is the kind of sequence needed for his construction of a bijection between [0, 1] and the irrationals in (0, 1).

*Universality and the Liar: An Essay on Truth and the Diagonal Argument*