|
|
|||||||
{230} | A. M. Turing | [ NOV. 12 1936.] | ||||||
ON COMPUTABLE NUMBERS, WITH AN APPLICATION TO THEENTSCHEIDUNGSPROBLEMBy A. M. TURING |
||||||||
[Received 28 May, 1936.—Read 12 November, 1936.] |
On computable numbers, with an application to the Entscheidungsproblem was written by Alan Turing in 1936. | |||
Computing machinery and intelligence (Turing) | the Turing test and intelligence (abelard) | ||
|
|||
On computable numbers, with an application to the Entscheidungsproblem (Turing) | Decision processes (abelard) | ||
The document, decision processes by abelard, gives an empiric analysis of the Entscheidungsproblem.. Computing machinery and intelligence
was published by Alan Turing in 1950. |
This document uses advanced technology.
You will need to use a Microsoft Internet Explorer browser (version 4 or above), or Mozilla Firefox with an IE Tab or IE View Extension, to see this document in full. If, on your screen, the embedded character (above on the left) does not appear similar to the character on the right, your browser is unable to display these embedded characters. A suitable browser is available to download (free) from Microsoft . Such browsers (Microsoft browsers version 4 and higher) can also be found on many software CD-ROMs, or else go to the yellow link above for links to either of two different Firefox add-ons. If the characters do look similar, or if you don't care, continue to the document start. For those interested in the reason for this, the document includes embedded text achieved using a technique for font embedding that is supported only by Microsoft Internet Explorer. More universal versions of this technology are no longer widely available.. |
|
|
|||
1. Computing machines. | |||
2. Definitions. | |||
Automatic machines. | |||
Computing machines. | |||
Circle and circle-free numbers. | |||
Computable sequences and numbers. | |||
3. Examples of computing machines. | |||
4. Abbreviated tables | |||
Further examples. | |||
5. Enumeration of computable sequences. | |||
6. The universal computing machine. | |||
7. Detailed description of the universal machine. | |||
8. Application of the diagonal process. | |||
9. The extent of the computable numbers. | |||
10. Examples of large classes of numbers which are computable. | |||
11. Application to the Entscheidungsproblem. | |||
APPENDIX | |||
ON COMPUTABLE NUMBERS, WITH AN APPLICATION TO THE ENTSCHEIDUNGSPROBLEM. A CORRECTION By A. M. Turing |
|||
Publisher’s copyright notice—the London Mathematical Society | |||
|
|||
The “computable” numbers may be described briefly as the real numbers whose expressions as a decimal are calculable by finite means. Although the subject of this paper is ostensibly the computable numbers, it is almost equally easy to define and investigate computable functions of an integral variable or a real or computable variable, computable predicates, and so forth. The fundamental problems involved are, however, the same in each case, and I have chosen the computable numbers for explicit treatment as involving the least cumbrous technique. I hope shortly to give an account of the relations of the computable numbers, functions, and so forth to one another. This will include a development of the theory of functions of a real variable expressed in terms of computable numbers. According to my definition, a number is computable if its decimal can be written down by a machine. In §§ 9, 10 I give some arguments with the intention of showing that the computable numbers include all numbers which could naturally be regarded as computable. In particular, I show that certain large classes of numbers are computable. They include, for instance, the real parts of all algebraic numbers, the real parts of the zeros of the Bessel functions, the numbers X, e, etc. The computable numbers do not, however, include all definable numbers, and an example is given of a definable number which is not computable. Although the class of computable numbers is so great, and in many ways similar to the class of real numbers, it is nevertheless enumerable. In §8 I examine certain arguments which would seem to prove the contrary. By the correct application of one of these arguments, conclusions are reached which are superficially similar to those of Gödel [1] . These results {231} have valuable applications. In particular, it is shown (§11) that the Hilbertian Entscheidungsproblem can have no solution. In a recent paper Alonzo Church[2] has introduced an idea of “effective calculability”, which is equivalent to my “computability”, but is very differently defined. Church also reaches similar conclusions about the Entscheidungsproblem.[3] The proof of equivalence between “computability” and “effective calculability” is outlined in an appendix to the present paper.
|
|||
1. Computing machines.We have said that the computable numbers are those whose decimals are calculable by finite means. This requires rather more explicit definition. No real attempt will be made to justify the definitions given until we reach §9. For the present I shall only say that the justification lies in the fact that the human memory is necessarily limited. We may compare a man in the process of computing a real number to a machine which is only capable of a finite number of conditions q1, q2, ..., qR which will be called “m-configurations”. The machine is supplied with a “tape”, (the analogue of paper) running through it, and divided into sections (called “squares”) each capable of bearing a “symbol”. At any moment there is just one square, say the r-th, bearing the symbol S(r) which is “in the machine”. We may call this square the “scanned square”. The symbol on the scanned square may be called the “scanned symbol”. The “scanned symbol” is the only one of which the machine is, so to speak, “directly aware”. However, by altering its m-configuration the machine can effectively remember some of the symbols which it has “seen” (scanned) previously. The possible behaviour of the machine at any moment is determined by the m-configuration qn and the scanned symbol S(r). This pair qn, S(r) will be called the “configuration”: thus the configuration determines the possible behaviour of the machine. In some of the configurations in which the scanned square is blank (i.e. bears no symbol) the machine writes down a new symbol on the scanned square: in other configurations it erases the scanned symbol. The machine may also change the square which is being scanned, but only by shifting it one place to right or left. In addition to any of these operations the m-configuration may be changed. Some of the symbols written down {232} will form the sequence of figures which is the decimal of the real number which is being computed. The others are just rough notes to “assist the memory”. It will only be these rough notes which will be liable to erasure. It is my contention that these operations include all those which are used in the computation of a number. The defence of this contention will be easier when the theory of the machines is familiar to the reader. In the next section I therefore proceed with the development of the theory and assume that it is understood what is meant by “machine”, “tape”, “scanned”, etc. |
2. Definitions.Automatic machines.If at each stage the motion of a machine (in the sense of §1) is completely determined by the configuration, we shall call the machine an “automatic machine” (or a-machine). For some purposes we might use machines (choice machines or c-machines) whose motion is only partially determined by the configuration (hence the use of the word “possible” in §1). When such a machine reaches one of these ambiguous configurations, it cannot go on until some arbitrary choice has been made by an external operator. This would be the case if we were using machines to deal with axiomatic systems. In this paper I deal only with automatic machines, and will therefore often omit the prefix a-. Computing machines.If an a-machine prints two kinds of symbols, of which the first kind (called figures) consists entirely of 0 and 1 (the others being called symbols of the second kind), then the machine will be called a computing machine. If the machine is supplied with a blank tape and set in motion, starting from the correct initial m-configuration, the subsequence of the symbols printed by it which are of the first kind will be called the sequence computed by the machine. The real number whose expression as a binary decimal is obtained by prefacing this sequence by a decimal point is called the number computed by the machine. At any stage of the motion of the machine, the number of the scanned square, the complete sequence of all symbols on the tape, and the m-configuration will be said to describe the complete configuration at that stage. The changes of the machine and tape between successive complete configurations will be called the moves of the machine. {233} If a computing machine never writes down more than a finite number of symbols of the first kind it will be called circular. Otherwise it is said to be circle-free. A machine will be circular if it reaches a configuration from which there is no possible move, or if it goes on moving, and possibly printing symbols of the second kind, but cannot print any more symbols of the first kind. The significance of the term “circular” will be explained in §8.Computable sequences and numbers.A sequence is said to be computable if it can be computed by a circle-free machine. A number is computable if it differs by an integer from the number computed by a circle-free machine. We shall avoid confusion by speaking more often of computable sequences than of computable numbers. |
advertising disclaimer |
3. Examples of computing machines.I. A machine can be constructed to compute the sequence 010101.... The machine is to have the four m-configurations “ b”, “c”, “z”, “e” and is capable of printing “0”, and “1”. The behaviour of the machine is described in the following table in which “R” means “the machine moves so that it scans the square immediately on the right of the one it was scanning previously”. Similarly for “L”. “E” means the scanned symbol is “erased” and “P” stands for “prints”. This table (and all succeeding tables of the same kind) is to be understood to mean that for a configuration described in the first two columns the operations in the third column are carried out successively, and the machine then goes over into the m-configuration described in the last column. When the second column is left blank, it is understood that the behaviour of the third and fourth columns applies for any symbol and for no symbol. The machine starts in the m-configuration b with a blank tape.
{234}If (contrary to the description in §1) we allow the letters L, R to appear more than once in the operations column we can simplify the table considerably.
II. As a slightly more difficult example we can construct a machine to compute the sequence 001011011101111011111.... The machine is to be capable of five m-configurations, viz. “o”, “q”, “p”, “f”, “b” and of printing “e”, “x”, “0”, “1”. The first three symbols on the tape will be “ e e 0”; the other figures follow on alternate squares. On the intermediate squares we never print anything but “x”. These letters serve to “keep the place” for us and are erased when we have finished with them. We also arrange that in the sequence of figures on alternate squares there shall be no blanks. To illustrate the working of this machine a table is given below of the first few complete configurations. These complete configurations are described by writing down the sequence of symbols which are on the tape, {235} with the m-configuration written below the scanned symbol. The successive complete configurations are separated by colons.
This table could also be written in the form
in which a space has been made on the left of the scanned symbol and the m-configuration written in this space. This form is less easy to follow, but we shall make use of it later for theoretical purposes. The convention of writing the figures only on alternate squares is very useful: I shall always make use of it. I shall call the one sequence of alternate squares F-squares and the other sequence E-squares. The symbols on E-squares will be liable to erasure. The symbols on F-squares form a continuous sequence. There are no blanks until the end is reached. There is no need to have more than one E-square between each pair of F-squares: an apparent need of more E-squares can be satisfied by having a sufficiently rich variety of symbols capable of being printed on E-squares. If a symbol J- is on an F-square S and a symbol I is on the E-square next on the right of S, then S and J will be said to be marked with I. The process of printing this I will be called marking J (or S) with I. |
4. Abbreviated tablesThere are certain types of process used by nearly all machines, and these, in some machines, are used in many connections. These processes include copying down sequences of symbols, comparing sequences, erasing all symbols of a given form, etc. Where such processes are concerned we can abbreviate the tables for the m-configurations considerably by the use of “skeleton tables”. In skeleton tables there appear capital German letters [4] and small Greek letters. These are of the nature of “variables”. By replacing each capital German letter throughout by an m-configuration {236} and each small Greek letter by a symbol, we obtain the table for an m-configuration. The skeleton tables are to be regarded as nothing but abbreviations: they are not essential. So long as the reader understands how to obtain the complete tables from the skeleton tables, there is no need to give any exact definitions in this connection. Let us consider an example: If we were to replace C throughout by q (say), B by r, and I by x, we should have a complete table for the m-configuration f(qYr, x). f is called an “m-configuration function” or “m-function”. The only expressions which are admissible for substitution in an m-function are the m-configurations and symbols of the machine. Those have to be enumerated more or less explicitly: they may include expressions such as p (e, x); indeed they must if there are any m-functions used at all. If we did not insist on this explicit enumeration but simply stated that the machine had certain m-configurations (enumerated) and all m-configurations obtainable by substitution of m-configurations in certain m-functions, we should usually get an infinity of m-configurations; e.g., we might say that the machine was to have the m-configuration q and all m-configurations obtainable by substituting an m-configuration for C in p(C). Then it would have qY p(q), p(p(q)),p(p(p(q))) ... as m-configurations. Our interpretation rule then is this. We are given the names of the m-configurations of the machine, mostly expressed in terms of m-functions. We are also given skeleton tables. All we want is the complete table for the m-configurations of the machine. This is obtained by repeated substitution in the skeleton tables. (In the explanations the symbol “\” is used to signify “the machine goes into the m-configuration ...”)
The last example seems somewhat more difficult to interpret than most. Let us suppose that in the list of m-configurations of some machine there appears e(b, x) (= q, say). The table is
Or, in greater detail:
In this we could replace e1(qYB, x) by q' and then give the table for f(with the right substitutions) and eventually reach a table in which no m-functions appeared. {238} The last line stands for the totality of lines obtainable from it by replacing J by any symbol which may occur on the tape of the machine concerned. The first symbol marked I and the first marked J are compared. If there is neither I nor J \E. If there are both and the symbols are alike, \C. Otherwise \U.
cpe(CYUYEYI,J) differs from cp(CYUYEYI,J) in that in the case when there is similarity the first I and J are erased.
cpe(UYEYI,J).
The sequence of symbols marked I is compared
with the sequence marked J.
\E if they are similar. Otherwise U.
Some of the symbols Iand Jare
erased. |
5. Enumeration of computable sequences.A computable sequence O is determined by a description of a machine which computes O. Thus the sequence 001011011101111... is determined by the table on p.234, and, in fact, any computable sequence is capable of being described in terms of such a table. It will be useful to put these tables into a kind of standard form. In the first place let us suppose that the table is given in the same form as the first table, for example, I on p.233. That is to say, that the entry in the operations column is always of one of the forms E : E, R : E, L : Pa : Pa, R : Pa, L : R : L : or no entry at all. The table can always be put into this form by introducing more m-configurations. Now let us give numbers to the m-configurations, calling them q1 , ..., qR, as in § 1. The initial m-configuration is always to be called q1. We also give numbers to the symbols S1, …, Sm{240}and, in particular, blank = S0, 0 = S1 , l = S2. The lines of the table are now of form
Lines such as
Are to be written as
And lines such as
To be written as
In this way we reduce each line of the table to a line of one of the forms (N1), (N2), (N3). From each line of form (N1) let us form an expression qi Sj Sk L qm; from each line of form (N2) we form an expression qi Si Sk R qm; and from each line of form (N3) we form an expression qi Sj Sk Nqm. Let us write down all expressions so formed from the table for the machine and separate them by semi-colons. In this way we obtain a complete description of the machine. In this description we shall replace qi by the letter “D” followed by the letter “A” repeated i times, and Sj by “D” followed by “C” repeated j times. This new description of the machine may be called the standard description (S.D). It is made up entirely from the letters “A”, “C”, “D”, “L”, “R”, “N”, and from “;”. If finally we replace “A” by “1”, “C” by “2”, “D” by “3”, “L” by “4”, “R” by “5”, “N” by “6”, and “;” by “7” we shall have a description of the machine in the form of an arabic numeral. The integer represented by this numeral may be called a description number (D.N) of the machine. The D.N determine the S.D and the structure of the {241} machine uniquely. The machine whose D.N is n may be described as M(n). To each computable sequence there corresponds at least one description number, while to no description number does there correspond more than one computable sequence. The computable sequences and numbers arc therefore enumerable. Let us find a description number for the machine I of §3. When we rename the m-configurations its table becomes:
Other tables could be obtained by adding irrelevant lines such as
Our first standard form would be
The standard description is
A description number is
and so is
A number which is a description number of a circle-free machine will be called a satisfactory number. In §8 it is shown that there can be no general process for determining whether a given number is satisfactory or not. |
6. The universal computing machine.It is possible to invent a single machine which can be used to compute any computable sequence. If this machine I is supplied with a tape on the beginning of which is written the S.D of some computing machine M, {242} then I will compute the same sequence as M. In this section I explain in outline the behavior of the machine. The next section is devoted to giving the complete table for I. Let us first suppose that we have a machine M' which will write down on the F-squares the successive complete configurations of M. These might be expressed in the same form as on p.235, using the second description, (C), with all symbols on one line. Or, better, we could transform this description (as in §5) by replacing each m-configuration by “D” followed by “A” repeated the appropriate number of times, and by replacing each symbol by “D” followed by “C” repeated the appropriate number of times. The numbers of letters “A” and “C” are to agree with the numbers chosen in §5, so that, in particular, “0” is replaced by “DC”, “1” by “DCC”, and the blanks by “D” . These substitutions are to be made after the complete configurations have been put together, as in (C). Difficulties arise if we do the substitution first. In each complete configuration the blanks would all have to be replaced by “D” , so that the complete configuration would not be expressed as a finite sequence of symbols. If in the description of the machine II of §3 we replace “o ” by “DAA”, “e” by “DCCC ”, “q”by “DAAA”, then the sequence (C) becomes:
(This is the sequence of symbols on F-squares.) It is not difficult to see that if M can be constructed, then so can M'. The manner of operation of M' could be made to depend on having the rules of operation (i.e., the S.D) of it written somewhere within itself (i.e. within M'); each step could be carried out by referring to these rules. We have only to regard the rates as being capable of being taken out and exchanged or others and we have something very akin to the universal machine. One thing is lacking: at present the machine M' prints no figures. We may correct this by printing between each successive pair of complete configurations the figures which appear in the new configuration but not in the old. Then (C1) becomes
It is not altogether obvious that the E-squares leave enough room for the necessary “rough work”, but this is, in fact, the case. The sequences of letters between the colons in expressions such as (C1) may be used as standard descriptions of the complete configurations. When the letters are replaced by figures, as in §5, we shall have a numerical {243} description of the complete configuration, which may be called its description number. |
7. Detailed description of the universal machine.A table is given below of the behaviour of this universal machine. The m-configurations of which the machine is capable are all those occurring in the first and last columns of the table, together with all those which occur when we write out the unabbreviated tables of those which appear in the table in the form of m-functions. E.g., e(anf) appears in the table and is an m-function. Its unabbreviated table is (see p. 239)
Consequently e1(anf) is an m-configuration of I. When I is ready to start work the tape running through it bears on it the symbol e on an F-square and again e on the next E-square; after this, on F-squares only, comes the S.D of the machine followed by a double colon “: :” (a single symbol, on an F-square). The S.D consists of a number of instructions, separated by semi-colons. Each instruction consists of five consecutive parts i ) “D” followed by a sequence of letters “A”.
This describes the relevant m-configuration. iii ) “D” followed by another sequence of letters
“C”. This describes the symbol into which the scanned
symbol is to be changed. The machine I is to be capable of printing
“A”, “C”, “D”,
“0”, “1”, “u”, “v”,
“w”, “x”, “y”,
“z”. {244} Subsidiary skeleton table. The table for U. |