It Began with Babbage
Page 18
VII
Paradigms in the natural sciences differ in a fundamental way from paradigms of the kind that concerns us in this story. Consider, for example, the Darwinian paradigm in biology. Its vital element is the theory of natural selection, and this is a statement about the organic world as it is. Philosophers would call it a descriptive theory. The Darwinian paradigm is, accordingly, a descriptive paradigm, concerning the organic world as it is.
In contrast, what we are calling the stored-program computer paradigm is about an artificial world; the computer is an artifact, an invented thing. Any possible science that might be represented by this paradigm is a science of the artificial (see Prologue).38 And any paradigm characterizing an artificial science, dealing with an artifact (or a family of artifacts) is necessarily a prescriptive paradigm. It speaks of a world as it ought to be (see Prologue, Section II).
Natural scientists may agree or disagree about how the world really is; artificial scientists may agree or disagree about how the world ought to be. This distinction between is and ought is, equivalently, the distinction between what is true and what is right. It is the distinction between empirical statements that are true or false, and value judgments that distinguish between right or wrong with respect to some purpose or goal. The paradigms that govern the artificial sciences, being prescriptive, express value judgments; the paradigms that govern the natural sciences, being descriptive, express statements about facts. Thus, one can argue whether the special theory of relativity is true—that is, whether it is a correct description of some aspect of the physical world. One cannot argue whether the ENIAC is true—only whether it is achieves its stated purpose, or how well it achieves its stated purpose, how good or bad it is with respect to its intended purpose.
Let us keep this in mind for the purpose of this unfolding story. Let us always keep in mind that any science we associate with computers (which are artifacts), is a science of the artificial. A paradigm for an artificial science is, then, unconcerned fundamentally with truth or falsehood. It is concerned fundamentally with goodness or badness, rightness or wrongness—not in an ethical or moral sense, but relative to goals and purposes.
VIII
The EDVAC report, although intended for a few eyes only, was circulated widely. Its status for paradigmhood was a matter of social acceptance by those who were either working on, or were seriously interested in, computers.
One of those who read the EDVAC report was Alan Turing, who, at the end of World War II, joined (in June 1945) the newly formed mathematics division of Britain’s National Physical Laboratory (NPL) in Teddington, outside London.39 Turing’s boss at NPL, the man who had recruited him, mathematician John R. Womersley (1907–1958), head of the mathematics division, had shown Turing the EDVAC report.40 On joining NPL, Turing began working immediately on the preliminary design of a stored-program electronic computer.
The critical element in the EDVAC report—the critical factor in the viability of a stored-program computer—was the means to achieve an economical yet fast, large internal memory. Turing’s own “universal machine,” the product of his 1936 Entscheidungsproblem paper postulated a linear tape that would move left and right across a read/write head. In a lecture delivered to the London Mathematical Society in 1947 on his new project, he alluded to this abstract machine, but he pointed out that, although in the kind of computing machine he had envisioned it was necessary for the memory to be infinite, an infinite tape would be impractical in a “real” stored-program machine because of the time that would be spent in searching the tape for information needed at any given point of time.41
In fact, there was a physical artifact corresponding to Turing’s abstract idea. Prior to joining NPL, Turing had been sent to Germany as a member of an Anglo-American team to determine the status of German wartime communication technology.42 One of the captured German army devices was the magnetophone, an early form of the tape recorder.43 However, Turing rejected this mechanism for the reason mentioned earlier; it required too much back-and-forth movement.44 Instead, he favored the acoustic delay line as a memory device.
Such a delay line had been built by Presper Eckert and others at the Moore School in summer 1943, and was studied for application to radar.45 When plans for the EDVAC were being drawn up, Eckert and another member of the ENIAC team worked on a preliminary design of an acoustic delay memory using mercury.46 The credit for the idea lay entirely with Eckert, according to Goldstine.47
In the EDVAC report, von Neumann made no reference to any specific acoustic memory, Eckert’s or otherwise. Rather, he discussed at great length, in an abstract sort of way, a “delay memory” and its characteristics.48 He also described an alternative (and for him, preferred) form of memory “along the lines of the iconoscope,”49 an electrostatic storage tube that stored electrical charges and that, he believed, held distinct advantages over the delay line as memory.
The basic principle of the acoustic delay line memory is that because sound takes a certain amount of time to travel through a physical medium such as a liquid like mercury, for that duration of time, the medium may be said to be storing the sound wave. Consider a tube of mercury of some length. An electrical signal could be transformed into an acoustic disturbance, propagate through the mercury in the tube from one end, and be transformed back into an electrical signal at the other end. If this “output” electrical signal was fed back to the “input” to the tube, then one would have a memory device. Sound travels through mercury at the rate of 1450 meters/second. A tube of mercury 1.45 meters long will give a delay of 1 millisecond.
Translation of electrical pulses into an acoustic wave and the reverse could be done using a phenomenon called the piezoelectric effect, discovered in 1880 by French scientists Pierre Curie (1859–1906) and his brother Jacques (1856–1941). In this instance, an electrical disturbance imposed on a quartz crystal would cause the crystal to oscillate. When such a crystal was attached to the input side of a tube of mercury, the oscillation produced an acoustic pulse, which propagated through the mercury, taking a certain amount of time. After a delay, it caused another quartz crystal to vibrate, producing, in turn, an electrical pulse. The latter is returned, through appropriate circuits that reshape and amplify the pulse, to the input side of the tube.50
Suppose now a binary 1 is represented by a pulse 0.5 microsecond wide and a 0 is noted by the absence of a pulse. A pulse position (corresponding to a 1 or a 0 followed by a gap before the next pulse [1] or nonpulse [0]) would be 1 microsecond. Then, a single delay tube 1.45 meters long would hold a sequence of 1000 binary digits. To reshape and amplify the output pulse before recirculating it would need about 10 vacuum tubes. Thus, 1000 binary digits could be stored on a mercury tube at the cost of 10 vacuum tubes. If, on the other hand, vacuum tubes were used for memory (as in the ENIAC), then 1000 binary digits would need 1000 vacuum tubes. In terms of vacuum tube use, the cost of an acoustic memory reduces by a factor of 100 to 1.
Acknowledging that Eckert was the originator of the idea of using a delay line as memory, Turing chose this mechanism over alternatives because it was “already a going concern.”51
IX
Turing named the machine he began to design the ACE (Automatic Computing Engine). In 1945, he wrote Proposal for Development in the Mathematics Division of an Automatic Computing Engine (ACE), which was perhaps as extensive in scope and length as the EDVAC report.52 Although believing his own paper to be a completely comprehensive account of the design of his proposed machine, he added that his paper should be read alongside the EDVAC report.53 Thus, von Neumann’s paper appeared to have played a part in shaping Turing’s ideas about a practical stored-program computer—a curious and pleasing quid pro quo if, in fact, von Neumann’s idea had been shaped by Turing’s 1936 work.
It was an ambitious plan. The ACE would use a delay line memory of some 6400 words of 32 binary digits each, held in 200 long mercury delay lines.54 Unfortunately, the ACE project had more than its share of prob
lems, mainly in communications among its designers in NPL’s mathematics division and the implementers who were in the electronics section. Eventually, the problems were resolved and, in 1949, detailed design began on a much-stripped down version of the ACE, called Pilot ACE. Its memory capacity was much smaller than what Turing had originally planned, comprising 300 words of 32 binary digits each.55
Public demonstrations of the Pilot ACE were given in May 1950,56 but by then at least two other stored-program computers were operational (as we see later) both, as it happened, in England. The ACE project is significant to this story not because of priority-of-invention reasons; rather, it represents an almost instant recognition by Turing (and Womersley) at NPL of the significance of the stored-program concept. It was an important piece of evidence pointing to the acceptance of the stored-program computer as a computational paradigm.
Well before the public demonstrations of the Pilot ACE, however, Turing had left NPL. In September 1947, he took sabbatical leave from NPL and returned to Cambridge to resume his war-interrupted fellowship at King’s College.57 A year later, he resigned from NPL and moved to Manchester to take up a position created for him and funded by the Royal Society at the University of Manchester. His new position was deputy director of the Royal Society Computing Laboratory.58 The University of Manchester harbored computational ambitions.
X
If a paradigm, when born, elicits prompt recognition and acceptance by members of the relevant scientific community, if it initiates research programs (“normal science” in Kuhn’s language), if it is quickly assimilated and internalized as a mental schema by individuals, then, like Turing, but more effectively, the work by Englishman (later Sir) Maurice Wilkes (1913–2010) and his colleagues in Cambridge University between 1946 and 1949 epitomized these phenomena. Wilkes recognized the significance of the ideas put forth in the EDVAC report as soon as he first encountered them in May 1946. In his memoirs, written in 1985, he records how, on reading the report, he immediately recognized that this was “the real thing,” that this was the way the development of the computer would follow.59
It would be a travesty to call the work that Wilkes and his collaborators did in those first 3 years of peacetime as “normal science.” There was nothing remotely normal about it. Wilkes was on terra incognita, a terrain unknown not just to him, but also to everyone else. What Wilkes did was design and implement successfully and completely a computer called the Electronic Delay Storage Automatic Calculator (EDSAC) that not only adhered to the general principles of the stored-program computer, but also demonstrated empirically the viability of the concept. It was, in the realm of the artificial sciences, what in the natural sciences is called experimentum crucis, a crucial experiment that could make or break a theory or hypothesis. It was not the only experiment under way at that time to test the viability of the stored-program concept, but it was the first such complete experiment. In fact, it is fair to say that beginning with the EDSAC project, Wilkes’s scientific life entailed one long series of experiments that revealed how an artificial science (in this case, computer science) can be an empirical science.
The EDSAC project was significant in another sense. It opened up an entirely new region of the stored-program computer paradigm, a new class of artifacts the likes of which had never been seen before: computer programs or software.
XI
Wilkes obtained his BA degree in mathematics from Cambridge University (”mathematics tripos” in Cambridge language) in 1934, the same year as Turing. While Turing was a student (and later, fellow) of King’s College, Wilkes studied at (and would later become a fellow of) St. John’s College a few hundred yards away, but apparently they did not meet until much later.60
Wilkes was very much a “Cambridge man” who, on entering the university in 1931 as an undergraduate, spent his entire academic life in Cambridge until his retirement in 1980. When he died in Cambridge, he was emeritus professor of computer technology and a much-honored man, including the award of a knighthood.61
Wilkes’s forte during his early years was in applied mathematics, especially as applied to radio physics. He did his doctoral research at the Cavendish Laboratory (where the fabled Lord Rutherford was still the Cavendish professor and director), and obtained his PhD in 1938.62
By then, however, he had already encountered the lure of automatic computing. While working at the Cavendish, he came to know of the differential analyzer from a lecture in 1936 given by Douglas Hartree (1897–1958), a mathematician and numeric analyst and professor of applied mathematics at the University of Manchester. Hartree had built a differential analyzer for his department. The lecture was followed by a demonstration of a model version of the analyzer (built from components of what, in England, is called a meccano set and in America, an erector set), and was housed in the physical chemistry department of the university.
Working on the properties of long-wave radio waves, Wilkes was having to deal with the solution of differential equations. The machine beckoned, and soon he had obtained permission to use it.63 Not long after, he was put in charge of the machine. By a happy coincidence, the University of Cambridge had ambitions of acquiring a full-scale differential analyzer. By 1937, plans to establish a computing laboratory in the university were underway. It was named the University Mathematical Laboratory and it came into existence in 1937 as an independent academic department of the university.64 The part-time director of the laboratory was (later, Sir) John Lennard-Jones (1894–1954), professor of theoretical chemistry at the university, who had initiated the building of the model analyzer. In late 1937, Wilkes, still a doctoral research student, was appointed, a demonstrator at the university—effectively, a very junior academic position, in the Mathematical Laboratory.
After the end of World War II (during which Wilkes was engaged in radar development, application, and deployment), he returned to Cambridge, where he was promoted to the rank of university lecturer and appointed acting director of the Mathematical Laboratory. His main mandate was “to take part in the development of new machines and new methods of computing and to provide for the instruction of students.”65 The year after, in late 1946, he was formally appointed director of the laboratory, a position he would only relinquish on retirement 34 years later. In 1965, he was appointed to Cambridge’s first chair in computer technology—almost a decade after his election as an FRS, Britain’s most coveted scientific honor.
XII
At the time the war ended, Wilkes knew nothing about the developments in electronic digital computing, not in America and certainly not in Germany. Because of its highly classified nature he was not privy to the Colossus work in Bletchley Park, either.66 This situation was soon remedied—first, through Hartree, an authority in Britain on the differential analyzer and automatic computing, and through Comrie (whom we encountered much earlier in the story [see Chapter 5, Section V]), who had recently returned from a visit to America, bringing back with him a copy of the EDVAC report, which he gave to Wilkes. Therein lay, Wilkes recalled later, the fundamental principle of the stored-program computer.67
Soon after this, Wilkes received “suddenly” an invitation from Harold Pender (1879–1959), dean of the Moore School of Electrical Engineering, to attend a course offered by the school on electronic computers.68 The outcome was a first visit to the United States, meeting some of the main players in the development of automatic computing in America, including Goldstine and Mauchly in Philadelphia, and Howard Aiken and Samuel Caldwell in the “other” Cambridge. He observed the ENIAC and learned about the use of mercury delay lines as the basis for improved memory.69
Wilkes, like von Neumann in the EDVAC report, recognized the main disadvantage of the acoustic delay line memory: its slow access speed, because of the time needed for the acoustic pulse to circulate (hence the word delay), and the complicated timing circuits this entailed.70 But Wilkes, although formally trained as an applied mathematician, had a profoundly engineering mind. His was a pragmatic dispo
sition. Whatever doubts he may have harbored about acoustic delay line memory were put aside when, on return to England (on the Queen Mary) in September 1946, he met an Austrian-born research student in the Cavendish Laboratory, Thomas Gold (1920–2004), later a distinguished astrophysicist, who put before his “wondering eyes” a scale drawing of a mercury tank that would do the job.71 Gold’s wartime work was on radar, and in this context he had been involved in designing mercury tanks. Somewhat like Turing’s choice of delay lines for ACE, Wilkes’s choice of memory technology was dictated by pragmatics—in his case, not just the availability of technology, but also of human expertise to go with it.
XIII
The machine that Wilkes and his group built was called the Electronic Delay Storage Automatic Calculator—EDSAC, for short—and, like the ENIAC, the full name would be quickly forgotten or ignored (Figure 8.1).
Initially, apart from Gold (who helped him during the first experiments with mercury tanks),72 a workshop assistant, and a laboratory assistant, Wilkes was by himself. Later, an instrument maker, an electronic technician, and several research students would join the project. The latter included, in particular, William Renwick (1924–1971) and David Wheeler (1927–2004), both of whom would author or coauthor with Wilkes publications on the early Cambridge computers. Wheeler (as we will see) has a particularly important place in the consolidation of the stored-program computer paradigm.
FIGURE 8.1 Architecture of the EDSAC.
The full name of this machine suggests how much memory considerations were at the forefront of Wilkes’s consciousness. The EDVAC report paid much attention to this issue, but the EDVAC report also paid much attention to all aspects of the stored-program computer principles, including what von Neumann called “orders.”73 This was the word frequently used at the time to mean instructions. The collection of orders comprised the “order code” (in present-centered language, instruction set).