ENIAC

From Infogalactic: the planetary knowledge core
Jump to: navigation, search
ENIAC
ENIAC Penn1.jpg
ENIAC is located in Philadelphia
ENIAC
Location within Philadelphia
Location S 33rd St., S of Walnut St.
Coordinates Lua error in package.lua at line 80: module 'strict' not found.
PA marker dedicated Thursday, June 15, 2000
Glen Beck (background) and Betty Snyder (foreground) program ENIAC in BRL building 328. (U.S. Army photo)
Programmers Betty Jean Jennings (left) and Fran Bilas (right) operate ENIAC's main control panel at the Moore School of Electrical Engineering. (U.S. Army photo from the archives of the ARL Technical Library)

ENIAC (/ˈini.æk/ or /ˈɛni.æk/; Electronic Numerical Integrator And Computer)[1][2] was the first electronic general-purpose computer. It was Turing-complete, digital, and could solve "a large class of numerical problems" through reprogramming.[3][4]

Though ENIAC was designed and primarily used to calculate artillery firing tables for the United States Army's Ballistic Research Laboratory,[5][6] its first programs included a study of the feasibility of the thermonuclear weapon.[7]

When ENIAC was announced in 1946, it was heralded as a "Giant Brain" by the press.[8] It had a speed on the order of one thousand (103) times faster than that of electro-mechanical machines; this computational power, coupled with general-purpose programmability, excited scientists[who?] and industrialists[who?] alike.

Development and design

ENIAC's design and construction was financed by the United States Army, Ordnance Corps, Research and Development Command, led by Major General Gladeon M. Barnes. The construction contract was signed on June 5, 1943; work on the computer began in secret at the University of Pennsylvania's Moore School of Electrical Engineering[9] the following month, under the code name "Project PX."

ENIAC was designed by John Mauchly and J. Presper Eckert of the University of Pennsylvania, U.S.[10] The team of design engineers assisting the development included Robert F. Shaw (function tables), Jeffrey Chuan Chu (divider/square-rooter), Thomas Kite Sharpless (master programmer), Arthur Burks (multiplier), Harry Huskey (reader/printer) and Jack Davis (accumulators). In 1946, the researchers resigned from the University of Pennsylvania and formed the Eckert-Mauchly Computer Corporation.

ENIAC was a modular computer, composed of individual panels to perform different functions. Twenty of these modules were accumulators, which could not only add and subtract but hold a ten-digit decimal number in memory. Numbers were passed between these units across several general-purpose buses (or trays, as they were called). In order to achieve its high speed, the panels had to send and receive numbers, compute, save the answer and trigger the next operation, all without any moving parts. Key to its versatility was the ability to branch; it could trigger different operations, depending on the sign of a computed result.

Components

ENIAC contained 17,468 vacuum tubes, 7200 crystal[citation needed] diodes, 1500 relays, 70,000 resistors, 10,000 capacitors and approximately 5,000,000 hand-soldered joints. It weighed more than 30 short tons (27 t), was roughly 2.4m × 0.9m × 30m (8 × 3 × 100 feet) in size, occupied 167m2 (1800 ft2) and consumed 150 kW of electricity.[11][12] This power requirement led to the rumor that whenever the computer was switched on, lights in Philadelphia dimmed.[13] Input was possible from an IBM card reader; an IBM card punch was used for output. These cards could be used to produce printed output offline using an IBM accounting machine, such as the IBM 405.

ENIAC used ten-position ring counters to store digits; each digit required 36 vacuum tubes, 10 of which were the dual triodes making up the flip-flops of the ring counter. Arithmetic was performed by "counting" pulses with the ring counters and generating carry pulses if the counter "wrapped around," the idea being to electronically emulate the operation of the digit wheels of a mechanical adding machine.

ENIAC had 20 ten-digit signed accumulators, which used ten's complement representation and could perform 5000 simple addition or subtraction operations between any of them and a source (e.g., another accumulator or a constant transmitter) every second. It was possible to connect several accumulators to run simultaneously, so the peak speed of operation was potentially much higher, due to parallel operation.

It was possible to wire the carry of one accumulator into another accumulator to perform double precision arithmetic, but the accumulator carry circuit timing prevented the wiring of 3+ for even higher precision. ENIAC used 4 of the accumulators (controlled by a special multiplier unit) to perform up to 385 multiplication operations/second; 5 of the accumulators were controlled by a special divider/square-rooter unit to perform up to 40 division operations/second or 3 square root operations/second.

The other 9 units in ENIAC were the Initiating Unit (started and stopped the machine), the Cycling Unit (used for synchronizing the other units), the Master Programmer (controlled "loop" sequencing), the Reader (controlled an IBM punch-card reader), the Printer (controlled an IBM card punch), the Constant Transmitter and 3 function tables.[clarification needed]

Cpl. Irwin Goldstein (foreground) sets the switches on one of ENIAC's function tables at the Moore School of Electrical Engineering. (U.S. Army photo) [14]

Operation Times

The references by Rojas and Hashagen (or Wilkes)[10] give more details about the times for operations, which differ somewhat from those stated above.

The basic machine cycle was 200 microseconds (20 cycles of the 100 kHz clock in the cycling unit), or 5,000 cycles per second for operations on the 10-digit numbers. In one of these cycles, ENIAC could write a number to a register, read a number from a register, or add/subtract two numbers.

A multiplication of a 10-digit number by a d-digit number (for d up to 10) took d+4 cycles, so a 10- by 10-digit multiplication took 14 cycles, or 2800 microseconds—a rate of 357 per second. If one of the numbers had fewer than 10 digits, the operation was faster.

Division and square roots took 13(d+1) cycles, where d is the number of digits in the result (quotient or square root). So a division or square root took up to 143 cycles, or 28,600 microseconds—a rate of 35 per second. (Wilkes 1956:20[10] states that a division with a 10 digit quotient required 6 milliseconds.) If the result had fewer than ten digits, it was obtained faster.

Reliability

ENIAC used common octal-base radio tubes of the day; the decimal accumulators were made of 6SN7 flip-flops, while 6L7's, 6SJ7's, 6SA7's and 6AC7's were used in logic functions.[15] Numerous 6L6's and 6V6's served as line drivers to drive pulses through cables between rack assemblies.

Several tubes burned out almost every day, leaving it nonfunctional about half the time. Special high-reliability tubes were not available until 1948. Most of these failures, however, occurred during the warm-up and cool-down periods, when the tube heaters and cathodes were under the most thermal stress. Engineers reduced ENIAC's tube failures to the more acceptable rate of one tube every two days. According to a 1989 interview with Eckert, "We had a tube fail about every two days and we could locate the problem within 15 minutes."[16] In 1954, the longest continuous period of operation without a failure was 116 hours—close to five days.

Programming

ENIAC could be programmed to perform complex sequences of operations, including loops, branches, and subroutines. The task of taking a problem and mapping it onto the machine was complex, and usually took weeks. After the program was figured out on paper, the process of getting the program into ENIAC by manipulating its switches and cables could take days. This was followed by a period of verification and debugging, aided by the ability to execute the program step by step. A programming tutorial for the modulo function using an ENIAC simulator gives an impression how a program on the ENIAC looked like.[17]

ENIAC's six primary programmers, Kay McNulty, Betty Jennings, Betty Snyder, Marlyn Wescoff, Fran Bilas and Ruth Lichterman, not only determined how to input ENIAC programs, but also developed a deep understanding of ENIAC's inner workings.[18][19] The programmers debugged problems by crawling inside the massive structure to find bad joints and bad tubes. Betty Jennings later recalled, "Since we knew both the application and the machine, we learned to diagnose troubles as well as, if not better than, the engineer."[20]

Herman Goldstine selected the programmers, then called "operators", from the human "computers" who had been calculating ballistics tables with desk calculators and a differential analyzer prior to and during the development of ENIAC.[21] Under Herman and Adele Goldstine's direction, the programmers studied ENIAC's blueprints and physical structure to determine how to manipulate its switches and cables, rather than learning a programming language. Though contemporaries considered programming a clerical task and did not publicly recognize the programmers' impact on the successful operation and announcement of ENIAC,[21] McNulty, Jennings, Snyder, Wescoff, Bilas, and Lichterman have since been recognized for their ground-breaking contributions to computing.[22][23][24][25]

Following the initial six programmers, an expanded team of a hundred scientists was recruited to continue work on the ENIAC. Among these were several women again, including Gloria Ruth Gordon.[26]

Role in the Hydrogen Bomb

Although the Ballistic Research Laboratory was the sponsor of ENIAC, one year into this three-year project John von Neumann, a mathematician working on the hydrogen bomb at Los Alamos, became aware of this computer.[27] Los Alamos subsequently became so involved with ENIAC that the first test problem ran consisted of computations for the hydrogen bomb, not artillery tables.[6] The input/output for this test was one million cards.[28]

Later developments

The completed machine was announced to the public the evening of February 14, 1946[29] and formally dedicated the next day[30] at the University of Pennsylvania. The original contract amount was $61,700; the final cost was almost $500,000 (approximately $6,100,000 today). It was formally accepted by the U.S. Army Ordnance Corps in July 1946. ENIAC was shut down on November 9, 1946 for a refurbishment and a memory upgrade, and was transferred to Aberdeen Proving Ground, Maryland in 1947. There, on July 29, 1947, it was turned on and was in continuous operation until 11:45 p.m. on October 2, 1955.[2]

Role in the development of the EDVAC

A few months after ENIAC's unveiling, in the summer of 1946, as part of "an extraordinary effort to jump-start research in the field",[31] the Pentagon invited "the top people in electronics and mathematics from the United States and Great Britain"[31] to a series of forty-eight lectures altogether called The Theory and Techniques for Design of Digital Computers more often named the Moore School Lectures.[31] Half of these lectures were given by the inventors of ENIAC.[32]

ENIAC was a one-of-a-kind design and was never repeated. The freeze on design in 1943 meant that the computer design would lack some innovations that soon became well-developed, notably the ability to store a program. Eckert and Mauchly started work on a new design, to be later called the EDVAC, which would be both simpler and more powerful. In particular, in 1944 Eckert wrote his description of a memory unit (the mercury delay line) which would hold both the data and the program. John von Neumann, who was consulting for the Moore School on the EDVAC, sat in on the Moore School meetings at which the stored program concept was elaborated. Von Neumann wrote up an incomplete set of notes (First Draft of a Report on the EDVAC) which were intended to be used as an internal memorandum describing, elaborating, and couching in formal logical language the ideas developed in the meetings. ENIAC administrator and security officer Herman Goldstine distributed copies of this First Draft to a number of government and educational institutions, spurring widespread interest in the construction of a new generation of electronic computing machines, including Electronic Delay Storage Automatic Calculator (EDSAC) at Cambridge, England and SEAC at the U.S. Bureau of Standards.

Improvements

A number of improvements were made to ENIAC after 1948, including a primitive read-only stored programming mechanism[33] using the Function Tables as program ROM, an idea included in the ENIAC patent and proposed independently by Dr. Richard Clippinger of BRL. Clippinger consulted with von Neumann on what instruction set to implement. Clippinger had thought of a 3-address architecture while von Neumann proposed a 1-address architecture because it was simpler to implement. Three digits of one accumulator (6) were used as the program counter, another accumulator (15) was used as the main accumulator, a third accumulator (8) was used as the address pointer for reading data from the function tables, and most of the other accumulators (1–5, 7, 9–14, 17–19) were used for data memory.

The programming of the stored program for ENIAC was done by Betty Jennings, Clippinger and Adele Goldstine. It was first demonstrated as a stored-program computer on September 16, 1948, running a program by Adele Goldstine for John von Neumann. This modification reduced the speed of ENIAC by a factor of six and eliminated the ability of parallel computation, but as it also reduced the reprogramming time to hours instead of days, it was considered well worth the loss of performance. Also analysis had shown that due to differences between the electronic speed of computation and the electromechanical speed of input/output, almost any real-world problem was completely I/O bound, even without making use of the original machine's parallelism. Most computations would still be I/O bound, even after the speed reduction imposed by this modification.

Early in 1952, a high-speed shifter was added, which improved the speed for shifting by a factor of five. In July 1953, a 100-word expansion core memory was added to the system, using binary coded decimal, excess-3 number representation. To support this expansion memory, ENIAC was equipped with a new Function Table selector, a memory address selector, pulse-shaping circuits, and three new orders were added to the programming mechanism.

Comparison with other early computers

<templatestyles src="Module:Hatnote/styles.css"></templatestyles>

A function table from ENIAC on display at Aberdeen Proving Ground museum.

Mechanical and electrical computing machines have been around since the 19th century, but the 1930s and 1940s are considered the beginning of the modern computer era.

ENIAC was, like the Z3 and Harvard Mark I, able to run an arbitrary sequence of mathematical operations, but did not read them from a tape. Like the Colossus, it was programmed by plugboard and switches. ENIAC combined full, Turing complete programmability with electronic speed. The Atanasoff–Berry Computer (ABC), ENIAC, and Colossus all used thermionic valves (vacuum tubes). ENIAC's registers performed decimal arithmetic, rather than binary arithmetic like the Z3 or the ABC.

Like the Colossus, ENIAC required rewiring to reprogram until September 1948. Three months earlier, in June 1948, the Manchester Small-Scale Experimental Machine (SSEM) ran its first program and earned the distinction of first stored-program computer. Though the idea of a stored-program computer with combined memory for program and data was conceived during the development of ENIAC, it was not initially implemented in ENIAC because World War II priorities required the machine to be completed quickly, and ENIAC's 20 storage locations would be too small to hold data and programs.

Public knowledge

The Z3 and Colossus were developed independently of each other and of the ABC and ENIAC during World War II. The Z3 was destroyed by the Allied bombing raids of Berlin in 1943. The Colossus machines were part of the UK's war effort. Their existence only became generally known in the 1970s, though knowledge of their capabilities remained among their UK staff and invited Americans. All but two of the machines that remained in use in GCHQ until the 1960s, were destroyed in 1945.[citation needed] The ABC was dismantled by Iowa State University, after John Atanasoff was called to Washington, D.C., to do physics research for the U.S. Navy.

ENIAC, by contrast, was put through its paces for the press in 1946, "and captured the world's imagination".[34] Older histories of computing may therefore not be comprehensive in their coverage and analysis of this period.

Patent

<templatestyles src="Module:Hatnote/styles.css"></templatestyles>

For a variety of reasons (including Mauchly's June 1941 examination of the Atanasoff–Berry Computer, prototyped in 1939 by John Atanasoff and Clifford Berry), U.S. Patent 3,120,606 for ENIAC, applied for in 1947 and granted in 1964, was voided by the 1973 decision of the landmark federal court case Honeywell v. Sperry Rand, putting the invention of the electronic digital computer in the public domain and providing legal recognition to Atanasoff as the inventor of the first electronic digital computer.

Parts on display

Detail of the back of a section of ENIAC, showing vacuum tubes

Pieces of ENIAC are held by the following institutions:

Recognition

ENIAC was named an IEEE Milestone in 1987.[36]

In 1995, a very small silicon chip measuring 7.44 mm by 5.29 mm was built with the same functionality as ENIAC. Although this 20 MHz chip was many times faster than ENIAC, it had but a fraction of the speed of modern microprocessors of the late 1990s.[37][38]

In 1997, the six women who did most of the programming of ENIAC were inducted into the Women in Technology International Hall of Fame.[22][23] The role of the ENIAC programmers is treated in a 2010 documentary film titled Top Secret Rosies: The Female "Computers" of WWII by LeAnn Erickson.[24] A 2014 documentary short, The Computers by Kate McMahon tells of the story of the six programmers.[25]

In 2011, to honor of the 65th anniversary of the ENIAC's unveiling, the city of Philadelphia declared February 15 as The ENIAC Day.[39]

See also

Notes

  1. John Presper Eckert Jr. and John W. Mauchly, Electronic Numerical Integrator and Computer, United States Patent Office, US Patent 3,120,606, filed 26 June 1947, issued 4 February 1964; invalidated 19 October 1973 after court ruling on Honeywell v. Sperry Rand.
  2. 2.0 2.1 Lua error in package.lua at line 80: module 'strict' not found.
  3. Goldstine & Goldstine 1946, p. 97
  4. Lua error in package.lua at line 80: module 'strict' not found.
  5. Lua error in package.lua at line 80: module 'strict' not found.
  6. 6.0 6.1 Goldstine 1972, p. 214
  7. Scott McCartney p.103 (1999): "ENIAC correctly showed that Teller's scheme would not work, but the results led Teller and Ulam to come up with another design together."
  8. Brain used in the press as a metaphor became common during the war years. Looking, for example, at Life magazine: August 16, 1937 p.45 Overseas Air Lines Rely on Magic Brain (RCA Radiocompass). March 9, 1942 p.55 the Magic Brain—is a development of RCA engineers (RCA Victrola). December 14, 1942 p.8 Blanket with a Brain does the rest! (GE Automatic Blanket). November 8, 1943 p.8 Mechanical brain sights gun (How to boss a BOFORS!)
  9. Goldstine & Goldstine 1946
  10. 10.0 10.1 10.2 Lua error in package.lua at line 80: module 'strict' not found.
  11. Lua error in package.lua at line 80: module 'strict' not found.
  12. Lua error in package.lua at line 80: module 'strict' not found.
  13. Lua error in package.lua at line 80: module 'strict' not found.
  14. The original photo can be seen in the article: Lua error in package.lua at line 80: module 'strict' not found.
  15. Burks 1947, pp. 756–767
  16. Lua error in package.lua at line 80: module 'strict' not found.
  17. Lua error in package.lua at line 80: module 'strict' not found.
  18. Lua error in package.lua at line 80: module 'strict' not found.
  19. Lua error in package.lua at line 80: module 'strict' not found.
  20. Lua error in package.lua at line 80: module 'strict' not found.
  21. 21.0 21.1 Lua error in package.lua at line 80: module 'strict' not found.
  22. 22.0 22.1 Lua error in package.lua at line 80: module 'strict' not found.
  23. 23.0 23.1 Lua error in package.lua at line 80: module 'strict' not found.
  24. 24.0 24.1 Lua error in package.lua at line 80: module 'strict' not found.
  25. 25.0 25.1 Lua error in package.lua at line 80: module 'strict' not found.
  26. Lua error in package.lua at line 80: module 'strict' not found.
  27. Goldstine 1972, p. 182
  28. Goldstine 1972, p. 226
  29. Lua error in package.lua at line 80: module 'strict' not found.
  30. Honeywell, Inc. v. Sperry Rand Corp., 180 U.S.P.Q. (BNA) 673, p. 20, finding 1.1.3 (U.S. District Court for the District of Minnesota, Fourth Division 1973) (“The ENIAC machine which embodied 'the invention' claimed by the ENIAC patent was in public use and non-experimental use for the following purposes, and at times prior to the critical date: ... Formal dedication use February 15, 1946 ...”).
  31. 31.0 31.1 31.2 Scott McCartney p.140 (1999)
  32. Scott McCartney p.140 (1999): Eckert gave 11 lectures, Mauchly gave 6, Goldstine gave 6, von Neumann, who was to give 1, didn't showup. the other 24 were spread among various invited academics and military officials.
  33. Lua error in package.lua at line 80: module 'strict' not found.
  34. Lua error in package.lua at line 80: module 'strict' not found.
  35. Lua error in package.lua at line 80: module 'strict' not found.
  36. Lua error in package.lua at line 80: module 'strict' not found.
  37. Lua error in package.lua at line 80: module 'strict' not found.
  38. Lua error in package.lua at line 80: module 'strict' not found.
  39. Lua error in package.lua at line 80: module 'strict' not found.

References

  • Lua error in package.lua at line 80: module 'strict' not found.
  • Lua error in package.lua at line 80: module 'strict' not found.
  • Eckert, J. Presper, The ENIAC (in Nicholas Metropolis, J. Howlett, Gian-Carlo Rota, (editors), A History of Computing in the Twentieth Century, Academic Press, New York, 1980, pp. 525–540)
  • Eckert, J. Presper and John Mauchly, 1946, Outline of plans for development of electronic computers, 6 pages. (The founding document in the electronic computer industry.)
  • Fritz, Barkley, The Women of ENIAC (in IEEE Annals of the History of Computing, Vol. 18, 1996, pp. 13–28)
  • Lua error in package.lua at line 80: module 'strict' not found. (also reprinted in The Origins of Digital Computers: Selected Papers, Springer-Verlag, New York, 1982, pp. 359–373)
  • Lua error in package.lua at line 80: module 'strict' not found.
  • Mauchly, John, The ENIAC (in Metropolis, Nicholas, J. Howlett, Gian-Carlo Rota, 1980, A History of Computing in the Twentieth Century, Academic Press, New York, ISBN 0-12-491650-3, pp. 541–550, "Original versions of these papers were presented at the International Research Conference on the History of Computing, held at the Los Alamos Scientific Laboratory, 10–15 June 1976.")
  • Rojas, Raúl and Ulf Hashagen, editors, The First Computers: History and Architectures, 2000, MIT Press, ISBN 0-262-18197-5.
  • Lua error in package.lua at line 80: module 'strict' not found.

Further reading

  • Berkeley, Edmund. GIANT BRAINS or machines that think. John Wiley & Sons, inc., 1949. Chapter 7 Speed – 5000 Additions a Second: Moore School's ENIAC (Electronic Numerical Integrator And Computer)
  • Lua error in package.lua at line 80: module 'strict' not found.
  • Hally, Mike. Electronic Brains: Stories from the Dawn of the Computer Age, Joseph Henry Press, 2005. ISBN 0-309-09630-8
  • Lua error in package.lua at line 80: module 'strict' not found.
  • Tompkins, C.B. and J.H Wakelin, High-Speed Computing Devices, McGraw-Hill, 1950.
  • Lua error in package.lua at line 80: module 'strict' not found.
  • Lua error in package.lua at line 80: module 'strict' not found.

External links