The Project Gutenberg eBook of Giant brains; or, Machines that think This ebook is for the use of anyone anywhere in the United States and most other parts of the world at no cost and with almost no restrictions whatsoever. You may copy it, give it away or re-use it under the terms of the Project Gutenberg License included with this ebook or online at www.gutenberg.org. If you are not located in the United States, you will have to check the laws of the country where you are located before using this eBook. Title: Giant brains; or, Machines that think Author: Edmund Callis Berkeley Release date: September 14, 2022 [eBook #68991] Language: English Original publication: United States: John Wiley & Sons, 1949 Credits: Tim Lindell and the Online Distributed Proofreading Team at https://www.pgdp.net (This book was produced from images made available by the HathiTrust Digital Library.) *** START OF THE PROJECT GUTENBERG EBOOK GIANT BRAINS; OR, MACHINES THAT THINK *** Transcriber’s Notes: Underscores “_” before and after a word or phrase indicate _italics_ in the original text. A single underscore after a symbol indicates a subscript. Small capitals have been converted to SOLID capitals. Illustrations have been moved so they do not break up paragraphs. Typographical and punctuation errors have been silently corrected. GIANT BRAINS OR MACHINES THAT THINK EDMUND CALLIS BERKELEY Consultant in Modern Technology President, E. C. Berkeley and Associates JOHN WILEY & SONS, INC., NEW YORK CHAPMAN & HALL, LIMITED, LONDON Copyright, 1949 by EDMUND CALLIS BERKELEY _All Rights Reserved_ _This book or any part thereof must not be reproduced in any form without the written permission of the publisher._ Second Printing, February, 1950 Printed in the United States of America To my friends, whose help and instruction made this book possible PREFACE The Subject, Purpose, and Method of this Book The subject of this book is a type of machine that comes closer to being a brain that thinks than any machine ever did before 1940. These new machines are called sometimes mechanical brains and sometimes sequence-controlled calculators and sometimes by other names. Essentially, though, they are machines that can handle information with great skill and great speed. And that power is very similar to the power of a brain. These new machines are important. They do the work of hundreds of human beings for the wages of a dozen. They are powerful instruments for obtaining new knowledge. They apply in science, business, government, and other activities. They apply in reasoning and computing, and, the harder the problem, the more useful they are. Along with the release of atomic energy, they are one of the great achievements of the present century. No one can afford to be unaware of their significance. In this book I have sought to tell a part of the story of these new machines that think. Perhaps you, as you start this book, may not agree with me that a machine can think: the first chapter of this book is devoted to the discussion of this question. My purpose has been to tell enough about these machines so that we can see in general how they work. I have sought to explain some giant brains that have been built and to show how they do thinking operations. I have sought also to talk about what these machines can do in the future and to judge their significance for us. It seems to me that they will take a load off men’s as great as the load that printing took off men’s writing: a tremendous burden lifted. We need to examine several of the new mechanical brains: Massachusetts Institute of Technology’s differential analyzer, Harvard’s IBM automatic sequence-controlled calculator, Moore School’s ENIAC (Electronic Numerical Integrator and Calculator), and Bell Laboratories’ general-purpose relay calculator. These are described in the sequence in which they were finished between the years 1942 and 1946. We also have to go on some excursions—for instance, the nature of language and of symbols, the meaning of thinking, the human brain and nervous system, the future design of machinery that can think, and a little algebra and logic. I have also sought to discuss the relations between machines that think and human society—what we can foresee as likely to happen or be needed as a result of the remarkable invention of machines that can think. READING THIS BOOK This book is intended for everyone. I have sought to put it together in such a way that any reader can select from it what he wants. Perhaps at first reading you want only the main thread of the story. Then read only what seems interesting, and skip whatever seems uninteresting. The subheadings should help to tell you what to read and what to skip. Nearly all the chapters can be read with little reference to what goes before, although some reference to the supplements in the back may at times be useful. Perhaps your memory of physics is dim, like mine. The little knowledge of physics needed is explained here and there throughout the book, and the index should tell where to find any explanation you may want. Perhaps it is a long time since you did any algebra. Then Supplement 2 on mathematics may hold something of use to you. Two sections (one in Chapter 5 and one in Chapter 6) labeled as containing some rather mathematical details may be skipped with no great loss. Perhaps you are unacquainted with logic that uses symbols—the branch of logic called mathematical logic. In fact, very few people are familiar with it. No discussion in the book hinges on understanding this subject, except for Chapter 9 where a machine that calculates logical truth is described. In all other chapters you may freely skip all references to mathematical logic. But, if you are curious about the subject and how it can be usefully applied in the field of mechanical brains, then begin with the introduction to the subject in Chapter 9, and note the suggestions in the section entitled “Algebra of Logic” in Supplement 2. In any case, glance at the table of contents, the chapter headings and subheadings, and the supplements at the back. These should give an idea of how the book is put together and how you may select what may be interesting to you. Please do not read this book straight from beginning to end unless that way proves to be congenial to you. If you are not interested in technical details, skip most of the middle chapters, which describe existing mechanical brains. If, on the other hand, you want more details than this book contains, look up references in Supplement 3. Here are listed, with a few comments, over 250 books, articles, and pamphlets related to the subject of machinery for computing and reasoning. These cover many parts of the field; some parts, however, are not yet covered by any published information. There are no photographs in this book, although there are over 80 drawings. Photographs of these complicated machines can really show very little: panels, lights, switches, wires, and other kinds of hardware. What is important is the way the machine works inside. This cannot be shown by a photograph but may be shown by schematic drawings. In the same way, a photograph of a human being shows almost nothing about how he thinks. UNDERSTANDING THIS BOOK I have tried to write this book so that it could be understood. I have attempted to explain machinery for computing and reasoning without using technical words any more than necessary. To do this seemed to be easy in some places, much harder in others. As a test of this attempt, a count has been made of all the different words in the book that have two syllables or more, that are used for explaining, and that are not themselves defined. There are fewer than 1800 of these words. In Supplement 1, entitled “Words and Ideas,” I have digressed to discuss further the problem of explanation and understanding. Every now and then in the book, along comes a word or a phrase that has a special meaning, for example, the name of something new. When it first appears, it is put in italics and is explained or defined. In addition, all the words and phrases having special meaning appear again in the index, and next to each is the page number of its explanation or definition. In many places, I have talked of mechanical brains as if they were living. For example, instead of “capacity to store information” I have spoken of “memory.” Of course, the machines are not living; but they do have individuality, responsiveness, and other traits of living beings, just as a political party pictured as a living elephant does. Besides, to treat things as persons is a help in making any subject vivid and understandable, as every song writer and cartoonist illustrates. We speak of “Old Man River” and “Father Time”; we may speak of a ship or a locomotive as “she”; and the crew on the first Harvard sequence-controlled calculator has often called her “Bessy, the Bessel engine.” Let us pause a little longer on the subject of understanding. What is the understanding of something new? It is a state of knowing, a process of knowing more and more. The more we know about something new, the better we understand it. It is possible for almost anybody to understand almost anything, I believe. What is mainly needed in order to grasp an idea is a good collection of true statements about it and some practice in using those statements in situations. For example, no one has ever seen or touched the separate scraps of electricity called electrons. But electrons have been described and measured; hundreds of thousands of people work with electrons; they know and use true statements about electrons. In effect, these people understand electrons. Probably the hardest task of an author is to make his statements understandable yet accurate. It is too much to hope for complete success. I shall be very grateful to any reader who points out to me the statements that he has not understood or that are in error. As to the views I have expressed, I do not expect every reader to agree with me. In fact, I shall be glad if many a reader disagrees with me. For then someone else may say to both of us, “You’re both right and both wrong—the truth lies atwixt and atween you.” Thoughtful and tolerant disagreement is the finest climate for scientific progress. BASIC FACTS Many of the mechanical brains described in this book will do good work for years; but their design is already out of date. Many organizations are hard at work finding new tricks in electronics, materials, and engineering and making new mechanical brains that are better and faster. In spite of future developments, though, the basic facts about mechanical brains will endure. These basic facts are drawn from the principles of thinking, of mathematics, of science, of engineering, etc. These facts govern all handling of information. They do not depend very much on human or mechanical energy. They do not depend very much on signs. They do not depend very much on the century, or the language, or the country. For example, “II et III V sunt,” the Romans may have said; “deux et trois font cinq,” say the French; “2 + 3 = 5,” say the mathematicians; and we say, “two and three make five.” The main effort in this book has been to make clear the basic facts about mechanical brains, for they are now a masterly instrument for obtaining new knowledge. EDMUND CALLIS BERKELEY New York 11, N. Y. _June 30, 1949_ ACKNOWLEDGMENTS This book has been over seven years in the making and has evolved through many different plans for its contents. It springs essentially from the desire to see human beings use their knowledge better: we know enough, but how are we to use what we know? Machines that handle information, that make knowledge accessible, are a long step in the direction of using what we know. For help in causing this desire to come to fruition, I should like to express my indebtedness especially to Professor (then Commander, U.S.N.R.) Howard H. Aiken of Harvard University, whose stimulus, while I was stationed for ten months in 1945-46 in his laboratory, was very great. I should also like to express my appreciation to Mr. Harry J. Volk, whose vision and enthusiasm greatly encouraged me in the writing of this book. For careful reviews and helpful comments on the chapters dealing with existing mechanical brains, I am especially grateful to Dr. Franz L. Alt, Mr. E. G. Andrews, Professor Samuel H. Caldwell, Dr. Grace M. Hopper, Mr. Theodore A. Kalin, and Dr. John W. Mauchly, who are experts in their fields. Dr. Ruth P. Berkeley, Dr. Rudolf Flesch, Mr. J. Ross Macdonald, Dr. Z. I. Mosesson, Mr. Irving Rosenthal, Mr. Max S. Weinstein, and many others have been true friends in reading and commenting upon many parts of the manuscript. Mr. Frank W. Keller devoted much time and skill to converting my rough sketches into illustrations. Mr. Murray B. Ritterman has been of invaluable help in preparing and checking much of the bibliography. Miss Marjorie L. Black has helped very greatly in turning scraps of paper bearing sentences into an excellent manuscript for the printer. For permission to use the quotations on various pages in Chapters 11 and 12, I am indebted to the kindness of: E. P. Dutton & Co., for quotations from _Frankenstein_, by Mary W. Shelley, Everyman’s Library, No. 616. Samuel French, for quotations from _R. U. R._, by Karel Čapek.[1] _Modern Industry_, for a quotation from the issue of February 15, 1947. [1] Copyright 1923 by Doubleday, Page and Co.; all rights reserved; quotations reprinted by permission of Karel Čapek and Samuel French. Responsibility for the statements and opinions expressed in this book is solely my own. These statements and opinions do not necessarily represent the views of any organization with which I may be or have been associated. To the best of my knowledge and belief no information contained in this book is classified by the Department of Defense of the United States. EDMUND CALLIS BERKELEY CONTENTS 1. CAN MACHINES THINK? What Is a Mechanical Brain? 1 2. LANGUAGES: Systems for Handling Information 10 3. A MACHINE THAT WILL THINK: The Design of a Very Simple Mechanical Brain 22 4. COUNTING HOLES: Punch-Card Calculating Machines 42 5. MEASURING: Massachusetts Institute of Technology’s Differential Analyzer No. 2 65 6. ACCURACY TO 23 DIGITS: Harvard’s IBM Automatic Sequence-Controlled Calculator 89 7. SPEED—5000 ADDITIONS A SECOND: Moore School’s ENIAC (Electronic Numerical Integrator and Calculator) 113 8. RELIABILITY—NO WRONG RESULTS: Bell Laboratories’ General-Purpose Relay Calculator 128 9. REASONING: The Kalin-Burkhart Logical-Truth Calculator 144 10. AN EXCURSION: The Future Design of Machines That Think 167 11. THE FUTURE: Machines That Think, and What They Might Do for Men 180 12. SOCIAL CONTROL: Machines That Think, and How Society May Control Them 196 SUPPLEMENTS 1. Words and Ideas 209 2. Mathematics 214 3. References 228 INDEX 257 Chapter 1 CAN MACHINES THINK? WHAT IS A MECHANICAL BRAIN? Recently there has been a good deal of news about strange giant machines that can handle information with vast speed and skill. They calculate and they reason. Some of them are cleverer than others—able to do more kinds of problems. Some are extremely fast: one of them does 5000 additions a second for hours or days, as may be needed. Where they apply, they find answers to problems much faster and more accurately than human beings can; and so they can solve problems that a man’s life is far too short to permit him to do. That is why they were built. These machines are similar to what a brain would be if it were made of hardware and wire instead of flesh and nerves. It is therefore natural to call these machines _mechanical brains_. Also, since their powers are like those of a giant, we may call them _giant brains_. Several giant mechanical brains are now at work finding out answers never before known. Two are in Cambridge, Mass.; one is at Massachusetts Institute of Technology, and one at Harvard University. Two are in Aberdeen, Md., at the Army’s Ballistic Research Laboratories. These four machines were finished in the period 1942 to 1946 and are described in later chapters of this book. More giant brains are being constructed. Can we say that these machines really think? What do we mean by thinking, and how does the human brain think? HUMAN THINKING We do not know very much about the physical process of thinking in the human brain. If you ask a scientist how flesh and blood in a human brain can think, he will talk to you a little about nerves and about electrical and chemical changes, but he will not be able to tell you very much about how we add 2 and 3 and make 5. What men know about the way in which a human brain thinks can be put down in a few pages, and what men do not know would fill many libraries. Injuries to brains have shown some things of importance; for example, they have shown that certain parts of the brain have certain duties. There is a part of the brain, for instance, where sights are recorded and compared. If an accident damages the part of the brain where certain information is stored, the human being has to relearn—haltingly and badly—the information destroyed. We know also that thinking in the human brain is done essentially by a process of storing information and then referring to it, by a process of learning and remembering. We know that there are no little wheels in the brain so that a wheel standing at 2 can be turned 3 more steps and the result of 5 read. Instead, you and I store the information that 2 and 3 are 5, and store it in such a way that we can give the answer when questioned. But we do not know the register in our brain where this particular piece of information is stored. Nor do we know how, when we are questioned, we are able automatically to pick up the nerve channels that lead into this register, get the answer, and report it. Since there are many nerves in the brain, about 10 billion of them, in fact, we are certain that the network of connecting nerves is a main part of the puzzle. We are therefore much interested in nerves and their properties. NERVES AND THEIR PROPERTIES A single nerve, or _nerve cell_, consists of a _cell nucleus_ and a _fiber_. This fiber may have a length of anything from a small fraction of an inch up to several feet. In the laboratory, successive impulses can be sent along a nerve fiber as often as 1000 a second. Impulses can travel along a nerve fiber in either direction at a rate from 3 feet to 300 feet a second. Because the speed of the impulse is far less than 186,000 miles a second—the speed of an electric current—the impulse in the nerve is thought by some investigators to be more chemical than electrical. We know that a nerve cell has what is called an _all-or-none response_, like the trigger of a gun. If you stimulate the nerve up to a certain point, nothing will happen; if you reach that point, or cross it,—bang!—the nerve responds and sends out an impulse. The strength of the impulse, like the shot of the gun, has no relation whatever to the amount of the stimulation. [Illustration: FIG. 1. Scheme of a nerve cell.] The structure between the end of one nerve and the beginning of the next is called a _synapse_ (see Fig. 1). No one really knows very much about synapses, for they are extremely small and it is not easy to tell where a synapse stops and other stuff begins. Impulses travel through synapses in from ½ to 3 thousandths of a second. An impulse travels through a synapse only in one direction, from the head (or _axon_) of one nerve fiber to the foot (or _dendrite_) of another. It seems clear that the activity in a synapse is chemical. When the head of a nerve fiber brings in an impulse to a synapse, apparently a chemical called _acetylcholine_ is released and may affect the foot of another fiber, thus transmitting the impulse; but the process and the conditions for it are still not well understood. It is thought that nearly all information is handled in the brain by groups of nerves in parallel paths. For example, the eye is estimated to have about 100 million nerves sensitive to light, and the information that they gather is reported by about 1 million nerves to the part of the brain that stores sights. Not much more is yet known, however, about the operation of handling information in a human brain. We do not yet know how the nerves are connected so that we can do what we do. Probably the greatest obstacle to knowledge is that so far we cannot observe the detailed structure of a living human brain while it performs, without hurting or killing it. BEHAVIOR THAT IS THINKING Therefore, we cannot yet tell what thinking is by observing precisely how a human brain does it. Instead, we have to define thinking by describing the kind of behavior that we call thinking. Let us consider some examples. When you and I add 12 and 8 and make 20, we are thinking. We use our minds and our understanding to count 8 places forward from 12, for example, and finish with 20. If we could find a dog or a horse that could add numbers and tell answers, we would certainly say that the animal could think. With no trouble a machine can do this. An ordinary 10-column adding machine can be given two numbers like 1,378,917,766 and 2,355,799,867 and the instruction to add them. The machine will then give the answer, 3,734,717,633, much faster than a man. In fact, the mechanical brain at Harvard can add a number of 23 digits to another number of 23 digits and get the right answer in ³/₁₀ of a second. Or, suppose that you are walking along a road and come to a fork. If you stop, read the signpost, and then choose left or right, you are thinking. You know beforehand where you want to go, you compare your destination with what the signpost says, and you decide on your route. This is an operation of logical choice. A machine can do this. The mechanical brain now at Aberdeen which was built at Bell Laboratories can examine any number that comes up in the process of a calculation and tell whether it is bigger than 3 (or any stated number) or smaller. If the number is bigger than 3, the machine will choose one process; if the number is smaller than 3, the machine will choose another process. Now suppose that we consider the basic operation of all thinking: in the human brain it is called learning and remembering, and in a machine it is called storing information and then referring to it. For example, suppose you want to find 305 Main Street in Kalamazoo. You look up a map of Kalamazoo; the map is information kindly stored by other people for your use. When you study the map, notice the streets and the numbering, and then find where the house should be, you are thinking. A machine can do this. In the Bell Laboratories’ mechanical brain, for example, the map could be stored as a long list of the blocks of the city and the streets and numbers that apply to each block. The machine will then hunt for the city block that contains 305 Main Street and report it when found. A machine can handle information; it can calculate, conclude, and choose; it can perform reasonable operations with information. A machine, therefore, can think. THE DEFINITION OF A MECHANICAL BRAIN Now when we speak of a machine that thinks, or a mechanical brain, what do we mean? Essentially, a _mechanical brain_ is a machine that handles information, transfers information automatically from one part of the machine to another, and has a flexible control over the sequence of its operations. No human being is needed around such a machine to pick up a physical piece of information produced in one part of the machine, personally move it to another part of the machine, and there put it in again. Nor is any human being needed to give the machine instructions from minute to minute. Instead, we can write out the whole program to solve a problem, translate the program into machine language, and put the program into the machine. Then we press the “start” button; the machine starts whirring; and it prints out the answers as it obtains them. Machines that handle information have existed for more than 2000 years. These two properties are new, however, and make a deep break with the past. How should we imagine a mechanical brain? One way to think of a mechanical brain is shown in Fig. 2. We see here a railroad line with four stations, marked _input_, _storage_, _computer_, and _output_. These stations are joined by little gates or switches to the main railroad line. We can imagine that numbers and other information move along this railroad line, loaded in freight cars. _Input_ and _output_ are stations where numbers or other information go in and come out, respectively. _Storage_ is a station where there are many platforms and where information can be stored. The _computer_ is a special station somewhat like a factory; when two numbers are loaded on platforms 1 and 2 of this station and an order is loaded on platform 3, then another number is produced on platform 4. [Illustration: FIG. 2. Scheme of a mechanical brain.] We see also a tower, marked _control_. This tower runs a telegraph line to each of its little watchmen standing by the gates. The tower tells them when to open and when to shut which gates. Now we can see that, just as soon as the right gates are shut, freight cars of information can move between stations. Actually the freight cars move at the speed of electric current, thousands of miles a second. So, by closing the right gates each fraction of a second, we can flash numbers and information through the system and perform operations of reasoning. Thus we obtain a mechanical brain. In general, a mechanical brain is made up of: 1. A quantity of registers where information (numbers and instructions) can be stored. 2. Channels along which information can be sent. 3. Mechanisms that can carry out arithmetical and logical operations. 4. A control, which guides the machine to perform a sequence of operations. 5. Input and output devices, whereby information can go into the machine and come out of it. 6. Motors or electricity, which provide energy. THE KINDS OF THINKING A MECHANICAL BRAIN CAN DO There are many kinds of thinking that mechanical brains can do. Among other things, they can: 1. Learn what you tell them. 2. Apply the instructions when needed. 3. Read and remember numbers. 4. Add, subtract, multiply, divide, and round off. 5. Look up numbers in tables. 6. Look at a result, and make a choice. 7. Do long chains of these operations one after another. 8. Write out an answer. 9. Make sure the answer is right. 10. Know that one problem is finished, and turn to another. 11. Determine _most_ of their own instructions. 12. Work unattended. They do these things much better than you or I. They are fast. The mechanical brain built at the Moore School of Electrical Engineering at the University of Pennsylvania does 5000 additions a second. They are reliable. Even with hundreds of thousands of parts, the existing giant brains have worked successfully. They have remarkably few mechanical troubles; in fact, for one of the giant brains, a mechanical failure is of the order of once a month. They are powerful. The big machine at Harvard can remember 72 numbers each of 23 digits at one time and can do 3 operations with these numbers every second. The mechanical brains that have been finished are able to solve problems that have baffled men for many, many years, and they think in ways never open to men before. Mechanical brains have removed the limits on complexity of routine: the machine can carry out a complicated routine as easily as a simple one. Already, processes for solving problems are being worked out so that the mechanical brain will itself determine more than 99 per cent of all the routine orders that it is to carry out. But, you may ask, can they do any kind of thinking? The answer is no. No mechanical brain so far built can: 1. Do intuitive thinking. 2. Make bright guesses, and leap to conclusions. 3. Determine _all_ its own instructions. 4. Perceive complex situations outside itself and interpret them. A clever wild animal, for example, a fox, can do all these things; a mechanical brain, not yet. There is, however, good reason to believe that most, if not all, of these operations will in the future be performed not only by animals but also by machines. Men have only just begun to construct mechanical brains. All those finished are children; they have all been born since 1940. Soon there will be much more remarkable giant brains. WHY ARE THESE GIANT BRAINS IMPORTANT? Most of the thinking so far done by these machines is with numbers. They have already solved problems in airplane design, astronomy, physics, mathematics, engineering, and many other sciences, that previously could not be solved. To find the solutions of these problems, mathematicians would have had to work for years and years, using the best known methods and large staffs of human computers. These mechanical brains not only calculate, however. They also remember and reason, and thus they promise to solve some very important human problems. For example, one of these problems is the application of what mankind knows. It takes too long to find understandable information on a subject. The libraries are full of books: most of them we can never hope to read in our lifetime. The technical journals are full of condensed scientific information: they can hardly be understood by you and me. There is a big gap between somebody’s knowing something and employment of that knowledge by you or me when we need it. But these new mechanical brains handle information very swiftly. In a few years machines will probably be made that will know what is in libraries and that will tell very swiftly where to find certain information. Thus we can see that mechanical brains are one of the great new tools for finding out what we do not know and applying what we do know. Chapter 2 LANGUAGES: SYSTEMS FOR HANDLING INFORMATION As everyone knows, it is not always easy to think. By _thinking_, we mean computing, reasoning, and other handling of information. By _information_ we mean collections of ideas—physically, collections of marks that have meaning. By _handling_ information, we mean proceeding logically from some ideas to other ideas—physically, changing from some marks to other marks in ways that have meaning. For example, one of your hands can express an idea: it can store the number 3 for a short while by turning 3 fingers up and 2 down. In the same way, a machine can express an idea: it can store information by arranging some equipment. The Harvard mechanical brain can store 132 numbers between 0 and 99,999,999,999,999,999,999,999 for days. When you want to change the number stored by your fingers, you move them: perhaps you need a half second to change the number stored by your fingers from 3 to 2, for example. In the same way, a machine can change a stored number by changing the arrangement of some equipment: the electronic brain Eniac can change a stored number in ¹/₅₀₀₀ of a second. LANGUAGES Since it is not always easy to think, men have given much attention to devices for making thinking easier. They have worked out many _systems for handling information_, which we often call _languages_. Some languages are very complete and versatile and of great importance. Others cover only a narrow field—such as numbers alone—but in this field they may be remarkably efficient. Just what is a language? Every language is both a _scheme for expressing meanings_ and _physical equipment_ that can be handled. For example, let us take _spoken English_. The scheme of spoken English consists of more than 150,000 words expressing meanings, and some rules for putting words together meaningfully. The physical equipment of spoken English consists of (1) sounds in the air, and (2) the ears of millions of people, and their mouths and voices, by which they can hear and speak the sounds of English. For another example, let us take numbers expressed in the _Arabic numerals_ and the rules of arithmetic. The scheme of this language contains only ten digits 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 or their equivalents, and some rules for combining them. Sufficient physical equipment for this language might very well be a ten-column desk calculating machine with its counter wheels, gears, keys, etc. If we tried to exchange the physical equipment of these two languages, we would be blocked: the desk calculating machine cannot possibly express the meaningful combinations of 150,000 words, and sounds in the air are not permanent enough to express the steps of division of one large number by another. SCHEMES FOR EXPRESSING MEANINGS If we examine languages that have existed, we can observe a number of schemes for expressing meanings. In the table on pp. 12-13 is a rough list of a dozen of them. From among these we can choose the schemes that are likely to be useful in mechanical brains. Schemes 11 and 12 are the schemes that have been predominantly used in machinery for computing. Scheme 12 consisting of combinations of just two marks, ✓, ✕, provides one of the best codes for mechanical handling of information. This scheme, called _binary coding_ (see Supplement 2), is also useful for measuring the quantity of information. QUANTITY OF INFORMATION How should we measure the quantity of information? The smallest unit of information is a “yes” or a “no,” a check mark (✓) or a cross (✕), an impulse in a nerve or no impulse, a 1 or a 0, black or white, good or bad, etc. This twofold difference is called a _binary digit_ of information (see Supplement 2). It is the convenient _unit of information_. SCHEMES FOR EXPRESSING MEANINGS EXAMPLE: /————————————————^—————————————————\ PRINCIPLE SIGN USED IN SIGNIFICANCE NAME OF NO. OF SCHEME SCHEME (1) (2) (3) (4) (5) (6) _Sounds_ 1. Sound of new Bobwhite[2] Spoken kind of quail, Imitative; word is like English so called bowwow sound of from its note theory referent 2. An utterance Pooh![2] Spoken The speaker Pooh-pooh becomes a English expresses theory new word disdain 3. New word is Chortle[2] Spoken “Chuckle” Analogical like another English; and word invented by “snort” Lewis Carroll, blended 1896 4. Word has Mother[2] Spoken Female Historical been used English parent through the ages _Sights_ 5. Picture [picture Egyptian; Picture of Imitative; is like of eye] Ojibwa eye and pictographic referent (American tears, to Indian) mean grief 6. Pattern is 5 English; Five; Ideographic; symbol of French; cinq; mathematical; an idea German; fünf; symbolic; etc. etc. numeric _Mapping of Sounds_ 7. Object [picture Possible Picture of Rebus- pictured of knot] English a knot to writing; has the mean “not” phonographic wanted sound 8. Pattern is [picture Ancient Sign for Syllable- symbol for of star] Cypriote the writing a large (island of syllable sound unit Cyprus) _mu_ 9. Pattern is Ʒ International The sound Phonetic symbol for Phonetic _zh_, as writing a small Alphabet of _s_ in alphabetic sound unit 87 characters “measure” writing; _Mapping of Sights or Symbols_ 10. Systematic ENIAC Abbreviations, Initial Alphabetic combinations etc. letters coding of 26 of a letters 5-word title 11. Systematic 135-03-1228 Abbreviations, Social Numeric combinations nomenclature, Security coding of 10 digits etc. No. of a person 12. Systematic ✓,✕,✕,✓,✓ Checking “yes,” Binary combinations lists, “no,” coding of 2 marks etc. “no,” “yes,” “yes,” respectively [2] The preceding word is the spoken word, not the written one. With 2 units of information or 2 binary digits (1 or 0) we can represent 4 pieces of information: 00, 01, 10, 11 With 3 units of information we can represent 8 pieces of information: 000, 001, 010, 011, 100, 101, 110, 111 With 4 units of information we can represent 16 pieces of information: 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111 Now 4 units of information are sufficient to represent a _decimal digit_ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 and allow 6 possibilities to be left over; 3 units of information are not sufficient. For example, we may have: 0 0000 5 0101 1 0001 6 0110 2 0010 7 0111 3 0011 8 1000 4 0100 9 1001 We say, therefore, that a decimal digit 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 is _equivalent_ to 4 units of information. Thus a table containing 10,000 numbers, each of 10 decimal digits, is equivalent to 400,000 units of information. One of the 26 letters of the alphabet is equivalent to 5 units of information, for, 5 binary digits (1 or 0) have 32 possible arrangements, and these are enough to provide for the 26 letters. Any printed information in English can be expressed in about 80 characters consisting of 10 numerals, 52 capital and small letters, and some 18 punctuation marks and other types of marks; 6 binary digits (1 or 0) have 64 possible arrangements, and 7 binary digits (1 or 0) have 128 possible arrangements. Each character in a printed book, therefore, is roughly equivalent to 7 units of information. It can be determined that a big telephone book or a big reference dictionary stores printed information at the rate of about 1 billion units of information per cubic foot. If the 10 billion nerves in the human brain could independently be impulsed or not impulsed, then the human brain could conceivably store 10 billion units of information. The largest library in the world is the Library of Congress, containing 7 million volumes including pamphlets. It stores about 100 trillion units of information. We can thus see the significance of a _quantity of information_ from 1 unit to 100 trillion units. No distinction is here made between information that reports facts and information that does not. For example, a book of fiction about persons who never existed is still counted as information, and, of course, much instruction and entertainment may be found in such a source. PHYSICAL EQUIPMENT FOR HANDLING INFORMATION The first thing we want to do with information is _store_ it. The second thing we want to do is _combine_ it. We want equipment that makes these two processes easy and efficient. We want equipment for handling information that: 1. Costs little. 2. Holds much information in little space. 3. Is _permanent_, when we want to keep the information. 4. Is _erasable_, when we want to remove information. 5. Is _versatile_, holds easily any kind of information, and allows operations to be done easily. The amount of human effort needed to handle information correctly depends very much on the properties of the physical equipment expressing the information, although the laws of correct reasoning are independent of the equipment. For example, the great difficulty with spoken sounds as physical equipment for handling information is the trouble of storing them. The technique for doing so was mastered only about 1877 when Thomas A. Edison made the first phonograph. Even with this advance, no one can glance at a soundtrack and tell quickly what sounds are stored there; only by turning back the machine and listening to a groove can we determine this. It was not possible for the men of 2000 B.C. to wait thousands of years for the storing of spoken sounds. The problem of storing information was accordingly taken to other types of physical equipment. PHYSICAL EQUIPMENT FOR HANDLING INFORMATION PHYSICAL ARRANGED OPERATED OR LOW LITTLE PERM- ERAS- VERS- NO. OBJECTS IN OR ON PRODUCED BY COST? SPACE? ANENT? ABLE? ATILE? (1) (2) (3) (4) (5) (6) (7) (8) (9) _Mind_ 1. Nerve Human Body ✕ ✓✓ ✓ ✓ ✓✓ cells brain _Sounds_ 2. Sounds Air Voice ✓✓ ✓✓ ✕✕ ✓✓ ✓✓ 3. Sound- Wax Machines ✓ ✓ ✓✓ ✕ ✓✓ tracks cylinders, and phonograph motors records _Sights_ 4. Marks Sand Stick ✓ ✕ ✓ ✓✓ ✕ 5. Colored Cave Paintbrush ✕ ✕ ✓ ✕ ✕✕ painting walls, and paints canvases, etc. 6. Marks, Clay, Stylus, ✕✕ ✓ ✓✓ ✕✕ ✓ inscript- stone chisel ions 7. Marks Slate Chalk ✓ ✕ ✓ ✓✓ ✓ 8. Marks Paper, Pen ✓✓ ✓ ✓ ✕ ✓✓ parchment, and ink, etc. pencil 9. Letters, Paper, Printing ✓✓ ✓✓ ✓✓ ✕✕ ✓✓ etc. books, press, etc. movable type, motor, and hands 10. Photo- Film, Camera ✓ ✓✓ ✓ ✕✕ ✓✓ graphs prints, etc. 11. Letters, Paper, Typewriter ✓ ✓✓ ✓ ✕ ✓✓ etc. mimeograph and stencil, fingers etc. _Body_ 12. Gestures Space Body ✓ ✕ ✕✕ ✓✓ ✕✕ 13. Fingers Hands Body ✕ ✕ ✕✕ ✓✓ ✕✕ _Objects_ 14. Pebbles Slab Hands ✓✓ ✓ ✓ ✓ ✕✕ 15. Knots String Hands ✓✓ ✓ ✓ ✓ ✕✕ 16. Tallies, Stick Knife ✓✓ ✓ ✓✓ ✕✕ ✕✕ notches 17. Beads Rods in Hands ✓ ✓ ✓ ✓✓ ✕✕ a frame, abacus 18. Ruled Rulers, Hands, ✓ ✓ ✓ ✓ ✓ lines, scales, pressure, pointers dials etc. _Machines_ 19. Counter Desk Motor ✓ ✓ ✓ ✓✓ ✓ wheels, calculating and gears, machines, hands keys, fire-control lights, instruments, etc. etc. 20. Punched Punch card Motor ✓✓ ✓✓ ✓ ✕ ✓✓ cards machinery, and and teletype, input paper etc. instructions tape 21. Relays Dial Motor ✕ ✓ ✓ ✓✓ ✓✓ telephone, and other input machinery instructions 22. Elect- Machinery Motor ✓ ✓ ✓ ✓✓ ✓✓ ronic and tubes input instructions 23. Magnetic Machinery Motor ✓✓ ✓✓ ✓✓ ✓✓ ✓✓ surfaces: and wire, input tape, instructions discs 24. Delay Machinery Motor ✕ ✓ ✕ ✓✓ ✓✓ lines: and electric, input acoustic instructions 25. Electro- Machinery Motor ✕ ✓✓ ✕ ✓✓ ✓✓ static and storage input tubes instructions ✓✓ yes, very. ✓ yes, adequately. ✕ not generally. ✕✕ not at all. What are the types of physical equipment for handling information, and which are the good ones? In the table on pp. 16-17 is a rough list of 25 types of physical equipment for handling information. ✓✓ means “yes, very;” ✓ means “yes, adequately;” ✕ means “not generally;” ✕✕ means “not at all.” For example, our _fingers_ (see No. 13) as a device for handling information are very expensive for most cases. They take up a good deal of space. Certainly they are very temporary storage; any information they may express is very erasable; and what we can express with them alone is very limited. Yet, with a _typewriter_ (see No. 11), our fingers become versatile and efficient. In fact, our fingers can make 4 strokes a second; we can select any one of about 38 keys; and, since each key is equivalent to 5 or 6 units of information, the effective speed of our fingers may be about 800 units of information a second. LANGUAGES OF PHYSICAL OBJECTS The use of pebbles (see No. 14) for keeping track of numerical information is shown in the history of the words containing the root _calc_-of the word _calculate_. The Latin word _calcis_ meant pertaining to lime or limestone, and the Latin word _calculus_ derived from it meant first a small piece of limestone, and later any small stone, particularly a pebble used in counting. All three of these meanings have left descendants: “chalk,” “calcite,” “calcium,” relating in one way or another to lime; in medicine, “calculus,” referring to stones in the kidneys or elsewhere in the body; and in mathematics, “calculate,” “calculus,” referring to computations, once done with pebbles. The pebbles, and the slab (for which the ancient Greek word is _abax_) on which they were arranged and counted, were later replaced, for ease in handling, by groups of beads strung on rods and placed in a frame (see No. 17). These constituted the _abacus_ (see Supplement 2 and the figure there). This was the first calculating machine. It is still used all over Asia; in fact, even today more people use the abacus for accounting than use pencil and paper. The skill with which the abacus can be used was shown in November 1946 in a well-publicized contest in Japan. Kiyoshi Mastuzaki, a clerk in the Japanese communications department, using the abacus, challenged Private Thomas Wood of the U. S. Army, using a modern desk calculating machine, and defeated him in a speed contest involving additions, subtractions, multiplications, and divisions. The heaps of small pebbles, the notches in sticks, and the abacus had the advantage of being visible and comparatively permanent. Storing and reading were relatively easy. They were rather compact and easy to manipulate, certainly much easier than spoken words. But they were subject to disadvantages also. Moving correctly from one arrangement to another was difficult, since there was no good way for storing intermediate steps so that the process could be easily verified. Furthermore, these devices applied to specified numbers only. Also, there was no natural provision for recording what the several numbers belonged to. This had to be recorded with the help of another language, writing. The language of physical objects was picked up from obscurity by the invention of motors and the demands of commerce and business. Commencing in the late 1800’s, _desk calculating machines_ (see No. 19) were constructed to meet mass calculation requirements. They would add, subtract, multiply, and divide specific numbers with great accuracy and speed. But until recently they still were adjuncts to the other languages, for they provided figures one at a time for insertion in the spaces on the ledger pages or calculation sheets where figures were called for. Beginning in the 1920’s, a remarkable change has taken place. Instead of performing single operations, machines have been developed to perform chains of operations with many kinds of information. One of these machines is the _dial telephone_: it can select one of 7 million telephones by successive sorting according to the letters and digits of a telephone number. Another of these machines is a _fire-control instrument_, a mechanism for controlling the firing of a gun. For example, in a modern anti-aircraft gun the mechanism will observe an enemy plane flying at several hundred miles an hour, convert the observations into gun-aiming directions, and determine the aiming directions fast enough to shoot down the plane. _Punch-card machinery_, machines handling information expressed as punched holes in cards, enable the fulfillment of social security legislation, the production of the census, and countless operations of banks, insurance companies, department stores, and factories. And, finally, in 1942 the first _mechanical brain_ was finished at Massachusetts Institute of Technology. THE CRUCIAL DEVICES FOR MECHANICAL BRAINS Let us consider the two modern physical devices for handling information which make mechanical brains possible. These are _relays_ and _electronic tubes_ (Nos. 21 and 22). The last three kinds of equipment listed in the table (_magnetic surfaces_, No. 23; _delay lines_, No. 24; and _electrostatic storage tubes_, No. 25) were not included in any mechanical brains functioning by the middle of 1948. The discussion of them is therefore put off to Chapter 10, where we talk about the future design of mechanical brains. [Illustration: FIG. 1. Relay] Figure 1 shows a simple relay. There are two electrical circuits here. One has two terminals—Pickup and Ground. The other has three terminals—Common, Normally Open, and Normally Closed. When current flows through the coil of wire around the iron, it makes the iron a magnet; the magnet pulls down the flap of iron above, overcoming the force of the spring. When there is no current through the coil, the iron is not a magnet, and the flap is held up by the spring. Now suppose that there is current in Common. When there is no current in Pickup, the current from Common will flow through the upper contact, to the terminal marked Normally Closed. When there is current in Pickup, the current from Common will flow through the lower contact, to the terminal marked Normally Open. Thus we see that a relay expresses a “yes” or a “no,” a 1 or 0, a binary digit, a unit of information. A relay costs $5 to $10. It is rather expensive for storing a single unit of information. The fastest it can be changed from 1 to 0, or vice versa, is about ¹/₁₀₀ of a second. [Illustration: FIG. 2. Electronic tube.] Figure 2 shows a simple electronic tube. It has three parts—the Cathode, the Grid, and the Plate. The Grid actually is a coarse net of metal wires. Electrons can flow from the Cathode to the Plate, provided the voltage on the Grid is such as to permit them to flow. So we can see that an electronic tube is a very simple on-off device and expresses a “yes” or a “no,” a 1 or 0, a binary digit, a unit of information. A simple electronic tube suitable for calculating purposes costs 50 cents to a $1, only ⅒ the cost of a relay. It can be changed from 1 to 0, or back again, in 1 millionth of a second. Relays have been widely used in the mechanical brains so far built, and electronic tubes are the essence of Eniac. In the next chapter, we shall see how physical equipment for handling information can be put together to make a simple mechanical brain. Chapter 3 A MACHINE THAT WILL THINK: THE DESIGN OF A VERY SIMPLE MECHANICAL BRAIN We shall now consider how we can design a very simple machine that will think. Let us call it Simon, because of its predecessor, Simple Simon. SIMON, THE VERY SIMPLE MECHANICAL BRAIN By designing Simon, we shall see how we can put together physical equipment for handling information in such a way as to get a very simple mechanical brain. At every point in the design of Simon, we shall make the simplest possible choice that will still give us a machine that: handles information, transfers information automatically from one part of the machine to another, and has control over the sequence of operations. Simon is so simple and so small, in fact, that it could be built to fill up less space than a grocery-store box, about 4 cubic feet. If we know a little about electrical work, we will find it rather easy to make Simon. What do we do first to design the very simple mechanical brain, Simon? SIMON’S FLESH AND NERVES—REPRESENTING INFORMATION The first thing we have to decide about Simon is how information will be represented: as we put it into Simon, as it is moved around inside of Simon, and as it comes out of Simon. We need to decide what physical equipment we shall use to make Simon’s flesh and nerves. Since we are taking the simplest convenient solution to each problem, let us decide to use: _punched paper tape_ for putting information in, _relays_ (see Chapter 2) and wires for storing and transferring information, and _lights_ for putting information out. [Illustration: TWO-HOLED TAPE READER: Simon’s left ear that listens to numbers and operations. FOUR-HOLED TAPE READER: Simon’s right ear that listens to instructions. LIGHT BULBS: Simon’s eyes that wink answers. FIG. 1. Simon, the very simple mechanical brain.] For the equipment inside Simon, we could choose either electronic tubes or relays. We choose relays, although they are slower, because it is easier to explain circuits using relays. We can look at a relay circuit laid out on paper and tell how it works, just by seeing whether or not current will flow. Examples will be given below. When we look at a circuit using electronic tubes laid out on paper, we still need to know a good deal in order to calculate just how it will work. How will Simon perceive a number or other information by means of punched tape, or relays, or lights? With punched paper tape having, for example, 2 spaces where holes may be, Simon can be told 4 numbers—00, 01, 10, 11. Here the binary digit 1 means a hole punched; the binary digit 0 means no hole punched. With 2 relays together in a register, Simon can remember any one of the 4 numbers 00, 01, 10, and 11. Here the binary digit 1 means the relay picked up or energized or closed; 0 means the relay not picked up or not energized or open. With 2 lights, Simon can give as an answer any one of the 4 numbers 00, 01, 10, 11. In this case the binary digit 1 means the light glowing; 0 means the light off. (See Fig. 1.) We can say that the two lights by which Simon puts out the answer are his _eyes_ and say that he tells his answer by _winking_. We can say also that the two mechanisms for reading punched paper tape are Simon’s _ears_. One tape, called the _input tape_, takes in numbers or operations. The other tape takes in instructions and is called the _program tape_. SIMON’S MENTALITY—POSSIBLE RANGE OF INFORMATION We can say that Simon has a _mentality_ of 4. We mean not age 4 but just the simple fact that Simon knows only 4 numbers and can do only 4 operations with them. But Simon can keep on doing these operations in all sorts of routines as long as Simon has instructions. We decide that Simon will know just 4 numbers, 0, 1, 2, 3, in order to keep our model mechanical brain very simple. Then, for any register, we need only 2 relays; for any answer, we need only 2 lights. Any calculating machine has a _mentality_, consisting of the whole collection of different ideas that the machine can ever actually express in one way or another. For example, a 10-place desk calculating machine can handle numbers up to 10 decimal digits without additional capacity. It cannot handle bigger numbers. [Illustration: FIG. 2. Four directions.] What are the 4 _operations with numbers_ which Simon can carry out? Let us consider some simple operations that we can perform with just 4 numbers. Suppose that they stood for 4 directions in the order east, north, west, south (see Fig. 2). Or suppose that they stood for a turn counterclockwise through some right angles as follows: 0: Turn through 0°, or no right angles. 1: Turn through 90°, or 1 right angle. 2: Turn through 180°, or 2 right angles. 3: Turn through 270°, or 3 right angles. Then we could have the operations of _addition_ and _negation_, defined as follows: ADDITION NEGATION _c_ = _a_ + _b_ _c_ = -_a_ _b_: 0 1 2 3 _a_|_c_ _a_ +————————— ————+———— 0 | 0 1 2 3 0 | 0 1 | 1 2 3 0 1 | 3 2 | 2 3 0 1 2 | 2 3 | 3 0 1 2 3 | 1 For example, the first table says, “1 plus 3 equals 0.” This means that, if we turn 1 right angle and then turn in the same direction 3 more right angles, we face in exactly the same way as we did at the start. This statement is clearly true. For another example, the second table says, “2 is the negative of 2.” This means that, if we turn to the left 2 right angles, we face in exactly the same way as if we turn to the right 2 right angles, and this statement also is, of course, true. With only these two operations in Simon, we should probably find him a little too dull to tell us much. Let us, therefore, put into Simon two more operations. Let us choose two operations involving both numbers and logic: in particular, (1) finding which of two numbers is greater and (2) selecting. In this way we shall make Simon a little cleverer. It is easy to teach Simon how to find which of two numbers is the greater when all the numbers that Simon has to know are 0, 1, 2, 3. We put all possible cases of two numbers _a_ and _b_ into a table: _b_: 0 1 2 3 _a_+————————— 0 | 1 | 2 | 3 | Then we tell Simon that we shall mark with 1 the cases where _a_ is greater than _b_ and mark with 0 the cases where _a_ is not greater than _b_: GREATER THAN _b_: 0 1 2 3 _a_+————————— 0 | 0 0 0 0 1 | 1 0 0 0 2 | 1 1 0 0 3 | 1 1 1 0 For example, “2 is greater than 3” is false, so we put 0 in the table on the 2 line in the 3 column. We see that, for the 16 possible cases, _a_ is greater than _b_ in 6 cases and _a_ is not greater than _b_ in 10 cases. There is a neat way of saying what we have just said, using the language of _mathematical logic_ (see Chapter 9 and Supplement 2). Suppose that we consider the statement “_a_ is greater than _b_” where _a_ and _b_ may be any of the numbers 0, 1, 2, 3. We can say that the _truth value p_ of a _statement P_ is 1 if the statement is true and that it is 0 if the statement is false: _p_ = 1 if _P_ is true, 0 if _P_ is false The truth value of a statement _P_ is conveniently denoted as _T_(_P_) (see Supplement 2): _p_ = _T_(_P_) Now we can say that the table for the operation _greater than_ shows the truth value of the statement “_a_ is greater than _b_”: _p_ = _T_(_a_ > _b_) Let us turn now to the operation _selection_. By _selecting_ we mean choosing one number _a_ if some statement _P_ is true and choosing another number _b_ if that statement is not true. As before, let _p_ be the truth value of that statement _P_, and let it be equal to 1 if _P_ is true and to 0 if _P_ is false. Then the operation of selection is fully expressed in the following table and logical formula (see Supplement 2): SELECTION _c_ = _a_·_p_ + _b_·(1 - _p_) _p_: 0 0 0 0 1 1 1 1 _b_: 0 1 2 3 0 1 2 3 _a_+—————————————————— 0 | 0 1 2 3 0 0 0 0 1 | 0 1 2 3 1 1 1 1 2 | 0 1 2 3 2 2 2 2 3 | 0 1 2 3 3 3 3 3 For example, suppose that _a_ is 2 and _b_ is 3 and the statement _P_ is the statement “2 is greater than 0.” Since this statement is true, _p_ is 1, and _a_·_p_ + _b_·(1 - _p_) = 2(1) + 3(0) = 2 This result is the same as selecting 2 if 2 is greater than 0 and selecting 3 if 2 is not greater than 0. Thus we have four operations for Simon that do not overstrain his mentality; that is, they do not require him to go to any numbers other than 0, 1, 2, and 3. These four operations are: addition, negation, greater than, selection. We label these operations also with the numbers 00 to 11 as follows: addition, 00; negation, 01; greater than, 10; selection, 11. SIMON’S MEMORY—STORING INFORMATION The _memory_ of a mechanical brain consists of physical equipment in which information can be stored. Usually, each section of the physical equipment which can store one piece of information is called a _register._ Each register in Simon will consist of 2 relays. Each register will hold any of 00, 01, 10, 11. The information stored in a register 00, 01, 10, 11 may express a number or may express an operation. [Illustration: S1-2 Relay energized] [Illustration: S1-1 Relay not energized FIG. 3. Register _S_1 storing 10.] How many registers will we need to put into Simon to store information? We shall need one register to read the input tape and to store the number or operation recorded on it. We shall call this register the _input register I_. We shall need another register to store the number or operation that Simon says is the answer and to give it to the output lights. We shall call this register the _output register O_. We shall need 5 registers for the part of Simon which does the computing, which we shall call the _computer_: we shall need 3 to store numbers put into the computer (_C_1, _C_2, _C_3), 1 to store the operation governing the computer (_C_4), and 1 to store the result (_C_5). Suppose that we decide to have 8 registers for storing information, so as to provide some flexibility for doing problems. We shall call these registers _storage registers_ and name them _S_1, _S_2, _S_3, ··· _S_8. Then Simon will have 15 registers: a memory that at one time can hold 15 pieces of information. How will one of these registers hold information? For example, how will register _S_1 hold the number 2 (see Fig. 3)? The number 2 in machine language is 10. Register _S_1 consists of two relays, _S_1-2 and _S_1-1. 10 stored in register _S_1 means that relay _S_1-2 will be energized and that relay _S_1-1 will not be energized. THE CONTROL OF SIMON So far we have said nothing about the control of Simon. Is he docile? Is he stubborn? We know what his capacity is, but we do not know how to tell him to do anything. How do we connect our desires to his behavior? How do we tell him a problem? How do we get him to solve it and tell us the answer? How do we arrange control over the sequence of his operations? For example, how do we get Simon to add 1 and 2 and tell us the answer 3? On the outside of Simon, we have said, there are two ears: little mechanisms for reading punched paper tape. Also there are two eyes that can wink: light bulbs that by shining or not shining can put out information (see Fig. 1). One of the ears—let us call it the _left ear_—takes in information about a particular problem: numbers and operations. Here the _problem tape_ or _input tape_ is listened to. Each line on the input tape contains space for 2 punched holes. So, the information on the input tape may be 00, 01, 10, or 11—either a number or an operation. The other ear—let us call it the _right ear_—takes in information about the sequence of operations, the program or routine to be followed. Here the _program tape_ or _routine tape_ or _control tape_ is listened to. Each line on the program tape contains space for 4 punched holes. We tell Simon by _instructions_ on the program tape what he is to do with the information that we give him on the input tape. The information on the program tape, therefore, may be 0000, 0001, 0010, ···, 1111, or any number from 0 to 15 expressed in binary notation (see Supplement 2). How is this accomplished? In the first place, Simon is a machine, and he behaves during time. He does different things from time to time. His behavior is organized in _cycles_. He repeats a cycle of behavior every second or so. In each cycle of Simon, he listens to or reads the input tape once and he listens to or reads the program tape twice. Every complete instruction that goes on the program tape tells Simon a register from which information is to be sent and a register in which information is to be received. The first time that he reads the program tape he gets the name of the register that is to receive certain information, the _receiving register_. The second time he reads the program tape he gets the name of the register from which information is to be sent, the _sending register_. He finishes each cycle of behavior by transferring information from the sending register to the receiving register. For example, suppose that we want to get an answer out of Simon’s computer into Simon’s output lights. We put down the instruction Send information from _C_5 into _O_ or, more briefly, _C_5 → _O_ But he does not understand this language. We must translate into machine language, in this case punched holes in the program tape. Naturally, the punched holes in the program tape must be able to specify any sending register and any receiving register. There are 15 registers, and so we give them punched hole _codes_ as follows: REGISTER CODE REGISTER CODE _I_ 0001 _C_1 1010 _S_1 0010 _C_2 1011 _S_2 0011 _C_3 1100 _S_3 0100 _C_4 1101 _S_4 0101 _C_5 1110 _S_5 0110 _O_ 1111 _S_6 0111 _S_7 1000 _S_8 1001 To translate the direction of transfer of information, which we showed as an arrow, we put on the program tape the code for the receiving register first—in this case, output, _O_, 1111—and the code for the sending register second—in this case, _C_5, 1110. The instruction becomes 1111, 1110. The first time in any cycle that Simon listens with his right ear, he knows that what he hears is the name of the receiving register; and the second time that he listens, he knows that what he hears is the name of the sending register. One reason for this sequence is that any person or machine has to be prepared beforehand to absorb or take in any information. Now how do we tell Simon to add 1 and 2? On the input tape, we put: Add 00 1 01 2 10 On the program tape, we need to put: _I_ → _C_4 _I_ → _C_1 _I_ → _C_2 _C_5 → _O_ which becomes: 1101, 0001; 1010, 0001; 1011, 0001; 1111, 1110 THE USEFULNESS OF SIMON Thus we can see that Simon can do such a problem as: Add 0 and 3. Add 2 and the negative of 1. Find which result is greater. Select 3 if this result equals 2; otherwise select 2. To work out the coding for this and like problems would be a good exercise. Simon, in fact, is a rather clever little mechanical brain, even if he has only a mentality of 4. It may seem that a simple model of a mechanical brain like Simon is of no great practical use. On the contrary, Simon has the same use in instruction as a set of simple chemical experiments has: to stimulate thinking and understanding and to produce training and skill. A training course on mechanical brains could very well include the construction of a simple model mechanical brain as an exercise. In this book, the properties of Simon may be a good introduction to the various types of more complicated mechanical brains described in later chapters. The rest of this chapter is devoted to such questions as: How do transfers of information actually take place in Simon? How does the computer in Simon work so that calculation actually occurs? How could Simon actually be constructed? What follows should be skipped unless you are interested in these questions and the burdensome details needed for answering them. SIMON’S THINKING—TRANSFERRING INFORMATION The first basic thinking operation for any mechanical brain is transferring information automatically. Let us see how this is done in Simon. [Illustration: FIG. 4. Scheme of Simon.] Let us first take a look at the scheme of Simon as a mechanical brain (see Fig. 4). We have 1 input, 8 storage, 5 computer, and 1 output registers, which are connected by means of transfer wires or a transfer line along which numbers or operations can travel as electrical impulses. This transfer line is often called the _bus_, perhaps because it is always busy carrying something. In Simon the bus will consist of 2 wires, one for carrying the right-hand digit and one for carrying the left-hand digit of any number 00, 01, 10, 11. Simon also has a number of neat little devices that will do the following: When any number goes into a register, the coils of the relays of the register will be connected with the bus. When any number goes out of a register, the contacts of the relays of the register will be connected with the bus. For example, suppose that in register _C_5 the number 2 is stored. In machine language this is 10. That means the left-hand relay (_C_5-2) is energized and the right-hand relay (_C_5-1) is not energized. Suppose that we want to transfer this number 2 into the output register _O_, which has been cleared. What do we do? Let us take a look at a circuit that will transfer the number (see Fig. 5). First we see two relays in this circuit. They belong to the _C_5 register. The _C_5-2 relay is energized since it holds 1; current is flowing through its coil, the iron core becomes a magnet, and the contact above it is pulled down. The _C_5-1 relay is not energized since it holds 0; its contact is not pulled down. The next thing we see is two _rectifiers_. The sign for these is a triangle. These are some modern electrical equipment that allow electrical current to flow in only one direction. In the diagram, the direction is shown by the pointing of the triangle along the wire. Rectifiers are needed to prevent undesired circuits. Next, we see the bus, consisting of two wires. One carries the impulses for left-hand or 2 relays, and the other carries impulses for the right-hand or 1 relays. Next, we see two relays, called the _entrance relays_ for the _O_ register. Current from Source 1 may flow to these relays, energize them, and close their contacts. When the first line of the program tape is read, specifying the receiving register, the code 1111 causes Source 1 to be energized. This fact is shown schematically by the arrow running from the program tape code 1111 to Source 1. Finally, we see the coils of the two relays for the Output or _O_ register. We thus see that we have a circuit from the contacts of the _C_5 register through the bus to the coils of the _O_ register. [Illustration: FIG. 5. Transfer circuit.] We are now ready to transfer information when the second line of the program tape is read. This line holds 1110 and designates _C_5 as the sending register and causes Source 2 to be energized. This fact is shown schematically by the arrow running from the second line of the program tape to Source 2. When the second line is read, current flows: 1. From Source 2. 2. Through the contacts of the _C_5 register if closed. 3. Through the rectifiers. 4. Through the bus. 5. Through the entrance relay contacts of the _O_ register. 6. Through the coils of the _O_ register relays, energizing such of them as match with the _C_5 closed contacts; and finally 7. Into the ground. Thus relay _O_-2 is energized; it receives current because contact _C_5-2 is closed. And relay _O_-1 is not energized; it receives no current since contact _C_5-1 is open. So we have actually transferred information from the _C_5 register to the _O_ register. The same process in principle applies to all transfers: The pattern of electrical impulses, formed by the positioning of one register, is produced in the positioning of another register. SIMON’S COMPUTING AND REASONING Now so far the computing registers in Simon are a mystery. We have said that _C_1, _C_2, and _C_3 take in numbers 00, 01, 10, 11, that _C_4 takes in an operation 00, 01, 10, 11, and that _C_5 holds the result. What process does Simon use so that he has the correct result in register _C_5? Let us take the simplest computing operation first and see what sort of a circuit using relays will give us the result. The simplest computing operation is _negation_. In negation, a number 00, 01, 10, 11 goes into the _C_1 register, and the operation 01 meaning negation goes into the _C_4 register, and the correct result must be in the _C_5 register. So, first, we note the fact that the _C_4-2 relay must not be energized, since it contains 0, and that the _C_4-1 relay must be energized, since it contains 1. Now the table for negation, with _c_ =-_a_, is: _a_ | _c_ ————+———— 0 | 0 1 | 3 2 | 2 3 | 1 Negation in machine language will be: _a_ | _c_ ————+———— 00 | 00 01 | 11 10 | 10 11 | 01 Now if _a_ is in the _C_1 register and if _c_ is in the _C_5 register, then negation will be: _C_1 | _C_5 —————+————— 00 | 00 01 | 11 10 | 10 11 | 01 But each of these registers _C_1, _C_5 will be made up of two relays, the left-hand or 2 relay and the right-hand or 1 relay. So, in terms of these relays, negation will be: _C_1-2 _C_1-1 | _C_5-2 _C_5-1 ——————————————+—————————————— 0 0 | 0 0 0 1 | 1 1 1 0 | 1 0 1 1 | 0 1 Now, on examining the table, we see that the _C_5-1 relay is energized if and only if the _C_1-1 relay is energized. So, in order to energize the _C_5-1 relay, all we have to do is transfer the information from _C_1-1 to _C_5-1. This we can do by the circuit shown in Fig. 6. (In this and later diagrams, we have taken one more step in streamlining the drawing of relay contacts: the contacts are drawn, but the coils that energize them are represented only by their names.) [Illustration: FIG. 6. Negation—right-hand digit.] [Illustration: FIG. 7. Negation—left-hand digit.] Taking another look at the table, we see also that the _C_5-2 relay must be energized if and only if: _C_1-2 AND _C_1-1 HOLDS: HOLDS: 0 1 1 0 A circuit that will do this is the one shown in Fig. 7. In Fig. 8 is a circuit that will do all the desired things together: give the right information to the _C_5 relay coils if and only if the _C_4 relays hold 01. [Illustration: FIG. 8. Negation circuit.] Let us check this circuit. First, if there is any operation other than 01 stored in the _C_4 relays, then no current will be able to get through the _C_4 contacts shown and into the _C_5 relay coils, and the result is blank. Second, if we have the operation 01 stored in the _C_4 relays, then the _C_4-2 contacts will not be energized—a condition which passes current—and the _C_4-1 contacts will be energized—another condition which passes current—and: IF THE NUMBER AND THE _C_5 RELAYS IN _C_1 IS: THEN _C_1-1: AND _C_1-2: ENERGIZED ARE: 0 does not close does not close neither 1 closes does not close _C_5-2, _C_5-1 2 does not close closes _C_5-2 only 3 closes closes _C_5-1 only Thus we have shown that this circuit is correct. We see that this circuit uses more than one set of contacts for several relays (_C_1-2, _C_4-1, _C_4-2); relays are regularly made with 4, 6, or 12 sets of contacts arranged side by side, all controlled by the same pickup coil. These are called 4-, 6-, or 12-_pole_ relays. [Illustration: FIG. 9. Addition circuit.] [Illustration: FIG. 10. Greater-than circuit.] Circuits for _addition_, _greater than_, and _selection_ can also be determined rather easily (see Figs. 9, 10, 11). (_Note_: By means of the _algebra of logic_, referred to in Chapter 9 and Supplement 2, the conditions for many relay circuits, as well as the circuit itself, may be expressed algebraically, and the two expressions may be checked by a mathematical process.) For example, let us check that the addition circuit in Fig. 9 will enable us to add 1 and 2 and obtain 3. We take a colored pencil and draw closed the contacts for _C_1-1 (since _C_1 holds 01) and for _C_2-2 (since _C_2 holds 10). Then, when we trace through the circuit, remembering that addition is stored as 00 in the _C_4 relays, we find that both the _C_5 relays are energized. Hence _C_5 holds 11, which is 3. Thus Simon can add 1 and 2 and make 3! [Illustration: FIG. 11. Selection Circuit.] PUTTING SIMON TOGETHER In order to put Simon together and make him work, not very much is needed. On the outside of Simon we shall need two small mechanisms for reading punched paper tape. Inside Simon, there will be about 50 relays and perhaps 100 feet of wire for connecting them. In addition to the 15 registers (_I_, _S_1 to _S_8, _C_1 to _C_5, and _O_), we shall need a register of 4 relays, which we shall call the _program register_. This register will store the successive instructions read off the program tape. We can call the 4 relays of this register _P_8, _P_4, _P_2, _P_1. For example, if the _P_8 and _P_2 relays are energized, the register holds 1010, and this is the program instruction that calls for the 8th plus 2nd, or 10th, register, which is _C_1. For connecting receiving registers to the bus, we shall need a relay with 2 poles, one for the 2-line and one for the 1-line, for each register that can receive a number from the bus. For example, for entering the output register, we actually need only one 2-pole relay instead of the two 1-pole relays drawn for simplicity in Fig. 5. There will be 13 2-pole relays for this purpose, since only 13 registers receive numbers from the bus; registers _I_ and _C_5 do not receive numbers from the bus. We call these 13 relays the _entrance relays_ or _E relays_, since _E_ is the initial letter of the word entrance. [Illustration: FIG. 12. Select-Receiving-Register circuit.] The circuit for selecting and energizing the _E_ relays is shown in Fig. 12. We call this circuit the _Select-Receiving-Register_ circuit. For example, suppose that the _P_8 and _P_2 relays are energized. Then this circuit energizes the _E_10 relay. The _E_10 relay closes the contacts between the _C_1 relay coils and the bus; and so it connects the _C_1 register to receive the next number that is sent into the bus. This kind of circuit expresses a classification and is sometimes called a _pyramid circuit_ since it spreads out like a pyramid. A similar pyramid circuit is used to select the sending register. We shall need a relay for moving the input tape a step at a time. We shall call this relay the _MI relay_, for _m_oving _i_nput tape. We also need a relay for moving the program tape a step at a time. We shall call this relay the _MP relay_ for _m_oving _p_rogram tape. Here then is approximately the total number of relays required: RELAYS NAME NUMBER _I_, _S_, _C_, _O_ Input, Storage, Computer, Output 30 _P_ Program 4 _E_ Entrance 13 _MI_ Move Input Tape 1 _MP_ Move Program Tape 1 ———— Total 49 A few more relays may be needed to provide more contacts or poles. For example, a single _P_1 relay will probably not have enough poles to meet all the need for its contacts. [Illustration: FIG. 13. Latch relay.] Each cycle of the machine will be divided into 5 equal _time intervals_ or _times_ 1 to 5. The timing of the machine will be about as follows: TIME ACTION 1 Move program tape. Move input tape if read out of in last cycle. 2 Read program tape, determining the receiving register. Read through the computing circuit setting up the _C_5 register. 3 Move program tape. Energize the _E_ relay belonging to the receiving register. 4 Read program tape again, determining the sending register. 5 Transfer information by reading through the Select-Sending-Register circuit and the Select-Receiving-Register circuit. In order that information may remain in storage until wanted, register relays should hold their information until just before the next information is received. This can be accomplished by keeping current in their coils or in other ways. There is a type of relay called a _latch relay_, which is made with two coils and a latch. This type of relay has the property of staying or latching in either position until the opposite coil is impulsed (see Fig. 13). This type of relay would be especially good for the registers of Simon. If any reader sets to work to construct Simon, and if questions arise, the author will be glad to try to answer them. Chapter 4 COUNTING HOLES: PUNCH-CARD CALCULATING MACHINES When we think of counting, we usually think of saying softly to ourselves “one, two, three, four, ···.” This is a good way to find the total of a small group of objects. But when we have a large group of objects or a great many groups of objects to be counted, a much faster way of counting is needed. A very fast way of sorting and counting is _punch-card calculating machinery_. This is machinery which handles information expressed as holes in cards. _Punch-card machines_ can: Sort, count, file, select, and copy information, Make comparisons, and choose according to instructions, Add, subtract, multiply, and divide, List information, and print totals. For example, in a life insurance company, much routine handling of information about insurance policies is necessary: Writing information on newly issued policies. Setting up policy-history cards. Making out notices of premiums due. Making registers of policies in force, lapsed, died, etc., for purposes of valuation as required by law or good management. Calculating and tabulating premium rates, dividend rates, reserve factors, etc. Computing and tabulating expected and actual death rates; and much more. All these operations can be done almost automatically by punch-card machines. ORIGIN AND DEVELOPMENT When a census of the people of a country is taken, a great quantity of sorting and counting is needed: by village, county, city, and state; by sex; by age; by occupation; etc. In 1886, the census of the people of the United States which had been taken in 1880 was still being sorted and counted. Among the men then studying census problems was a statistician and inventor, Herman Hollerith. He saw that existing methods were so slow that the next census (1890) would not be finished before the following census (1900) would have to be begun. He knew that cards with patterns of holes had been used in weaving patterns in cloth. He realized that the presence or absence of a property, for example employed or unemployed, could be represented by the presence or absence of a hole in a piece of paper. An electrical device could detect the hole, he believed, since it would allow current to flow through, whereas the absence of the hole would stop the current. He experimented with sorting and counting, using punched holes in cards, and with electrical devices to detect the holes and count them. A definite meaning was given to each place in the card where a hole might be punched. Then electrical devices handled the particular information that the punches represented. These devices either counted or added, singly or in various combinations, as might be desired. More than 50 years of development of punch-card calculating machinery have since then taken place. Several large companies have made quantities of punch-card machines. A great degree of development has taken place in the punch-card machines of International Business Machines Corporation (IBM), and for this reason these machines will be the ones described in this chapter. What is said here, however, may also in many ways apply to punch-card machines made by other manufacturers—Remington-Rand, Powers, Control Instrument, etc. GENERAL PRINCIPLES To use punch-card machines, we first convert the original information into patterns of holes in cards. Then we feed the cards into the machines. Electrical impulses read the pattern of holes and convert them into a pattern of timed electrical currents. Actually, the reading of a hole in a column of a punch card is done by a brush of several strands of copper wire pressed against a metal roller (Fig. 1). The machine feeds the card (the bottom edge first, where the 9’s are printed) with very careful timing over the roller; and, when the punched hole is between the brush and the roller, an electrical circuit belonging to that column of the card is completed. The machine responds according to its general design and its wiring for the particular problem: it punches new cards, or it prints new marks, or it puts information into new storage places. Clerks, however, move the cards from one machine to another. They wait on the machines, keep the card feeds full, and empty the card hoppers as they fill up. A human error of putting the wrong block of cards into a machine may from time to time cause a little trouble, especially in sorting. Actually, in a year, billions of punch cards are handled precisely. [Illustration: FIG. 1. Reading of punch cards.] The _punch card_ is a masterpiece of engineering and standardization. Its exact thickness matches the knife-blade edges that feed the cards into slots in the machines, and matches the channels whereby these cards travel through the machines. The standard card is 7⅜ inches long and 3¼ inches wide, and it has a standard thickness of 0.0065 inch and other standard properties with respect to stiffness, finish, etc. [Illustration: FIG. 2. Scheme of standard punch card. (Note: Positions 11 and 12 are not usually marked by printed numbers or letters.)] The standard IBM punch card of today has 80 _columns_ and 12 _positions_ for punching in each column (Fig. 2). A single punched hole in each of the positions known as 0 to 9 stands for each of the digits 0 to 9 respectively. The remaining 2 single punch positions available in any column are usually called the _11 position_ and _12 position_ (though sometimes called the numerical _X position_ and _Y position_). These two positions do not behave arithmetically as 11 and 12. Actually, in the space between one card and the next card as they are fed through the machines, more positions occur. For example, there may be 4 more: a 10 position preceding the 9, and a 13, a 14, and a 15 position following the 12. The 16 positions in total correspond to a full turn, 360°, of the roller under the brush, and to a complete _cycle_ in the machine; and a single position corresponds to ¹/₁₆ of 360°, or 22½°. In some machines, the total number of positions may be 20. A pair of punches stands for each of the letters of the alphabet, according to the scheme shown. A 12-1 J 11-1 Unused 0-1 B 12-2 K 11-2 S 0-2 C 12-3 L 11-3 T 0-3 D 12-4 M 11-4 U 0-4 E 12-5 N 11-5 V 0-5 F 12-6 O 11-6 W 0-6 G 12-7 P 11-7 X 0-7 H 12-8 Q 11-8 Y 0-8 I 12-9 R 11-9 Z 0-9 For example, the word MASON is shown punched in Fig. 3. [Illustration: FIG. 3. Alphabetic punching.] [Illustration: FIG. 4. Single-panel plugboard.] To increase the versatility of the machines and provide them with instructions, many of them have _plugboards_ (Fig. 4). These are standard interchangeable boards filled with prongs on one side and holes or terminals called _hubs_ on the other side. The side with the prongs connects to the ends of electrical circuits in the punch-card machine, which are brought together in one place for the purpose. On the other side of the board, using plugwires, we can connect the hubs to each other in different ways to produce different results. The single-panel plugboard is 10 inches long and 5¾ inches wide. It contains 660 hubs in front and 660 corresponding prongs in the back. A double-panel plugboard or a triple-panel plugboard applies to some machines. In less time than it takes to describe it, we can take one wired-up plugboard out of a machine and put in a new wired-up plugboard and thus change completely the instructions under which the machine operates. Many of the machines have a number of different switches that we must also change, when going from one kind of problem to another. The numbers that are stored or sorted in punch-card machines may be of any size up to 80 digits, one in each column of the punch card. In doing arithmetic (adding, subtracting, multiplying, and dividing), however, the largest number of digits is usually 10. Beyond 10 digits, we can work out tricks in many cases. TYPES OF PUNCH-CARD MACHINES The chief IBM punch-card machines are: the _key punch_, the _verifier_, the _sorter_, the _interpreter_, the _reproducer_, the _collator_, the _multiplying punch_, the _calculating punch_, and the _tabulator_. Of these 9 machines, the last 6 have plugboards and can do many different operations as a result. There is a flow of punch cards through each of these machines. The machines differ from each other in the number and relation of the paths of flow, or _card channels_, and in the number and relation of the momentary stopping places, or _card stations_, at which cards are read, punched, or otherwise acted on. We can get a good idea of what a machine is from a picture of these card channels. Key Punch We use a key punch (Fig. 5) to punch original information into blank cards. In the key punch there is one card channel; it has one entrance, one station, and one exit. At the card station, there are 12 _punching dies_, one for each position in the card column, and each card column is presented one by one for punching. The numeric _keyboard_ (Fig. 6) for the key punch has 14 keys: One key for each of the punches 0 to 9, 11, and 12, A _space key_, which allows a column of the punch card to go by with no punch in it, A _release key_, which ejects the card and feeds another card. [Illustration: FIG. 5. Key punch.] [Illustration: FIG. 6. Keyboard of key punch.] Of course, in using a key punch, we must punch the same kind of information in the same group of columns. For example, if these cards are to contain employees’ social security numbers, we must punch that number always in the same card columns, numbered, say, 15 to 23, or 70 to 78, etc. Verifier The verifier is really the same machine as the key punch, but it has dull punching dies moving gently instead of sharp ones moving with force. It turns on a red light and stops when there is no punched hole in the right spot to match with a pressed key. Sorter The sorter is a machine for sorting cards, one column at a time (Fig. 7). The sorter has a card channel that forks; it has one entrance, one station, and 13 exits. Each exit corresponds to: one of the 12 punch positions 0 to 9, 11, and 12; or _reject_, which applies when the column is nowhere punched. It has one card station where a brush reads a single column of the card. We can turn a handle and move the brush to any column. [Illustration: FIG. 7. Sorter.] Interpreter The interpreter takes in a card, reads its punches, prints on the card the marks indicated by the punches, and stacks the card. We call this process _interpreting_ the card, since it translates the punched holes into printed marks. The interpreter (Fig. 8) has one card channel, with one entrance, 2 card stations, and one exit. What the machine does at the second card station depends on what the machine reads at the first card station and on what we have told the machine by switches and plugboard wiring to do. [Illustration: FIG. 8. Interpreter.] Reproducer The reproducer or reproducing punch can: _Reproduce_, or copy the punches in one group of cards into another group of cards (in the same or different columns). _Compare_, or make sure that the punches in two groups of cards agree (and shine a red light if they do not). _Gang punch_, or copy the punches in a _master card_ into a group of _detail cards_. _Summary punch_, or copy totals or summaries obtained in the tabulator into blank cards in the reproducer. [Illustration: FIG. 9. Reproducer.] The reproducer (Fig. 9) has 2 independent card channels, the cards not mingling in any way, called the _reading channel_ and the _punching channel_. We can run the machine with only the punching channel working; in fact, IBM equips some models only with the punching channel, particularly for “summary punch” operation. The machine is timed so that, when any card is at the middle station in either channel, then the next preceding card is at the latest station, and the next following card is at the earliest station. At 5 stations, the machine reads a card. At the middle station of the punching channel, the machine punches a card. Using a many-wire cable, we can connect the tabulator to the reproducer and so cause the tabulator to give information electrically to the reproducer. This connection makes possible the “summary punch” operation. Here is an instance with punch-card machines where, in order to transfer information from one machine to another, we are not required to move cards physically from one machine to another. Collator The collator is a machine that arranges or _collates_ cards. It is particularly useful in selecting, matching, and merging cards. The collator (Fig. 10) has 2 card channels which join and then fork into 4 channels ending in pockets called _Hoppers_ 1, 2, 3, and 4. The 2 card feeds are called the _Primary Feed_ and the _Secondary Feed_. Cards from the Primary Feed may fall only into the first and second hoppers. Cards from the Secondary Feed may fall only into the second, third, and fourth hoppers. The collator has 3 stations at which cards may be read. [Illustration: No.1--Selected primaries No.2--Merged cards and unselected primaries No.3--Separate secondaries not selected No.4--Selected secondaries FIG. 10. Collator.] IBM can supply additional wiring called the _collator counting device_. With this we can make the collator count cards as well as compare them. For example, we could put 12 blank cards from the Secondary Feed behind each punched-card from the Primary Feed in order to prepare for some other operation. Calculating Punch The calculating punch was introduced in 1946. It is a versatile machine of considerable capacity. It adds, subtracts, multiplies, and divides. It also has a control over a sequence of operations, in some cases up to half a dozen steps. This machine (Fig. 11) has one card channel with 4 stations called, respectively, _control brushes_, _reading brushes_, _punch feed_, and _punching dies_. At station 1, there are 20 brushes; we can set these by hand to read any 20 of the 80 card columns. At station 2 there are 80 regular reading brushes. At station 3 the card waits for a part of a second while the machine calculates, and, when that is done, the card is fed into station 4, where it is punched or verified. The multiplying punch is an earlier model of the calculating punch, without the capacity for division. [Illustration: FIG. 11. Calculating punch.] Tabulator The tabulator can select and list information from cards. Also, it can total information from groups of cards in _counters_ of the tabulator and can print the totals. [Illustration: FIG. 12. Tabulator.] The tabulator (Fig. 12) has one card channel with two stations where cards may be read, called the _Upper Brushes_ and _Lower Brushes_. When the Lower Brush station is reading one card, the Upper Brush station is reading the next card. The tabulator also has another channel, which is for endless paper (and sometimes separate sheets or cards). This channel has one station; here printing takes place. Unlike the typewriter, the tabulator prints a whole row at a time. It can print up to 88 numerals or letters across the sheet in one stroke. The cards flowing through the card channel and the paper flowing through the paper channel do not have to move in step; in fact, we need many different time relations between them, and the number of rows printed on the paper may have almost any relation to the number of punch cards flowing through the card channel. At the station where paper is printed, we can put on the machine a mechanism called the _automatic carriage_. This is like a typewriter carriage, which holds the paper for a typewriter, but we can control the movement of paper through the automatic carriage by plugboard wiring, switch settings, and holes in punch cards. Thus we can arrange for headings, spacing, and feeding of new sheets to be controlled by the information and the instructions, with a great deal of versatility. HANDLING INFORMATION We have now described briefly the chief available punch-card machines as of the middle of 1948. The next question is: How do we actually get something done by means of punch cards? Let us go back to the census example, even though it may not be a very typical example, and see what would be done if we wished to compile a census by punch cards. The first thing we do is plan which columns of the punch card will contain what information about the people being counted. For example, the following might be part of the plan: NO. OF INFORMATION POSSIBILITIES COLUMNS State 60 1- 2 County 1,000 3- 5 Township 10,000 6- 9 City or village 10,000 10-13 Sex 2 14 Age last birthday 100 15-16 Occupation 100,000 17-21 ... ... ... Under the heading state, we know that there are 48 states, the District of Columbia, and several territories and possessions—all told, perhaps 60 possibilities. So, 2 punch-card columns are enough: they will allow 100 different sets of punches from 00 to 99 to be put in them. We then assign the _code_ 00 to Maine, 01 to New Hampshire, 02 to Vermont, etc., or we might assign the code 00 to Alabama, 01 to Arizona, 02 to Arkansas, etc.—whichever would be more useful. Under the other headings, we do the same thing: count the possibilities; assign codes. In this case, it will be reasonable to use numeric codes 0 to 9 in each column in all places because we shall have millions of cards to deal with and numeric codes can be sorted faster than alphabetic codes. Alphabetic codes require 2 punched holes in each column, and sorting any column takes 2 operations. The punch cards are printed with the chosen headings. We set up the codes in charts and give them to clerks. Using key punches and verifiers, they punch up the cards and check them. They work from the original information collected by the census-taker in the field. Since the original information will come in geographically, probably only one geographic code at a time will be needed, and it will be simple to keep track of. As to occupation, however, it may be useful to assign other clerks full-time to examining the original information and specifying the right code for the occupation. Then the clerks who do the punching will have only copying to do. The great bulk of the work with the census will be sorting, counting, and totaling. The original punch cards will be summarized into larger and larger groups. For example, the cards for all males age 23 last birthday living in the state of Massachusetts are sorted together. This group of cards may be put into a tabulator wired to a summary punch. When the tabulator has counted the last card of this group, the summary punch punches one card, showing the total number in this group. Some time later a card like this will be ready for every state. Then the whole group of state cards may be fed into the tabulator wired to the reproducer acting as summary punch. When totaled, the number of males age 23 last birthday in the United States will be punched into a single card. After more compiling, a card like this will be ready for all males in the United States at each age. Then this group of cards may be fed into the tabulator wired to the summary punch. Each card may be listed by the tabulator on the paper flowing through it, showing the age and the number of males living at that age. At the end of the listing, the tabulator will print the total number of all males in the list, and the summary punch will punch a card containing this total. ARITHMETICAL OPERATIONS Punch-card machines can perform the arithmetical operations of counting, adding, subtracting, multiplying, dividing, and rounding off. Counting Counting can be done by the sorter, the tabulator, and the collator. The tabulator can print the total count. The tabulator and summary punch wired together can put the total count automatically into another punch card. The sorter shows the count in dials. Adding and Subtracting Adding and subtracting can be done by the tabulator, the calculating punch, and the multiplying punch. In the calculating and multiplying punches, the sum or difference is usually punched into the same card from which the numbers were first obtained. The tabulator, however, obtains the result first in a counter; from the counter, it can be printed on paper or punched into a blank card with the aid of the summary punch. Numbers are handled as groups of decimal digits, and the machines mirror the properties of digits in the decimal system. Negative numbers are usually handled as _complements_ (see Supplement 2). For example, if we have in the tabulator a counter with a capacity of six digits, the number-000013 is stored in the counter as the complement 999987. We cannot store in the counter the number +999987, since we cannot distinguish it from-000013. In other words, if a counter is to be used for both positive and negative numbers, its capacity is actually one digit less, since in the last decimal place on the left 0 will mean positive and 9 will mean negative. Multiplying and Dividing Multiplying is done in the calculating and multiplying punches. In both cases, the multiplication table is built into the circuits of the machine, and the system of _left-hand components_ and _right-hand components_ is used (see Supplement 2). Dividing is done in the calculating punch and is carried out in that machine much as in ordinary arithmetic. By means of an estimating circuit the calculating punch guesses what multiple of the divisor will go into the dividend. Then it determines that multiple and tries it. Rounding Off Rounding off may be done in 3 punch-card machines, the calculating and multiplying punches, and the tabulator. For example, suppose we have the numbers 49.1476, 68.5327, and we wish to round them off to 2 decimal places. The results will be 49.15 and 68.53. For the first number, we raise the .0076, turning .1476 into .15, since .0076 is more than .005. For the second number, we drop the .0027 since it is less than .005. Each of these punch-card machines provides what is called a _5 impulse_ in each machine cycle. When the number is to be rounded off, the 5 impulse is plugged into the first decimal place that is to be dropped, and it is there added. If the figure in the decimal place to be dropped is 0 to 4, the added 5 makes no difference in the last decimal place that is to be kept. But, if the figure in the decimal place to be dropped is 5 to 9, then the added 5 makes a carry into the last decimal place that is to be kept, increasing it by 1, and this is just what is wanted for rounding off. LOGICAL OPERATIONS Punch-card machines do many operations of reasoning or logic that do not involve addition, subtraction, multiplication, or division. Just as we can write equations for arithmetical operations, so we can write equations for these logical operations using mathematical logic (see Chapter 9 and Supplement 2). If any reader, however, is not interested in these logical equations, he should skip each paragraph that begins with “in the language of logic,” or a similar phrase. Translating Reading and writing are operations perhaps not strictly of reasoning but of _translating_ from one language to another. Basically these operations take in a mark in one language and give out a mark with the same meaning in another language. For example, the interpreter takes in punched holes and gives out printed marks, but the holes and the marks have the same meaning. The major part of sorting is done by a punch-card sorting machine and can be considered an operation of translating. In sorting a card, the machine takes in a mark in the form of a punched hole on a punch card and specifies a place bearing the same mark where the card is put. The remaining part of sorting is done by human beings. This part consists of picking up blocks of cards from the pockets of the sorter and putting the blocks together in the right sequence. Comparing [Illustration: FIG. 13. Comparer.] The first operation of reasoning done by punch-card machines is _comparing_. For an example of comparing in the operation of the tabulator, let us take instructing the machine when to pick up a total and print it. As an illustration, suppose that we are making a table by state, county, and township of the number of persons counted in a census. Suppose that for each township we have one punch card telling the total number of persons. If all the cards are in sequence, then, whenever the county changes, we want a minor total, and, whenever the state changes, we want a major total. What does the machine do? The tabulator has a mechanism that we shall call a _comparer_ (Fig. 13). A comparer has 2 inputs that may be called _Previous_ and _Current_ and one output that may be called _Unequal_. The comparer has the property of giving out an impulse if and only if there is a difference between the 2 inputs. In the language of the algebra of logic (see Supplement 2 and Chapter 9), let the pieces of information coming into the comparer be _a_ and _b_, and let the information coming out of the comparer be _p_. Then the equation of the comparer is: _p_ = _T_(_a_ ≠ _b_) where “_T_ (···)” is “the truth value of ···” and “···” is a statement, and where the truth value is 1 if true and 0 if false. In wiring the tabulator so that it can tell when to total, we use the comparer. We feed into it the county from the current card and the county from the previous card. Out of the comparer we get an impulse if and only if these two pieces of information are different. This is just what happens when the county changes. The impulse from the comparer is then used in further wiring of the tabulator: it makes the counter that is busy totaling the number of persons in the county print its total and then clear. In the same way, another comparer, which watches state instead of county, takes care of major totals when the state changes. Selecting The next operation of reasoning which punch-card machines can do is _selecting_. The tabulator, collator, interpreter, reproducer, and calculating punch all may contain mechanisms that can select information. These mechanisms are called _selectors_. For example, suppose that we are using the tabulator to make a table showing for each city the number of males and the number of females. In the table we shall have three columns: first, city; second, males; third, females. Suppose that each punch card in columns 30 to 36 shows the total of males or females in a city. Suppose that, if and only if the card is for females, it has an X punch (or 11 punch) in column 79. What do we want to have happen? We want the number in columns 30 to 36 to go into the second column of the table if there is no X in column 79, and we want it to go into the third column of the table if there is an X in column 79. This is just another way of saying that we want the number to go into the males column if it is a number of males, and into the females column if it is a number of females. We make this happen by using a selector. A selector (Fig. 14) is a mechanism with 2 inputs and 2 outputs. The 2 inputs are called _X Pickup_ and _Common_. The 2 outputs are called _X_ and _No X_. The X Pickup, as its name implies, watches for X’s. The Common takes in information. What comes out of X is what goes into Common if and only if an X punch is picked up; otherwise nothing comes out. What comes out of No X is what goes into Common if and only if an X punch is not picked up; otherwise nothing comes out. From the point of view of ordering punch-card equipment, we should note that there are two types of selectors: _X selectors_ or _X distributors_, which have a selecting capacity of one column—that is, one decimal digit—and _class selectors_, which ordinarily have a selecting capacity of 10 columns or 10 decimal digits. But we shall disregard this difference here, as we have disregarded most other questions of capacity in multiplication, division, etc. [Illustration: FIG. 14. Selector.] In the language of logic (see Chapter 9 and Supplement 2), if _p_, _a_, _b_, _c_ are the information in X Pickup, Common, X, and No X, respectively, then the equations for a selector are: _b_ = _a_·_p_ _c_ = _a_·(1 - _p_) Returning now to the table we wish to make, we connect columns 30 to 36 of the punch card to Common. We connect column 79 of the punch card to the X Pickup. We connect the output No X to the males column of the table. We connect the output X to the females column of the table. In this way we make the number in the punch card appear in either one of two places in the table according to whether the number counts males or females. We might mention several more properties of selectors. A selector can be used in the reverse way, with X Pickup, X, and No X as inputs and Common as output (Fig. 15). What will come out of Common is (1) what goes into input No X if there is no X punch in the column to which input X Pickup is wired, and (2) what goes into input X if there is an X punch in the column to which input X Pickup is wired. In this case the logical equation for the selector is: _a_ = _bp_ + _c_(1 - _p_) Also, selectors can be used one after another, so that selecting based on 2 or 3 X punches can be made. [Illustration: FIG. 15. Selector.] In the language of logic, if _p_, _q_, _r_ are the truth values of “there is an X punch in column _i_, _j_, _k_,” respectively, then by means of selectors we can get such a function as: _c_ = _apq_ + _b_(1 - _q_)(1 - _r_) Also, a selector may often be energized not only by an X punch but also by a punch 0, 1, 2, ···, 9 and 12. In this case, the selector is equipped with an additional input that can respond to any digit. This input is called the Digit Pickup. Digit Selector Something like an ordinary selector is another mechanism called a _digit selector_ (Fig. 16). This has one input, Common, and 12 outputs, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12. This mechanism is often included in the tabulator and may be included in other punch-card machines. For example, suppose that we want to do something if and only if column 62 of a punch card contains a 3 or a 4 or a 9. Then we connect a brush that reads column 62 of the punch card to the Common input of the digit selector. And we connect out from the digit selector jointly from outputs 3, 4, and 9. [Illustration: FIG. 16. Digit selector.] In the language of logic, if _a_ is the digit going into Common, and if _p_ is the impulse coming out of the digit selector, then the equation of the mechanism in this case is: _p_ = _T_(_a_ = 3, 4, 9) Sequencer A fourth operation of reasoning done by punch-card machines is finding that one number is greater than, or equal to, or less than another. This operation is done in the collator and may be called _sequencing_. For example, suppose that we have a file of punch cards for cities, showing in columns 41 to 48 the number of people. Suppose that we wish to pick out the cards for cities over 125,000 in population. Now the collator has a mechanism that has 2 inputs and 3 outputs (Fig. 17). We may call this mechanism a _sequencer_, since it can tell the sequence of two numbers. What goes into the _Primary_ input is a number: let us call it _a_. What goes into _Secondary_ is another number: let us call it _b_. An impulse comes out of _Low Primary_ if _a_ is less than _b_. An impulse comes out of _Equal_ if _a_ equals _b_. An impulse comes out of _Low Secondary_ if _a_ is greater than _b_. [Illustration: FIG. 17. Sequencer.] In the language of logic, if _p_, _q_, _r_ are the three indications in Low Primary, Equal, and Low Secondary, then: _p_ = _T_(_a_ < _b_) _q_ = _T_(_a_ = _b_) _r_ = _T_(_a_ > _b_) Returning to our example, we punch up a card with 125,000 in columns 43 to 48, and we put this card into the Secondary Feed. We take the punch cards for cities and put them into the Primary Feed. In the plugboard, we connect the hubs of the Secondary Brushes (that read the card in the Secondary Feed), columns 43 to 48, to the Secondary input of the Sequencer. We connect the hubs of the Primary Brushes (that read the card in the Primary Feed), columns 41 to 48, to the Primary input of the Sequencer. Then we connect the Low Primary output of the Sequencer to a device that causes the city card being examined to fall into pocket 1. We connect Equal output and Low Secondary output to a device that causes the city card being examined to fall into pocket 2. Then, when the card for any city comes along, the machine compares the number of people in the city with 125,000. If the number is greater than 125,000, the card will fall into pocket 1; otherwise the card will fall into pocket 2. At the end of the run, we shall find in pocket 1 all the cards we want. NEW DEVELOPMENTS We may expect to see over the next few years major developments in punch-card machinery. It would seem likely that types of punch-card machines like the following might be constructed: A punch-card machine that performs any arithmetical or logical operation at high speed and may perform a dozen such operations in sequence during the time that a punch card passes through the machine. A punch-card machine that uses loops of punched paper tape, which express either a sequence of values in a table that the machine can consult or a sequence of instructions that govern the operations of the machine. Punch-card machinery that uses a larger card than the 80-column card. A punch-card machine that may have a fairly large amount of internal memory, perhaps 30 or 40 registers where numbers or words may be stored and referred to. SPEED The speed of various operations with present IBM punch-card machines is about as shown in the table. MACHINE OPERATION TIME IN SECONDS Key punch Punch 80 columns About 20 to 40 Verifier Check 80 columns About 20 to 40 Sorter Sort 1 card on 1 column 0.15 Interpreter Print 1 line 0.8 Reproducer Reproduce a card, all 80 columns 0.6 Collator Merge 2 cards 0.25 Multiplying punch Multiply by 8 digits 5.6 Calculating punch Add 0.3 Calculating punch Multiply by 8 digits 3.6 Calculating punch Divide, obtaining 8 quotient digits 9.0 Tabulator Print 1 line, numbers only 0.4 Tabulator Print 1 line, letters included 0.75 Tabulator Add numbers from 1 card 0.4 COST Punch-card machines may be either rented or purchased from some manufacturers but only rented from others. If we take the cost of a clerk as $120 to $150 a month, the monthly rent of most punch-card machines ranges from ⅒ of the cost of a clerk for the simplest type of machine, such as a key punch, to 3 times the cost of a clerk for a complicated and versatile type of machine, such as a tabulator with many attachments. The rental basis is naturally convenient for many kinds of jobs. RELIABILITY The reliability of work with punch cards and punch-card machines is often much better than 99 per cent: in 10,000 operations, failures should be less than 2 or 3. This is, of course, much better than with clerical operations. There are a number of causes for machine or card failures. Sometimes cards may be warped and may not feed into the machines properly. Or, the air in the room may be very dry, and static electricity may make the cards stick together. Or, the air may be too humid; the cards may swell slightly and may jam in the machine. A punch may get slightly out of true alignment, and punches in the cards may be slightly off. A relay may get dust on its contact points and, from time to time, fail to perform in the right way. Considerable engineering effort has been put into remedying these and other troubles, with much success. To make sure that we have correct results from human beings working with punch-card machines, we may verify each process. Information that is punched on the key punch may be verified on the verifier. Multiplications done with multiplicand _a_ and multiplier _b_ may be repeated and compared with multiplications done with multiplicand _b_ and multiplier _a_. Cards that are sorted on the sorter may be put through the collator to make sure that their sequence is correct. It is often good to plan every operation so that we have a proof that the result is right. It is standard practice to have the machines inspected regularly in order to keep them operating properly. On the average, for every 50 to 75 machines, there will be one full-time service man maintaining them and taking care of calls for repairs. Of course, as with any machinery, some service calls will be a result of the human element; for example, a problem may have been set up wrongly on a machine. GENERAL USEFULNESS Punch-card calculations are much faster and more accurate than hand calculations. With punch cards, work is organized so that all cases are handled at the same time in the same way. This process is very different from handling each case separately from start to finish. As soon as the number of cases to be handled is more than a hundred and each item of information is to be used five or more times, punch cards are likely to be advantageous, provided other factors are favorable. Vast quantities of information have been handled very successfully by punch-card machines. Over 30 scientific and engineering laboratories in the United States are doing computation by punch cards. Over a billion punch cards, in fact, are used annually in this country. Chapter 5 MEASURING: MASSACHUSETTS INSTITUTE OF TECHNOLOGY’S DIFFERENTIAL ANALYZER NO. 2 In the previous chapter we talked about machines that move information expressed as holes in cards. In this chapter we shall talk about machines that move information expressed as measurements. ANALOGUE MACHINES A simple example of a device that uses a measurement to handle information is a doorpost. Here the height of a child may be marked from year to year as he grows (Fig. 1). Or, suppose that we have a globe of the world and wish to find the shortest path between Chicago and Moscow. We may lay a piece of string on the globe, pull it tight between those points, and then measure the string on a scale to see about what distance it shows (Fig. 2). Machines that handle information as measurements of physical quantities are called _analogue_ machines, because the measurement is _analogous_ to, or like, the information. A common example of analogue machine is the _slide rule_. With this we calculate by noting the positions of ruled lines on strips that slide by each other. These strips are made of fine wood, or of plastic, or of steel, in such fashion that the ruled lines will hold true positions and not warp. If we space the rulings so that 1, 2, 3, 4, 5, 6 ··· are equally spaced, then the slide rule is useful for addition (Fig. 3). But if we space the rulings so that _powers_ (for example, powers of two—1, 2, 4, 8, 16, 32 ···) (Fig. 4) are equally spaced, we can do multiplication. The spacings are then according to the _logarithms_ of numbers (see Supplement 2). Multiplication is more troublesome than addition, and so more slide rules are made for multiplication than for addition. [Illustration: FIG. 1. Measurement by doorpost.] [Illustration: FIG. 2. Measurement by string.] [Illustration: FIG. 3. Slide Rule for adding.] [Illustration: FIG. 4. Slide Rule for multiplying.] During World War II, the aiming and firing of guns against hostile planes was done by machine. After sighting a plane, these machines automatically calculated how to direct fire against it. They were much better and faster than any man. These _fire-control instruments_ were analogue machines with steel and electrical parts built to fine tolerances. With care we can get accuracy of 1 part in 10,000 with analogue machines, but greater accuracy is very hard to get. PHYSICAL QUANTITIES Suppose that we wish to make an analogue machine. We need to represent information by a measurement of something. What should we select? What physical thing to be measured should we choose to put into the machine? Different amounts of this _physical quantity_ will match with different amounts of the measurement being expressed. In the case of the doorpost, the string, and the slide rule, the physical quantity is distance. In many fire-control instruments, the physical quantity is the _amount of turning of a shaft_ (Fig. 5). Many other physical quantities have from time to time been used in analogue machines, such as electrical measurements. The speedometer of an automobile tells distance traveled and speed. It is an analogue machine. It uses the amount of turning of a wheel, and some electrical properties. It handles information by means of measurements. The basic physical quantity that it measures is the amount of turning of a shaft. [Illustration: FIG. 5. Measurement by amount of turning of a shaft.] DIFFERENTIAL ANALYZER The biggest and cleverest mechanical brain of the analogue type which has yet been built is the _differential analyzer_ finished in 1942 at Massachusetts Institute of Technology in Cambridge, Mass. The fundamental physical quantity used in this machine is the amount of turning of a shaft. The name _analyzer_ means an apparatus or machine for analyzing or solving problems. It happens that the word “analyzer” has been used rather more often in connection with analogue machines, and so in many cases the word “analyzer” carries the meaning “analogue” as well. The word “differential” in the phrase “differential analyzer” refers to the main purpose of the machine: it is specially adapted for solving problems involving _differential equations_. Now what is a differential equation? DIFFERENTIAL EQUATIONS In order to explain what a differential equation is, we need to use certain ideas. These ideas are: _equation_; _formula_; _function_; _rate of change_; _interval_; _derivative_; and _integral_. In the next few paragraphs, we shall introduce these ideas briefly, with some explanation and examples. It is entirely possible for anyone to understand these ideas rather easily, by collecting true statements about them; no one should feel that because these ideas may be new they cannot be understood readily. PHYSICAL PROBLEMS In physics, chemistry, mechanics, and other sciences there are many problems in which the behavior of distance, of time, of speed, heat, volume, electrical current, weight, acceleration, pressure, and many other _physical quantities_ are related to each other. Examples of such problems are: [Illustration: FIG. 6. Paths of a shot from a gun, trajectories.] What are the various angles to which a gun should be raised in order that it may shoot various distances? (See Fig. 6.) (The paths of a shot from a gun are called _trajectories_.) If a plane flies in a direction always at the same angle from the north, how much farther will it travel than if it flew along the shortest path? (See Fig. 7.) (A path always at the same angle from the north is called a _loxodrome_, and a shortest path on a globe is called a _great circle_.) How should an engine be designed so that it will have the least vibration when it moves fast? In _physical problems_ like these, the answer is not a single number but a _formula_. What we want to do in any one of these problems is find a formula so that any one of the quantities may be calculated, given the behavior of the others. For example, here is a familiar problem in which the answer is a formula and not a number: [Illustration: FIG. 7. Paths of a flight.] [Illustration: FIG. 8. Room formulas.] How are the floor area of a room, its length, and its width related to each other? (See Fig. 8.) The answer is told in any one of three _equations_: (_floor area_) EQUALS (_length_) TIMES (_width_) (_length_) EQUALS (_floor area_) DIVIDED BY (_width_) (_width_) EQUALS (_floor area_) DIVIDED BY (_length_) The first equation shows that the floor area depends on the length of the room and also on the width of the room. So we say floor area is a _function_ of length and width. This particular function happens to be _product_, the result of multiplication. In other words, floor area is equal to the product of length and width. Now there is another kind of function called a _differential function_ or _derivative_. A _differential function_ or _derivative_ is an _instantaneous rate of change_. An instantaneous rate of change is the result of two steps: (1) finding a rate of change over an _interval_ and then (2) letting the interval become smaller and smaller indefinitely. For example, suppose that we have the problem: How are speed, distance, and time related to each other? One of the answers is: (_speed_) EQUALS THE INSTANTANEOUS RATE OF CHANGE OF (_distance_) WITH RESPECT TO (_time_) Or we can say, and it is just the same thing in other words: (_speed_) EQUALS THE DERIVATIVE OF (_distance_) WITH RESPECT TO (_time_) Now we can tell what a differential equation is. It is simply an equation in which a derivative occurs, such as the last example. Perhaps the commonest kind of equation in physical problems is the differential equation. SOLVING PHYSICAL PROBLEMS Now we were able to change the equation about floor area into other forms, if we wanted to find length or width instead of floor area. When we did this, we ran into the _inverse_ or opposite of multiplication: division. In the same way, we can change the equation about speed into other forms, if we want to find distance or time instead of speed. If we do this, we run into a new idea, the inverse or opposite of the derivative, called _integral_. The two new equations are: (_distance_) EQUALS THE INTEGRAL OF (_speed_) WITH RESPECT TO (_time_) (_time_) EQUALS THE INTEGRAL OF [ONE DIVIDED BY (_speed_)] WITH RESPECT TO (_distance_) These equations may also be called differential equations. An integral is the result of a process called _integrating_. To integrate speed and get distance is the result of three steps: (1) breaking up an interval of time into a large number of small bits, (2) adding up all the small distances that we get by taking each bit of time and multiplying by the speed which applied in that bit of time, and (3) letting the bits of time get smaller and smaller, and letting the number of them get larger and larger, indefinitely. In other words, (_total distance_) EQUALS THE SUM OF ALL THE SMALL (_distances_), EACH EQUAL TO: A BIT OF (_time_) MULTIPLIED BY THE (_speed_) APPLYING TO THAT BIT This is another way of saying as before, (_distance_) EQUALS THE INTEGRAL OF (_speed_) WITH RESPECT TO (_time_) To solve a differential equation, we almost always need to integrate one or more quantities. ORIGIN AND DEVELOPMENT OF THE DIFFERENTIAL ANALYZER For at least two centuries, solving differential equations to answer physical problems has been a main job for mathematicians. Mathematics is supposed to be logical, and perhaps you would think this would be easy. But mathematicians have been unable to solve a great many differential equations; only here and there, as if by accident, could they solve one. So they often wished for better methods in order to make the job easier. A British mathematician and physicist, William Thomson (Lord Kelvin), in 1879 suggested solving differential equations by a machine. He went further: he described mechanisms for integrating and other mathematical processes, and how these mechanisms could be connected together in a machine. No such machine was then built; engineering in those years was not equal to it. In 1923, a machine of this type for solving the differential equations of trajectories was proposed by L. Wainwright. In 1925, at Massachusetts Institute of Technology, the problem of a machine to solve differential equations was again being studied by Dr. Vannevar Bush and his associates. Dr. Bush experimented with mechanisms that would integrate, add, multiply, etc., and methods of connecting them together in a machine. A major part of the success of the machine depended on a device whereby a very small turning force would do a rather large amount of work. He developed a way in which the small turning force, about as small as a puff of breath, could be used to tighten a string around a drum already turning with a considerable force, and thus clutch the drum, bring in that force, and do the work that needed to be done. You may have watched a ship being loaded, seen a man coil a rope around a _winch_, and watched him swing a heavy load into the air by a slight pull on the rope (Fig. 9). If so, you have seen this same principle at work. The turning force (or _torque_) that pulls on the rope is greatly increased (or _amplified_) by such a mechanism, and so we call it a _torque amplifier_. [Illustration: FIG. 9. Increasing turning force; winch, or torque amplifier.] By 1930, Dr. Bush and his group had finished the first differential analyzer. It was entirely mechanical, having no electrical parts except the motors. It was so successful that a number of engineering schools and manufacturing businesses have since then built other machines of the Bush type. Each time, some improvements were made in accuracy and capacity for solving problems. But, if you changed from one problem to another on this type of machine, you had to do a lot of work with screwdrivers and wrenches. You had to undo old mechanical connections between shafts and set up new ones. Accordingly, in 1935, the men at MIT started designing a second differential analyzer. In this one you could make all the connections electrically. MIT finished its second differential analyzer in 1942, but the fact was not published during World War II, for the machine was put to work on important military problems. In fact, a rumor spread and was never denied that the machine was a white elephant and would not work. The machine was officially announced in October 1945. It was the most advanced and efficient differential analyzer ever built. We shall talk chiefly about it for the rest of this chapter. A good technical description of this machine is in a paper, “A New Type of Differential Analyzer,” by Vannevar Bush and Samuel H. Caldwell, published in the _Journal of the Franklin Institute_ for October 1945. GENERAL ORGANIZATION OF MIT DIFFERENTIAL ANALYZER NO. 2 A differential analyzer is basically made up of shafts that turn. When we set up the machine to solve a differential equation, we assign one shaft in the machine to each quantity referred to in the equation. It is the job of that shaft to keep track of that quantity. The total amount of turning of that shaft at any time while the problem is running measures the size of that quantity at that time. If the quantity decreases, the shaft turns in the opposite direction. For example, if we have speed, time, and distance in a differential equation, we label one shaft “speed,” another shaft “time,” and another shaft “distance.” If we wish, we may assign 10 turns of the “time” shaft to mean “one second,” 2 turns of the “distance” shaft to mean “one foot,” and 4 turns of the “speed” shaft to mean “one foot per second.” These are called _scale factors_. We could, however, use any other convenient units that we wished. By just looking at a shaft or a wheel, we can tell what part of a full turn it has made—a half, or a quarter, or some other part—but we cannot tell by looking how many full turns it has made. In the machine, therefore, there are mechanisms that record not only full turns but also tenths of turns. These are called _counters_. We can connect a counter to any shaft. When we want to know some quantity that a shaft and counter are keeping track of, we read the counting mechanism. The second differential analyzer, which MIT finished in 1942, went a step further than any previous one. In this machine, a varying number can be expressed either (1) mechanically as the amount of turning of a shaft, or (2) electrically as the amount of two _voltages_ in a pair of wires. The MIT men did this by means of a mechanism called an _angle-indicator_. Angle indicators have essentially three parts: a _transmitter_, a _receiver_, and switches. The transmitter (Fig. 10) can sense the exact amount that a shaft has turned and give out a voltage in each of two wires which tells exactly how much the shaft has turned (Fig. 11). The receiving device (Fig. 12), which has a motor, can take in the voltages in the two wires and drive a second shaft, making it turn in step with the first shaft. By means of the switchboard (Fig. 13), the two wires from the transmitter of any angle-indicator can lead anywhere in the machine and be connected to the receiver of any other angle indicator. [Illustration: FIG. 10. Scheme of angle-indicator transmitter.] [Illustration: FIG. 11. Indication of angle.] [Illustration: FIG. 12. Scheme of angle-indicator receiver.] In a differential analyzer, we can connect the shafts together in many different ways. For example, suppose that we want one shaft _b_ to turn twice as much as another shaft _a_. For this to happen we must have a mechanism that will connect shaft _a_ to shaft _b_ and make shaft _b_ turn twice as much as shaft _a_. We can draw the scheme of this mechanism in Fig. 14: a box, standing for any kind of simple or complicated mechanism; a line going into it, standing for input of the quantity _a_; a line going out of it, standing for output of the quantity _b_; and a statement saying that _b_ equals 2_a_. [Illustration: FIG. 13. Switchboard.] One mechanism that will make shaft _b_ turn twice as much as shaft _a_ is a _pair of gears_ such that: (1) they mesh together and (2) the gear on shaft _a_ has twice as many teeth as the gear on shaft _b_ (Fig. 15). On the mechanical differential analyzer that MIT finished in 1930, a pair of gears was the mechanism actually used for doubling. To make one shaft turn twice as much as another by this device, we would: go over to the machine with a screwdriver; pick out from a box two gears, one with twice as many teeth as the other; slide them onto the shafts that are to be connected; make the gears mesh together; and screw them tight on their shafts. [Illustration: FIG. 14. Scheme of a doubling mechanism.] [Illustration: FIG. 15. Example of a doubling mechanism.] On the MIT differential analyzer No. 2, however, we are better off. A much more convenient device for doubling is used. We make use of: a _gearbox_ in whichthere are two shafts that may be geared so that one turns twice as much as the other, and two angle-indicator transmitters and receivers. Looking at the drawing (Fig. 16), we can see that: shaft _a_ drives shaft _c_ to turn in step, shaft _c_ drives shaft _d_ to turn twice as much, and shaft _d_ drives shaft _b_ to turn in step. Here we can accomplish doubling by closing the pairs of switches that connect to the gearbox shafts. [Illustration: Angle indicators: T, transmitters, and R, receivers FIG. 16. Another example of a doubling mechanism.] Above, we have talked about a mechanism with gears that would multiply the amount of turning by the _constant ratio_ 2. But, of course, in a calculation, any ratio, say 7.65, 3.142, ···, might be needed, not only 2. In order to handle various constant ratios, gearboxes of two kinds are in differential analyzer No. 2. The first kind is a _one-digit gearbox_. It can be set to give any of 10 ratios, 0.1, 0.2, 0.3, ···, 1.0. The second kind is a _four-digit gearbox_. It can be set to give any one of more than 11 thousand ratios, 0.0000, 0.0001, 0.0002, ···, 1.1109, 1.1110. We can thus multiply by constant ratios. Adders We come now to a new mechanism, whose purpose is to add or subtract the amount of turning of two shafts. It is called an _adder_. The scheme of it is shown in Fig. 17: an input shaft with amount of turning _a_, another input shaft with amount of turning _b_, and an output shaft with amount of turning _a_ + _b_. The adder essentially is another kind of gearbox, called a _differential gear assembly_. This name is confusing: the word “differential” here has nothing to do with the word “differential” in “differential analyzer.” This mechanism is very closely related to the “differential” in the rear axle of a motor car, which distributes a driving thrust from the motor to the two rear wheels of the car. [Illustration: FIG. 17. Scheme of an adder mechanism.] [Illustration: FIG. 18. Example of an adding mechanism (differential gear assembly).] A type of differential gear assembly that will add is shown in Fig. 18. This is a set of 5 gears _A_ to _E_. The 2 gears _A_ and _B_ are input gears. The amount of their turning is _a_ and _b_, respectively. They both mesh with a third gear, _C_, free to turn, but the axis of _C_ is fastened to the inside rim of a fourth, larger gear, _D_. Thus _D_ is driven, and the amount of its turning is (_a_ + _b_)/2. This gear meshes with a gear _E_ with half the number of teeth, and so the amount of turning of _E_ is _a_ + _b_. We can subtract the turning of one shaft from the turning of another simply by turning one of the input shafts in the opposite direction. Integrators Another mechanism in a differential analyzer, and the one that makes it worth while to build the machine, is called an _integrator_. This mechanism carries out the process of integrating, of adding up a very large number of small changing quantities. Figure 19 shows what an integrator is. It has three chief parts: a _disc_, a little _wheel_, and a _screw_. The round disc turns horizontally on its vertical shaft. The wheel rests on the disc and turns vertically on its horizontal shaft. The screw goes through the support of the disc; when the screw turns, it changes the distance between the edge of the wheel and the center of the disc. [Illustration: FIG. 19. Mechanism of integrator.] Now let us watch this mechanism move. If the disc turns a little bit, the wheel pressing on it must turn a little bit. If the screw turns a small amount, the distance between the edge of the wheel and the center of the disc changes. The amount that the wheel turns is doubled if its distance from the center of the disc is doubled, and halved if that distance is halved. So we see that: (_the total amount that the wheel turns_) EQUALS THE SUM OF ALL THE SMALL (_amounts of turning_), EACH EQUAL TO: A BIT OF (_disc turning_) MULTIPLIED BY THE (_distance from the center of the disc to the edge of the wheel_) APPLYING TO THAT BIT If we look back at our discussion of integrating (p. 72), we see that the capital words here are just the same as those used there. Thus we have a mechanism that expresses integration: (_the total amount that the wheel turns_) EQUALS THE INTEGRAL OF (_the distance from the center of the disc to the wheel_) WITH RESPECT TO (_the amount that the disc turns_) The scheme of this mechanism is shown in Fig. 20. For example, suppose that the screw measures the speed at which a car travels and that the disc measures time. The wheel, consequently, will measure distance traveled by the car. The mechanism INTEGRATES speed with respect to time and gives distance. [Illustration: FIG. 20. Scheme of integrator.] This mechanism is the device that Lord Kelvin talked about in 1879 and that Dr. Bush made practical in 1925. The mechanical difficulty is to make the friction between the disc and the wheel turn the wheel with enough force to do other work. In the second differential analyzer, the angle indicator set on the shaft of the wheel solves the problem very neatly. [Illustration: FIG. 21. Graph of air resistance coefficient.] Function Tables The behavior of some physical quantities can be described only by a series of numbers or a graphic curve. For example, the _resistance_ or _drag_ of the air against a passing object is related to the speed of the object in a rather complicated way. Part of the relation is called the _drag coefficient_ or _resistance coefficient_; a rough graph of this is shown in Fig. 21. This graph shows several interesting facts: (1) when the object is still, there is no air resistance; (2) as it travels faster and faster, air resistance rapidly increases; (3) when the object travels with the speed of sound, resistance is very great and increases enormously; (4) but, when the object starts traveling with a speed about 20 per cent faster than sound, the drag coefficient begins to decrease. This drawing or _graph_ shows in part how air resistance depends on speed of object; in other words, it shows the drag coefficient as a _function_ of speed (see Supplement 2). [Illustration: FIG. 22. Pointer following graph.] Now we need a way of putting any function we wish into a differential analyzer. To do this, we use a mechanism called a _function table_. We draw a careful graph of the function according to the scale we wish to use, and we set the graph on the outside of a large drum (Fig. 22). For example, we can put the resistance coefficient graph on the drum; the speed (or _independent variable_) goes around the drum, and the resistance coefficient (or _dependent variable_) goes along the drum. The machine slowly turns the drum, as may be called for by the problem. A girl sits at the function table and watches, turning a handwheel that keeps the sighting circle of a pointer right over the graph. The turning of the handwheel puts the graphed function into the machine. Instead of employing a person, we can make one side of the graph black, leaving the other side white, and put in a _phototube_ (an electronic tube sensitive to amount of light) that will steer from pure black or pure white to half and half (see Fig. 23). We do not need many function tables to put in information, because we can often use integrators in neat combinations to avoid them. We shall say more about this possibility later. We can also use a function table to put out information and to draw a graph. To do so, we disconnect the handwheel; we connect the shaft of the handwheel to the shaft that records the function we are interested in; we take out the pointer and put in a pen; and we put a blank sheet of graph paper around the drum. [Illustration: FIG. 23. Phototube following graph.] We have now described the main parts of the second MIT differential analyzer. They are the parts that handle numbers. We can now tell the capacity of the differential analyzer by telling the number of main parts that it holds: Shafts About 130 One-digit gearboxes 12 Four-digit gearboxes 16 Adders About 16 Integrators 18 Function tables 3 On a simpler level, we can say that the machine holds these physical parts: Miles of wire About 200 Relays About 3000 Motors About 150 Electronic tubes About 2000 INSTRUCTING THE MIT DIFFERENTIAL ANALYZER NO. 2 Besides the function tables for putting information into the machine, there are three mechanisms that read punched paper tape. The three tapes are called the _A tape_, the _B tape_, and the _C tape_. From these tapes the machine is set up to solve a problem. Suppose that we have decided how the machine is to solve a problem. Suppose that we know the number of integrators, adders, gearboxes, etc., that must be used, and know how their inputs and outputs are to be connected. To carry out the solution, we now have to put the instructions and numbers into the machine. The _A_ tape contains instructions for connecting shafts in the machine. Each instruction connects a certain output of one type of mechanism (adder, etc.) to a certain input of another type of mechanism. When the machine reads an instruction on this tape, it connects electrically the transmitting angle-indicator of an output shaft to the receiving angle-indicator of another input shaft. Now the connecting part of the differential analyzer behaves as if it were very intelligent: it assigns an adder or an integrator or a gearbox, etc., to a new problem only if that mechanism is not busy. For example, if a problem tape calls for adder 3 (in the list belonging to the problem), the machine will assign the first adder that is not busy, perhaps adder 14 (in the machine), to do the work. Each time that adder 3 (in the problem list) is called for in the _A_ tape, the machine remembers that adder 14 was chosen and assigns it over again. This ability, of course, is very useful. The _B_ tape contains the ratios at which the gearboxes are to be set. For example, suppose that we want gearbox 4 (in the problem list) to change its input by the ratio of 0.2573. The machine, after reading the _A_ tape, has assigned gearbox 11 (in the machine list). Then, when the machine reads the _B_ tape, it sets the ratio in gearbox 11 to 0.2573. The answer to a differential equation is different for different starting conditions. For example, when we know speed and time and wish to find distance traveled and where we have arrived, we must know the point at which we started. We therefore need to arrange the machine so that we can put in different starting conditions (or different _initial conditions_, as the mathematician calls them). The _C_ tape puts the initial conditions into the machine. For example, reading the _C_ tape for the problem, the machine finds that 3000 should, at the start of the problem, stand in counter 4. The machine then reads the number at which counter 4 actually stands, say 6728.3. It subtracts the two numbers and remembers the difference, -3728.3. And whenever the machine reads that counter later, finding, say, 9468.4 in it, first the 3728.3 is subtracted, and then the answer 5740.1 is printed. ANSWERS Information may come out of the machine in either one of two ways: in printed numbers or in a graph. In fact, the same quantity may come out of the machine in both ways at the same time. To obtain a graph, we change a function table from input to output, put a pen on it, and have it draw the graph. The machine has 3 electric typewriters. The machine will take numerical information out of the counters at high speed even while they are turning, and it will put the information into relays. Then it will read from the relays into the typewriter keys one by one while they type from left to right across the page. HOW THE DIFFERENTIAL ANALYZER CALCULATES Up to this point in this chapter, the author has tried to tell the story of the differential analyzer in plain words. But for reading this section, a little knowledge of calculus is necessary. (See also Supplement 2.) If you wish, skip this section, and go on to the next one. We have described how varying quantities, or _variables_, are operated on in the machine in one way or another: adding, subtracting, multiplying by a constant, referring to a table, and integrating. What do we do if we wish to multiply 2 variables together? A neat trick is to use the formula: _xy_ = ⌠_x dy_ + ⌠_y dx_ ⌡ ⌡ To multiply in this way requires 2 integrators and 1 adder. The connections that are made between them are as follows: Shaft _x_ To Integrator 1, Screw Shaft _x_ To Integrator 2, Disc Shaft _y_ To Integrator 1, Disc Shaft _y_ To Integrator 2, Screw Integrator 1, Wheel To Adder 1, Input 1 Integrator 2, Wheel To Adder 1, Input 2 Adder 1, Output To Shaft expressing _xy_ A product of 2 variables _under the integral sign_ can be obtained a little more easily, because of the curious powers of the differential analyzer. Thus, if it is desired to obtain ∫_xy dt_, we can use the formula: ┌ ┐ ⌠ ⌠ │ ⌠ │ │_xy dt_ = │_x d_│ │ _y dt_ │ ⌡ ⌡ │ ⌡ │ └ ┘ and this operation does not require an adder. The connections are as follows: Shaft _t_ To Integrator 1, Disc Shaft _y_ To Integrator 1, Screw Integrator 1, Wheel To Integrator 2, Disc Shaft _x_ To Integrator 2, Screw Integrator 2, Wheel To Shaft expressing ∫_xy dt_ In order to get the quotient of 2 variables, _x_/_y_, we can use some more tricks. First, the _reciprocal_ 1/_y_ can be obtained by using the two _simultaneous equations_: ⌠ 1 ⌠ 1 │ ———— _dy_ = log _y_, │ - ———— _d_(log _y_) = _y_ ⌡ _y_ ⌡ _y_ The connections are as follows: Shaft _y_ To Integrator 1, Disc AND TO Integrator 2, Wheel Shaft log _y_ To Integrator 1, Wheel AND TO Integrator 2, Disc Shaft 1/_y_ To Integrator 1, Screw, AND NEGATIVELY TO Integrator 2, Screw In order to get _x_/_y_, we can then multiply _x_ by 1/_y_. We see that this setup gives us log _y_ for nothing, that is, without needing more integrators or other equipment. Clearly, other tricks like this will give sin _x_, cos _x_, _eˣ_, _x²_, and other functions that satisfy simple differential equations. An integral of a reciprocal can be obtained even more directly. Suppose that ⌠ 1 _y_ = │ ————— _dt_ ⌡ _x_ 1 Then _Dₜy_ = —————, _D{_y} t_ = _x_, _x_ ⌠ and _t_ = │_x dy_ ⌡ The connections therefore are: Shaft _t_ To Integrator, Wheel Shaft _x_ To Integrator, Screw Shaft _y_ To Integrator, Disc The light wheel then drives the heavy disc. Clearly only the angle-indicator device makes this possible at all. Naturally, the closer the wheel gets to the center of the disc, that is, _x_ approaching zero, the greater the strain on the mechanism, and the more likely the result is to be off. Mathematically, of course, the limit of 1/_x_ as _x_ approaches zero equals infinity, and this gives trouble in the machine. There is no standard mathematical method for solving any differential equation. But the machine provides a standard direct method for solving all differential equations with only one independent variable. First: assign a shaft for each _term_ that appears in the equation. For example, the highest derivative that appears and the independent variable are both assigned shafts. The integral of the highest derivative is easily obtained, and the integral of that integral, etc. Second: connect the shafts so that all the mathematical relations are expressed. Both _explicit_ and _implicit_ equations may be expressed. Third: for any shaft there must be just one _drive_, or source of torque. A shaft may, however, drive more than one other shaft. Fourth: choose _scale factors_ so that the limits of the machine are not exceeded yet at the same time are well used. For example, the most that an integrator or a function table can move is 1 or 2 feet. Also, the number of full turns made by a shaft in representing its variable should be large, often between 1000 and 10,000. Of course, as with all these large machines, anyone would need some months of actual practice before he could put on a problem and get an answer efficiently. AN APPRAISAL OF THE MACHINE The second MIT differential analyzer is probably the best machine ever built for solving most differential equations. It regularly has an accuracy of 1 part in 10,000. This is enough for most engineering problems. If greater accuracy is needed, the second differential analyzer cannot provide it. Once in a while the machine can reach an accuracy of 1 part in 50,000; but, to balance this, it is sometimes less accurate than 1 part in 10,000. The MIT differential analyzer No. 2 can find answers to problems very quickly. The time for setting up a problem to be run on the machine ranges from 5 to 15 minutes. The time for preparing the tapes that set up the problem is, of course, longer; but the punch for preparing the tape is a separate machine and does not delay the differential analyzer. The time for the machine to produce a single solution to a problem ranges usually from 3 minutes to a half-hour. It is easy to put on a problem, run a few solutions, take the problem off, study the results, change a few numbers, and then put the problem back on again. This virtue is a great help in a search in a new field. While the study is going on, time is not wasted, for the machine can be busy with a different problem. Running a problem a second time is a good check on the reliability of an answer. For, when the problem is run the second time, we can arrange that the machine will route the problem to other mechanisms. The machine has a control panel. Here the operator watching the machine can tell what units are doing what parts of what problems. If a unit gives trouble or needs to be inspected, the clerk can throw a “busy” switch. Then the machine cannot choose that unit for work to be done. The machine contains many protecting signals and alarms. It is idle for repairs less than 5 per cent of the time. It is not easy to determine the total cost of the machine, for it was partially financed by several large gifts. Also, much of the labor was done by graduate students in return for the instruction that they gained. The actual out-of-pocket cost was about $125,000. If the machine were to be built by industry, the cost would likely be more than 4 times as much. A simple differential analyzer, however, can be cheap. Small scale differential analyzers have been built for less than $1000; their accuracy has been about 1 part in 100. There are many things that this machine cannot do; it was not built to do them. (1) It cannot choose methods of solution. (2) It cannot perform steps in solving a problem that depend on results as they are found. (3) It cannot solve differential equations containing two or more independent variables. Such equations are called _partial differential equations_; they appear in connection with the flow of heat or air or electricity in 2 or 3 dimensions, and elsewhere. (4) It cannot solve problems requiring 6 or more digits of accuracy. (5) The machine, while running, can store numbers only for an instant, since it operates on the principle of smoothly changing quantities; however, when the machine stops, the number last held by each device is permanently stored. None of these comments, however, are criticisms of the machine. Instead they show avenues of development for future machines. As was said before, for solving most differential equations, this machine has no equal to date. The range of problems which any differential analyzer can do depends mostly on the number of its integrators. The second differential analyzer has 18 and provides for expansion to 30. The machine is constructed, also, so that it can be operated in 3 independent sections, each working to solve a different problem. The differential analyzer can operate unattended. After it has been set up and the first few results examined, it can be left alone to grind out large blocks of answers. An interesting example of the experimental use of a differential analyzer in a commercial business is the following: In Great Britain, R. E. Beard of the Pearl Assurance Company built a differential analyzer with 6 integrators. He applied this machine to compute to 3 figures certain insurance values known as _continuous annuities_ and _continuous contingent insurances_. He has described the machine and the application he made in a paper published in the _Journal of the Institute of Actuaries_, Vol. 71, 1942, pp. 193-227. Chapter 6 ACCURACY TO 23 DIGITS: HARVARD’S IBM AUTOMATIC SEQUENCE-CONTROLLED CALCULATOR One of the first giant brains to be finished was the machine in the Computation Laboratory at Harvard University called the _IBM Automatic Sequence-Controlled Calculator_. This great mechanical brain started work in April 1944 and has been running 24 hours a day almost all the time ever since. It has produced quantities of information for the United States Navy. Although many problems that have been placed on it have been classified by the Navy as confidential, the machine itself is fully public. The way it was working on Sept. 1, 1945, has been thoroughly described in a 540-page book published in 1946, Volume I of the Annals of the Harvard Computation Laboratory, entitled _Manual of Operation of the Automatic Sequence-Controlled Calculator_. Since then the machine has been improved in many ways. This machine does thousands of calculating steps, one after another, according to a scheme fixed ahead of time. This property is what gives the machine its name: _automatic_, since the individual operations are automatic, once the punched tape fixing the chain of operations has been put on the machine, and _sequence-controlled_, since control over the sequence of its operations has been built into the machine. ORIGIN AND DEVELOPMENT More than a hundred years ago, an English mathematician and actuary, Charles Babbage (1792-1871), designed a machine—or _engine_ as he called it—that would carry out the sequences of mathematical operations. In the 1830’s he received a government grant to build an _analytical engine_ whereby long chains of calculations could be performed. But he was unsuccessful, because the refined physical devices necessary for quantities of digital calculation were not yet developed. Only in the 1930’s did these physical devices become sufficiently versatile and reliable for a calculator of hundreds of thousands of parts to be successful. The Automatic Sequence-Controlled Calculator at Harvard was largely the concept of Professor Howard H. Aiken of Harvard. It was built through a partnership of efforts, ideas, and engineering between him and the International Business Machines Corporation, in the years 1937 to 1944. The calculator was a gift from IBM to Harvard University. Some very useful additional control units, named the _Subsidiary Sequence Mechanism_, were built at the Harvard Computation Laboratory in 1947 and joined to the machine. [Illustration: FIG. 1. Scheme of Harvard IBM Automatic Sequence-Controlled Calculator.] GENERAL ORGANIZATION The machine (see Fig. 1) is about 50 feet long, 8 feet high, and about 2 feet wide. It consists of 22 panels; 17 of them are set in a straight line, and the last 5 are at the rear of the machine. In the scheme of the machine shown in Fig. 1, the details you would see in a photograph have been left out. Instead you see the sections of the machine that are important because of what they do: _input_, _memory_, _control_, and _output_. Why do we not see a section labeled “computer”? Because in this mechanical brain the computing part of the machine is closely joined to the memory: every storage register can add and subtract. We shall soon discuss these sections of the machine more fully. PHYSICAL DEVICES Now in order for any brain to work, _physical devices_ must be used. For example, in the human body, a nerve is the physical device that carries information from one part of the body to another. In the Harvard machine, an insulated _wire_ is the physical device that carries information from one part of the machine to another. One side of every panel in the Harvard machine is heavily laden with a great network of wires. Between the panels, you can see in many places cables as thick as your arm and containing hundreds of wires. More than 500 miles of wire are used. The physical devices in the Harvard machine are numerous, as we would expect. It is perhaps not surprising that this machine has more than 760,000 parts. But, curiously enough, there are only 7 main kinds of physical devices in the major part of the machine. They are: wire, _two-position switches_, _two-position relays_ (see Chapter 2), _ten-position switches_, _ten-position relays_, _buttons_, and _cam contacts_ (see below). These are the devices that handle information in the form of electrical impulses. They can be combined by electrical circuits in a great variety of ways. There are, of course, other kinds of physical devices that are important, but they are not numerous, and they have rather simple duties. Looking at the machine, you can see three examples easily. Physical devices of the first kind convert punched holes into electrical impulses: 2 _card feeds_, 4 _tape feeds_. Those of the second kind convert electrical impulses into punched holes: 1 _card punch_, 1 _tape punch_. Those of the third kind convert electrical impulses into printed characters: 2 _electric typewriters_. We can think of a fourth kind of physical device that would be a help, but, at present writing, it does not yet exist: a device that converts printed characters into electrical impulses. The Harvard machine, of course, is complicated. But it is complicated because of the variety of ways in which relatively simple devices have been connected together to make a machine that thinks. Switches A _two-position switch_ (see Fig. 2) turned by hand connects a wire to either one of 2 others. These 2 positions may stand for “yes” and “no,” 0 and 1, etc. There are many two-position switches in the machine. A _ten-position switch_ or _dial switch_ (see Fig. 3) turned by hand connects the wire running into the center of the switch with a wire at any one of ten positions 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 around the edge. There are over 1400 dial switches in the machine. How does turning the pointer on the top of the dial make connection between the center wire and the edge wire? Under the face of the dial is the part that works, a short rod of metal fastened to the pointer (shown with dashes in Fig. 3). When the pointer turns, this rod also turns, making the desired connection. [Illustration: FIG. 2. Two-position switch.] [Illustration: FIG. 3. Dial switch.] Relays _Two-position relays_—more often called just _relays_ (see Chapter 2)—do the automatic routing of the electrical impulses that cause computing to take place. Each relay may take 2 positions, open or closed, and these positions may stand for 0 and 1. There are more than 3000 relays in the Harvard machine. A magnet pulling one way and a spring pulling the other way are sufficient in an ordinary relay to give 2 positions, “on” and “off,” “yes” and “no,” 0 and 1. But how do we make a relay that can hold any one of 10 positions? Figure 4 shows one scheme for a _ten-position relay_. The _arm_ can take any one of 10 positions, connecting the contact _Common_ to any one of the contacts O, 1, 2, 3, 4, 5, 6, 7, 8, and 9 so that current can flow. The _gear_ turns all the time. When an impulse comes in on the _Pickup_ line, the _clutch_ connects the arm to the gear. When an impulse comes in on the _Drop-out_ line, the clutch disconnects the arm from the gear. For example, suppose that the ten-position relay is stopped at contact 2, as shown. Suppose that we now pick up the relay, hold it just long enough to turn 3 steps, and then drop it out. The relay will now rest at contact 5. [Illustration: FIG. 4. Scheme of a ten-position relay, or counter position.] [Illustration: FIG. 5. Scheme of a counter wheel.] In the Harvard machine, the ten-position relays, much like the scheme shown, do the same work as _counter wheels_ (Fig. 5) in an ordinary desk calculating machine, and so they are often spoken of as _counter positions_ in the Harvard machine. They are very useful in the machine not only because they express the 10 decimal digits 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 but also because adding and subtracting numbers is accomplished by turning them through the proper number of steps. In fact, an additional impulse is provided when the counter position turns from 9 to 0, for purposes of carry. A group of 24 counter positions makes up each _storage counter_—or _storage register_—in the machine. There are 2200 of these counter positions. Each is connected to a continuously running gear on a small shaft (Fig. 6). All these shafts are connected by other gears and shafts to a main drive shaft, and they are driven by a 5-horsepower motor at the back of the machine. When a counter position is supposed to step, a clutch connects the drive to the running gear, and the counter position steps. When the counter position is supposed to stay unchanged, the clutch is disconnected and the driving gear runs free. In fact, when you first approach the Harvard machine, about the first thing you are aware of is the running of these gears and the intermittent whirring and clicking of the counter positions as they step. The machine gives a fine impression of being busy! [Illustration: FIG. 6. Scheme of counter 16.] Timing Contacts A _button_ (see Fig. 7) is a device for closing an electric circuit when and only when you push it. A simple example is the button for ringing a bell: you push the button, a circuit is closed, and something happens. When you let go, the circuit is opened. The Harvard machine has a button for starting, a button for stopping, and many others. [Illustration: FIG. 7. Button.] [Illustration: FIG. 8. Cam, with 5 lobes and contact.] A _cam contact_ (see Fig. 8) is an automatic device for closing an electric circuit for just a short interval of time. When the lobes on the cam strike the contact, it closes and current flows. When the lobes have gone by, the spring pushes open the contact, and no current flows. Just as a two-position relay is the automatic equivalent of a two-position switch, and a ten-position relay is the automatic equivalent of a ten-position switch, so a cam contact is the automatic equivalent of a button. All the cams in the machine have 20 pockets where small round metal lobes may or may not be inserted. Each cam makes a full turn once in ³/₁₀ of a second and is in time with all the others. Thus we can time all the electrical circuits in the machine in units of ³/₂₀₀ of a second. NUMBERS Numbers in the machine regularly consist of 23 decimal digits. The 24th numerical position at the left in any register contains only 0 for a positive number and only 9 for a negative number. _Nines complements_ (see Supplement 2) are used for negative numbers. For example,-00284 is represented as 999715, supposing that we had 5-digit numbers instead of 23-digit numbers. The sum of two nines complements is automatically corrected so that it is still a correct nines complement. The device that accomplishes this is called _end-around-carry_ (see Supplement 2). The decimal point is fixed for each problem; in other words, in any problem, the decimal point is consistently kept in one place, usually between the 15th and 16th decimal columns from the right. HOW INFORMATION GOES INTO THE MACHINE Numerical information may go into the machine in any one of 3 ways: (1) by regular IBM punch cards, using standard IBM card feeds (panel 16); (2) by hand-set dial switches (panels 1, 2); and (3) by long loops of punched tape placed on the value tape feeds (panels 12 to 14). Three sets of 24 columns each punched on a regular IBM punch card can be used to send 3 numbers and their signs into the machine in one machine cycle. This is the fastest way for giving numbers to the machine, but the most limited; for the cards must be referred to in order and can be referred to automatically only once. Also, there is the risk that they may be out of order. A card may be passed through the machine without reading; this saves some sorting in preparing cards for the machine. Machines for preparing the cards are regular IBM key punches, and machines for sorting them after preparation are regular IBM card sorters. In panels 1 and 2 there are 60 registers by which unchanging numbers like 1, or 3.14159265···, or 7.65 may be put into the machine. These are called the _constant registers_. Each constant register consists of 24 dial switches and contains 23 digits and a sign, 0 if positive and 9 if negative. Whenever the mathematician says a certain constant is needed for a problem, the operator of the machine walks over to these panels, and, while the machine is turned off, sets the dial switches for the number, one by one, by hand. If we need 40 constants of 10 digits each for a problem, then the operator sets 400 dial switches by hand and makes certain that the remaining 14 switches in each of the 40 constant registers used are either at 0 or 9, depending on the sign of the number. Only then can he return to start the machine. [Illustration: FIG. 9. Value tape code.] The third means by which numerical information can be put into the machine is the _value tape feeds_, in panels 12, 13, and 14. Here the machine can consult tables of numbers. The numbers are punched on paper tape 24 holes wide, made of punch-card stock. Tapes for the value tape feeds may be prepared by hand or by the machine itself using punch cards or machine calculation. The tapes use equally spaced _arguments_ (see Supplement 2). The tape punch changes the decimal digits in its keyboard into the following punching code (see Fig. 9): 0 0000 5 1100 1 1000 6 1010 2 0100 7 1001 3 0010 8 0110 4 0001 9 0101 Here the 1 denotes a punched hole and 0 no punched hole, and the 4 columns from left to right of the code correspond to 4 rows of the paper tape from bottom to top. To make sure the value tape is correct, the machine itself can read the value tape and check it mathematically or compare it with punch-card values. HOW INFORMATION COMES OUT OF THE MACHINE Information comes out of the machine in any one of three ways: (1) by punching on IBM cards with a regular IBM card punch that is built into the machine (panel 17), (2) by typing on paper sheets with electric typewriters (panels 16 and 17), and (3) by punching paper tape 24 holes wide of the same kind as is fed into the machine. Usually, one of the electric typewriters is used to print a result for a visual check and to print it before the machine makes a specified check of the value. Then, about 10 seconds later, after the result has been checked as specified in the machine, the checked result is printed by the second typewriter. In the second typewriter, a special one-use carbon ribbon of paper is used to produce copy for publication by a photographic process. The card punch writes a number more rapidly than an electric typewriter. This extra speed is sometimes very useful. However, the punch’s chief purpose is to record intermediate results on punch cards. Then, if there is a machine failure, and if the problem has been well organized, the problem may be run over from these intermediate results, instead of requiring a return to the original starting information. The tape punch used for preparing tape by hand can also be operated by cable from the machine. HOW INFORMATION IS HANDLED IN THE MACHINE The machine is a mechanical brain. So, between taking in information and putting out information, the machine does some “thinking.” It does this thinking according to instructions. The instructions go into the machine as: (1) the setting of switches, or (2) the pressing of buttons, or (3) the wiring of plugboards, or (4) feeding in tape punched with holes. The instructions are remembered in the machine in these 4 ways, and we can call these sets of devices the control of the machine. To illustrate: One of the buttons pressed for every problem is the Start Key: when you press it, the machine starts to work on the problem. One of the switches with which you give instructions is a switch that turns electric typewriter 1 on or off. One of the plugboards contains some hubs by which you can tell the machine how many figures to choose in the quotient when dividing, for clearly you do not need a quotient of 23 figures every time the machine divides. You can have 5 choices in any one problem; you can specify them by plugging, and you can call for any one of 5 choices of quotient size from time to time during the problem. In many cases, when we wish the machine to do the same thing for all of a single problem and do it whenever the occasion arises, we can put the instruction into the wiring of a plugboard. We use plugboard wiring, for example, in fixing the decimal point in multiplication, so that the product will read out properly, and in guiding the operation of the typewriters, so that printing will take place in the columns where we want it. Sequence of Steps The most important part of the control of the machine is the _sequence-tape feed_ and its _sequence-control tape_. These tell the machine a great part of what operations are to be performed. [Illustration: FIG. 10. Sequence-control tape code.] At the end of the room where the machine is, there is the special tape punch mentioned above. It holds a big spool of card stock that is thin, flexible, smooth, and tough. With one keyboard we may prepare value tape. With another keyboard we prepare the sequence-control tape. The tape (see Fig. 10) contains places for 24 round punched holes in each row. Some and only some of these holes are punched. Each row of punched holes is equivalent to an instruction to the machine and is called a _line of coding_ or _coding line_. In general, the instruction has the form: Take a number out of Register _A_; put the number into Register _B_; and perform operation _C_. The first group of 8 holes at the left is called the _A field_ or the _out-field_. Here we tell the machine where a number is to be taken from. The middle group of 8 holes is called the _B field_ or the _in-field_. Here we tell the machine where a number is to be put. The last group of 8 holes is called the _C field_ or the _miscellaneous field_. Here we tell the machine part or all of the operation that is to be performed. To illustrate (see Fig. 10), we have holes 3, 2, 1 punched in the _A_ field, holes 3, 2 punched in the _B_ field, and hole 7 punched in the _C_ field. Now 321 is the _code_—or machine language, or machine call number—for storage counter 7; 32 is the code for storage counter 6; and 7 in the _C_ field is the code (in this case, and generally) for “Add, and read the next line of coding.” So, if we punch out this line of coding and put the tape on the machine, we tell the machine to read the number in counter 7, add it into counter 6, and proceed to the next line of coding and read that. The holes in each group of 8 holes from left to right are numbered: 8, 7, 6, 5, 4, 3, 2, 1. The code 631, for example, means that holes 6, 3, 1 are punched and that no holes are punched at 8, 7, 5, 4, 2. Since it is more natural, the code is read from left to right, or 631, instead of from right to left in the sequence 136. The devices in the machine have _in-codes_, used in the in-field, and _out-codes_, used in the out-field. For each of the 72 regular storage counters, the in-code and the out-code are the same. The first 8 storage counters have the codes 1, 2, 21, 3, 31, 32, 321, 4, 41; the last 2 storage counters, the 71st and the 72nd, have the codes 7321, 74. The constant registers—often called _constant switches_, or just _switches_—naturally have only out-codes, since numbers can be entered into the constant registers only by setting dial switches by hand. The first 8 constant registers have the out-codes 741, 742, 7421, 743, 7431, 7432, 74321, 75, and the 59th and 60th constant registers have the out-codes 821, 83. Transferring, Adding, and Clearing Each storage counter has the property that any number transferred into it is added into it. For example, the instruction Take the number in switch 741; transfer it into storage register 321 is coded: 741, 321, 7 The 7 in the third column is an instruction to the sequence-tape feed to turn up to the next coding line and read it. If any number is already stored in register 321, the content of 741 will be added to it, and the total will then be stored in 321. Resetting or clearing a regular storage register is accomplished by a coding that is a departure from the usual scheme of “out” and “in.” The instruction Clear register 321; read the next coding line is coded: 321, 321, 7 Similarly, you can clear any other regular storage register if you repeat its code in the out-and in-fields. However, a few of the storage registers in the machine have special reset codes, and these may occur in any of the three fields _A_, _B_, _C_. As the result of a recent modification of the machine, you can easily double the number in any storage register. For example, the instruction Double the number in register 321; read the next coding line is coded: 321, 321, 743 Subtracting If the number in switch 741 is to be subtracted from the number in storage counter 321, the instruction is changed into: Take the negative of the number in switch 741; transfer it into storage register 321; read the next line of coding The coding line becomes: 741, 321, 732 By putting 32 in the _C_ field, we cause the number in switch 741 to be subtracted from whatever number is in register 321. We have 2 more choices in adding and subtracting. The value of the number without regard to sign—in other words, its _absolute value_ (see Supplement 2)—may be added or subtracted. The instruction Add the absolute value of is expressed by a _C_ field code 2, and the instruction Add the negative of the absolute value of is expressed by a _C_ field code 1. Multiplying When we wish to multiply one number by another and get a product, we have 3 numbers. We tell the machine about each of these numbers on a separate line of coding. Multiplication is signaled by sending a number into the _multiplicand counter_. The multiplicand counter has an in-code 761. If the multiplicand is in 321, the instruction is: Take the number in 321; enter it as multiplicand; read the next coding line The coding is: 321, 761, 7 On the third following coding line, the multiplier is sent into the _multiplier counter_. If the multiplier is in switch 741, the instruction is: Take the number in 741; enter it as multiplier; read the next coding line The coding is: 741, ——, 7 We do not punch anything in the middle field: the machine is “educated” and “knows” that it has started a multiplication and needs a multiplier, and it expects this multiplier in the third coding line. To have no code for the multiplier counter is, of course, a departure from the general rule, but it saves some punching and permits the use of this space for certain other codes, thus saving some operating time. We need not confuse the 761 in-code for the multiplicand counter with the 761 out-code, which happens to be the out-code of the 25th constant register, because neither can occur in the other’s field. We may, of course, use other registers besides 321 and 741 for supplying the multiplicand and multiplier. To get the product and put it into any storage counter _D_, we use two lines of coding one right after the other: —— —— 6421 8761 _D_ —— The _product counter_ has the out-code 8761. When the product is desired, it is called for, transferred into counter _D_, and the multiplication unit is automatically cleared. It takes time, however, for the machine to perform a multiplication. That is the reason for the preceding coding line and the 6421 in the _C_ field. While the multiplication is going on, we can instruct the machine to do other things that we want done. We can insert or _interpose_ coding lines in between the multiplier line and the product line. For example, if we have a multiplier of 10 digits, we can insert 8 coding lines and maybe more. The 6421 code essentially tells the machine to finish both the multiplication and the interposed instructions, and, as soon as the later one of these two tasks is finished, to transfer out the product to counter _D_. Up to the middle of 1946, the wiring of the machine was a little different and less convenient. When the product was obtained by the multiplication unit, it had to be accepted and transferred at once into one of the 72 storage registers. Dividing Division is called for by first sending the divisor into the _divisor counter_, and this has a code 76 in the _B_ field. If the divisor is in counter 321, the instruction may be: Take the number in 321; enter it as divisor; read the next coding line The coding will then be: 321, 76, 7 Three coding lines later, the dividend is called for, and the coding, if the dividend is in switch 7431, is: 7431, ——, 7 We can send the quotient, when ready, into any desired counter _Q_ by the following two lines of coding: —— —— 642 876 _Q_ —— In the same way as with multiplication, we can insert a number of coding lines in between the dividend line and the first quotient line. Both multiplication and division are carried out in the same unit of the machine, the _multiply-divide unit_. The machine first constructs a table of the multiples of the multiplicand or divisor: 1 times, 2 times, 3 times, ···, 9 times. In multiplication this table is then used by selecting multiples according to the digits of the multiplier one after another. In division the table is used by comparing multiples of the divisor against the dividend and successive remainders, finding which will go and which will not. Since the numbers in the machine are normally of 15 to 23 digits, any particular multiple will be used, on the average, several times, and so this process is relatively efficient. Actually the multiplicand and the divisor go into the same counter. Division, however, has the code 76 and multiplication the code 761, and so the difference is essentially an operation code not in the third or _C_ field. Consulting a Table When we desire the machine to consult a table of values (i.e., a _function_—see Supplement 2), we punch the table with its arguments and function values on a tape, and we put the tape on a value tape feed mechanism. The instruction to the machine may be: Take the number in register _A_; find the value of the function for this number, and enter it in register _B_. The coding is: —— —— 73 _A_ 7654 61 —— —— 762 —— —— 543 —— —— 75431 841 7654 —— _A_ 763 6421 8762 _B_ 73 —— 8763 7 Without explaining this coding line by line, we can say that this is what happens: The machine reads the argument in register _A_. The machine reads the argument in the table at which the value tape feed is resting. It subtracts them, and thereby determines how far away the desired argument is. The machine then turns the tape that required distance. It checks that the new argument is the wanted argument. It reads the value of the function entered at that point on the function tape. Selecting There is a storage counter in the machine that is called the _selection counter_. The selection counter is counter 70 and has the code 732. It has all the properties of an ordinary storage counter and, in addition, one extra property: depending on the sign of the number stored in the selection counter, it is possible to select whether some other number shall be treated positively or negatively. In other words, addition of a number anywhere in the machine may take place either positively or negatively, if the number stored in the selection counter is positive or negative, respectively. For example, suppose that _x_ is the number in the selection counter. Suppose that _y_ is the number in some other counter _A_. Suppose that _z_ is the number in counter _B_. Suppose that we use the coding: _A_, _B_, 7432 What we get in _B_, because of the 7432 in the third or _C_ field, is _z_ plus _y_ if _x_ is positive or zero, and _z_ minus _y_ if _x_ is negative. In the language of the algebra of logic (see Chapter 9 and Supplement 2), where _T_( ...) is “the truth value of ...,” the number in _b_ equals: _z_ + _y_·_T_(_x_ ≥ 0) - _y_·_T_(_x_ < 0) (The nines complement of 0, namely 999···9 to 24 digits, is treated by the machine as negative.) Why do we need an operation like this in a mechanical brain? Among other reasons, what we want to do with a number, in mathematics, often depends on its sign. It may happen that a table is, for negative arguments, the negative of what it is for positive arguments; in other words, _F_(-_x_) =-_F_(_x_). This is true, for instance, for a table of _cubes_ {_F_(_x_) = _x_³} or for a table of _trigonometric tangents_ (see Supplement 2). If so, we certainly do not want to take the time and trouble to list the whole table. We put down only half the table and then, if _x_ is negative, use the negative of the value in the table. In order to apply such a time-saving rule when using the machine, we need the selection counter or its equivalent. Checking There is another special counter in the machine that is called the _check counter_. It also has all the properties of an ordinary storage counter and, in addition, one extra property: If the sign of the number stored in the check counter on a certain coding line is negative, then on the next coding line the machine may be stopped. In other words, suppose that the check counter stores a certain tolerance _t_. Suppose, under the instructions we give the machine, that it calculates a positive number _x_ that ought to be less than this tolerance. Suppose that something may go wrong and that _x_ actually may be greater than _t_. Then we put a check into our instructions. We tell the machine: When you have found _x_, subtract it from _t_. If the result is positive, go ahead. If the result is negative or zero, _stop_! Here is the coding. Suppose that the tolerance _t_ is in switch 751. Suppose that the number _x_ to be checked is in counter 4321. Then the instructions and coding are: Clear the check counter — — 7 Put in the tolerance, from switch 751 751 74 7 Subtract the absolute value of the number to be checked 4321 74 71 Stop, O Mechanical Brain, if your result be negative! — — 64 An operation like this is very useful in a mechanical brain. It enables the calculation to be interrupted if something has gone wrong. Of course, other operations of checking besides this one are used—for example, inspecting for reasonableness the results printed on typewriter 1. Other Operations There are other operations in the machine. There are two pairs of storage registers that can be _coupled_ together so that we can handle problems requiring numbers of 46 digits instead of 23. Registers 64 and 65 can be coupled, and registers 68 and 69 can be coupled. There is another storage counter, No. 71, that has an extra property. We can read out the number it holds times 1, or times 10¹², or times 10⁻¹², as may be called for. As a result of this counter, we can do problems requiring 144 registers storing numbers of 11 digits each, instead of 72 registers storing 23 digits each. Bigger statistical problems can be handled, for example. There are some minor sequences of operations, or _subroutines_, that can be called for by a single code. The subroutine may be a whole set of additions, subtractions, multiplications, divisions, and choices, having a single purpose: to compute some number by a _process of rapid approximation_ (see Supplement 2). There are built-in subroutines for some special mathematical functions: the _logarithm_ of a number to the base 10, the _exponential_ of a number to the base 10, and the _sine_ of a number. (See Supplement 2.) There are also 10 changeable subroutines, each of 22 coding lines, which can be called in, when wanted, by the main sequence-control tape or by each other. These subroutines constitute the Subsidiary Sequence Mechanism, and are extremely useful. They have _A_, _B_, and _C_ fields just like the main sequence-control, but they are given information by plugging with short lengths of wire instead of by feeding punched paper tape. RAPID APPROXIMATION FOR A LOGARITHM Up to this point in this chapter the author has tried to tell the facts about the Harvard machine in plain words. But for reading this section, a little knowledge of calculus is necessary. (See also Supplement 2.) If you wish, skip this section and go on to the next one. What is the process that the machine uses to compute any desired logarithm to 23 digits? Suppose that we take for an example the process by which the machine computes log_{10} 49.3724. We choose a 6-digit number for simplicity; the machine would handle a 23-digit number in the same way. The process uses 2 fundamental equations involving the logarithm: the sum relation log (_a_·_b_·_c_···) = log _a_ + log _b_ + log _c_··· and the series relation _h_² _h_³ _h_⁴ logₑ(1 + _h_) = _h_ - ———— + ———— - ———— + ···, │_h_│ < 1 2 3 4 The error in this series is less than the first neglected term. Now, the machine stores the base 10 logarithms (to 23 decimal places) of the following 36 numbers: 1 1.1 1.01 1.001 2 1.2 1.02 1.002 ... ... ... ... 9 1.9 1.09 1.009 First, the number 49.3724 is examined in a counter called the _Logarithm-In-Out counter_, and the position of the decimal point is determined, giving the _characteristic_ of the logarithm. The number 49.3724 has the characteristic 1. Next, 4 successive divisions are performed, in which the 4 divisors are (1) the first digit of the number, (2) the first 2 digits of the quotient, (3) the first 3 digits of the next quotient, and (4) the first 4 digits of the subsequent quotient; thus, 4.93724/4 = 1.23431 1.23431/1.2 = 1.02860 1.02860/1.02 = 1.00843 1.00843/1.008 = 1.00043 For simplicity we have kept only 6 digits, although the machine, of course, would keep 23. It is interesting to note that the machine is able to sense digits and thus determine the 4 divisors; this is an arithmetical and numerical process and one that cannot be done in ordinary algebra. We now have: log₁₀ 49.3724 = 1 + log₁₀ 4 + log₁₀ 1.2 + log₁₀ 1.02 + log₁₀ 1.008 + log₁₀ 1.00043 To compute log₁₀ 1.00043 to 21 decimals we use ( _h_² _h_³ _h_⁴ _h_⁵ _h_⁶ ) log₁₀_e_ · (_h_ - ————— + ————— - ———— + ————— - —————) ( 2 3 4 5 6 ) with _h_ = 0.00043. Only 6 terms of the series relation are needed. For, the error is less than _h_⁷/7, which is less than 10⁻²¹/7, since _h_ < ¹/₁₀₀₀. The machine uses the series relation in the form log₁₀ (1 + _h_) = {([{(_c_₆_h_ + _c_₅)_h_ + _c_₄}_h_ + _c_₃]_h_ + _c_₂)_h_ + _c_₁}_h_ where _c_₁ = _M_, _c_₂ = -_M_/2, _c_₃ = _M_/3, ···, and _M_ = log₁₀__e_= 0.434294···. The 6 values of the _c_’s are also stored in the machine. When any logarithm is to be computed, the sum of the characteristic, of the 4 logarithms of the successive divisors, and of the first 6 terms of the series relation gives the logarithm. The maximum time required is 90 seconds. AN APPRAISAL OF THE CALCULATOR The IBM Automatic Sequence-Controlled Calculator at Harvard is a landmark in the development of machines that think. Its capacity for many problems for which it is suited is far beyond the capacity of a hundred human computers. Speed The time required in the machine for adding, subtracting, transferring, or clearing numbers is ³/₁₀ of a second. This is the time of one machine cycle or of reading one coding line. Multiplication takes at the most 6 seconds, and an average of 4 seconds. Division takes at the most 16 seconds, and an average of 11 seconds. Each, however, requires only 3 lines of coding, or ⁹/₁₀ of a second’s attention from the sequence mechanism; interposed operations fill the rest of the time. To calculate a logarithm, an exponential, or a sine to the full number of digits obtainable by means of the automatic subroutine takes at the most 90, 66, and 60 seconds, respectively. To get three 24-digit numbers from feeding a punch card takes ⅓ second. To punch a number takes from ½ second up to 3 seconds. To print a number takes from 1½ seconds up to 7 seconds. Cost and Value The cost of the machine was somewhere near 3 or 4 hundred thousand dollars, if we leave out some of the cost of research and development, which would have been done whether or not this particular machine had ever been built. A staff of 10 men, consisting of 4 mathematicians, 4 operators, and 2 maintenance men, are needed to keep the machine running 24 hours a day. This might represent, if capitalized, another 1 or 2 hundred thousand dollars. If a capital value of $500,000 is taken as equivalent to $50,000 a year, then the cost of the machine in operation 24 hours a day is in the neighborhood of $150 a day or $6 an hour. The value of the machine, however, is very much greater. If 100 human beings with desk calculators were set to work 8 hours a day at $1.50 an hour, the cost would be $1200 a day, or 8 times as much. Yet it is very doubtful that the work they could produce would equal that turned out by the machine, either in quality or quantity, when the machine is well suited to the problem. Reliability By reliability we mean the extent to which the results produced by the machine can be relied on to be right. The machine contains no built-in device for making its operations reliable. So, if we wish to check a multiplication, for example, we can do the multiplication a second time, interchanging the multiplier and the multiplicand. But if, say, digit 16 of the product were not transferring correctly, we would get the same wrong result both ways and we would not have a sufficient check. Thus, when we set up a problem for the machine to do, one of the big tasks we have is checking. We have to work out ways of making sure that the result, when we get it, is right and ways of instructing the machine to make the tests we want. This is not a new task. Whenever you or I set out to solve a problem, we have to make sure—usually by doing the problem twice, and preferably by doing it a different way the second time—that our answer, when we get it, is correct. One of the chief tasks for the mathematician, in making a sequence-control tape for the machine, is to put into it sufficient checks to make sure that the results are correct. We can use a number of different kinds of partial checks: the check counter; _differences_, and _smoothness_ (see Supplement 2); watching the results printed on typewriter 1; mathematical checks; comparison with known specific values; etc. In actual experience on the machine, human failures, such as failure to state the problem exactly or failure to put it on the machine correctly, have given about as much trouble as mechanical failures. The machine operates without mechanical failure about 90 to 95 per cent of the time. The balance of the time the machine is idle while being serviced or repaired. The machine is serviced by mechanics trained and supervised at Harvard. Often when we change the machine from one problem to another problem, we find some kind of trouble. Consequently, we need to work out in detail the first part of any calculation placed on the machine. We then compare the results step by step with the results produced by the machine. Any mathematician working with the machine needs considerable training in order to diagnose trouble quickly and guide the maintenance men to the place where repair or replacement is needed. Once you find the trouble, you can fix it easily. Without disturbing the soldered connections, you can easily pull out from its socket a relay that is misbehaving and plug in a new relay. With a screwdriver you can change a counter position—detach it from its socket and replace it by another one that is working correctly. One “bug” that will long be remembered around the Laboratory was a case involving a 5 that would incorrectly come in to a number every now and then. It did not happen often—only once in a while. After a week of search the bug was finally located: the insulation on a wire that carried a 5 had worn through in one spot, and once in a while this wire would shake against a post that could carry current and took in the 5! Efficiency In many respects, this machine is efficient and well-balanced. Its reading and writing speed is close to its calculating speed. We can punch or print a result on the average for every 10 additions or 1½ multiplications. The memory of 72 numbers in the machine is extremely useful; a smaller memory is a serious limitation on the achievements of a computing machine. The machine can do many kinds of arithmetic and logic. It is well educated and can compute automatically some rather complicated mathematical functions, like logarithm or sine. It has done difficult and important problems. It has computed and tabulated (see Supplement 2) _Bessel functions_, _definite integrals_, etc. It can solve _differential equations_ (see Chapter 5) and many other problems in mathematics, physics, and engineering. On the other hand, no calculator will ever again be built just like this one, useful though it is. Electronic computing is easily 100 times as fast as relay computing; nearly every future calculator will do its computing electronically. Many other improvements will be made. For example, in this calculator, there are 72 addition-subtraction mechanisms, yet only one of these can be used at a time. Also, the machine has only one combined multiply-divide unit. So we have to organize any computation with few multiplications, and with still fewer divisions, for they take longer still. Until 1947, we had to organize any computation in this calculator into one single fixed sequence of operations. In other words, there was no way to move from one subroutine to another subroutine depending on some indication that turned up in our computation. Recently, the Harvard Computation Laboratory decided to remedy this condition and provided the Subsidiary Sequence Mechanism equivalent to 10 subroutines of 22 lines of coding each. These are on relays and plug wires and may be called for by the sequence-control tape or by each other. This provision has added greatly to the efficiency of the calculator. Whatever else can be said about the Harvard IBM Automatic Sequence-Controlled Calculator, it must be said that this was the first general-purpose mechanical brain using numbers in digit form and able to do arithmetic and logic in hundreds of thousands of steps one after another. And great credit must go to Professor Howard H. Aiken of Harvard and the men of International Business Machines Corporation who made this great mechanical brain come into existence. Chapter 7 SPEED—5000 ADDITIONS A SECOND: MOORE SCHOOL’S ENIAC (ELECTRONIC NUMERICAL INTEGRATOR AND CALCULATOR) Another of the giant brains that has begun to work is named _ENIAC_. This name comes from the initial letters of the full name, _Electronic Numerical Integrator and Calculator_. Eniac was born in 1942 at the Moore School of Electrical Engineering, of the University of Pennsylvania, in Philadelphia. Eniac’s father was the Ordnance Department of the U. S. Army, which provided the funds to feed and rear the prodigy. In the short space of four years, Eniac grew to maturity, and in February 1946 he began to earn his own living by electronic thinking. Eniac promptly set several world’s records. He was the first giant brain to use electronic tubes for calculating. He was the first one to reach the speed of 5000 additions a second. He was the first piece of electronic apparatus containing as many as 18,000 electronic tubes all functioning together successfully. As soon as Eniac started thinking, he promptly made relay calculators obsolete from the scientific point of view, for they have a top speed of perhaps 10 additions a second. At the age of 5, he moved to Maryland at a cost of about $90,000, and his permanent home is now the Ballistic Research Laboratories at the U. S. Army’s Proving Ground at Aberdeen, Md. ORIGIN AND DEVELOPMENT In the Department of Terrestrial Magnetism in the Carnegie Institution of Washington, a great deal of information about the earth is studied. Many kinds of physical observations are there gathered and analyzed: electricity in the atmosphere, magnetism in the earth, and the weather, for example. In 1941, a physicist, Dr. John W. Mauchly, was thinking about the great mass of numerical information they had to handle. He became convinced that much swifter ways of handling these numbers were needed. He was certain electronic devices could be used for computing at very high speeds, yet he found no one busy applying electronics in this field. With hopes of finding some way of developing electronic computing, he joined the staff of the Moore School of Electrical Engineering in the autumn of 1941. The Moore School in 1934 and 1935 had built a differential analyzer; and, from that time on, the school had made a number of improvements in it. In 1941, with war imminent, the differential analyzer was put hard at work calculating tables for the Army’s Ballistic Research Laboratories. These tables were mostly firing tables, tables of the paths along which projectiles travel when fired—_trajectories_; obviously, you cannot fire a gun usefully, unless you know how to aim it. The amount of calculation of trajectories was so huge that Dr. Mauchly suggested that a machine using electronic tubes be constructed to calculate them. A good deal of discussion took place between men at the Moore School, men at the Ballistic Research Laboratories, and men from the Ordnance Department in Washington. A contract for research into an electronic trajectory computer was concluded with the Ordnance Department of the U. S. Army. Mauchly and one of the young electronics engineers studying at Moore School, J. Presper Eckert, Jr., set to work on the design. Gradually the design of a machine took form, and the crucial experiments on equipment were completed. In 1943, the design was settled as a special-purpose machine to calculate trajectories. Later on, the group modified the plans here and there to enable the machine to calculate a very wide class of problems. A group of Moore School electronics engineers and technicians during 1944 and 1945 built the machine, using as much as possible standard radio tubes and parts. Here, again, in spite of the successful progress of the electronic machine, the rumor that it was a “white elephant” was allowed to spread in order to protect the work from prying enemy ears. GENERAL ORGANIZATION The main part of Eniac consists of 42 _panels_, which are placed along the sides of a square U. Each of these panels is 9 feet high, 2 feet wide, and 1 foot thick. They are of sheet steel, painted black, with switches, lights, etc., mounted on them. At the tops of all the panels are air ducts for drawing off the hot air around the tubes. Large motors and fans above the machine suck the heated air away through the ducts. There are also 5 pieces of equipment which can be rolled from place to place and are called _portable_, but there is no choice as to where they can be plugged in. We shall call this equipment panels 43 to 47. Panels Now what are these panels, and what do they do? Each panel is an assembly of some equipment. The names of the panels are shown in the accompanying table. The arrangement of Eniac at the Ballistic Research Laboratories as shown in the table is slightly different from the arrangement of Eniac at Moore School. NAMES OF PANELS OF ENIAC PANEL NO. NAME (AND ADDITIONAL NAMES IN SOME CASES) 1 Initiating Unit 2 Cycling Unit 3, 4 Master Programmer, panels 1, 2 5 Accumulator 1 6 Accumulator 2 7 Accumulator 3 8 Accumulator 4 (Quotient) 9 Divider-Square-Rooter 10 Accumulator 5 (Numerator I) 11 Accumulator 6 (Numerator II) 12 Accumulator 7 (Denominator—Square Root I) 13 Accumulator 8 (Denominator—Square Root II) 14 Accumulator 9 (Shift I) 15 Accumulator 10 (Shift II) 16 Blank panel for new unit (Converter) 17 Accumulator 11 (Multiplier) 18 Accumulator 12 (Multiplicand) 19-21 Multiplier, panels 1, 2, 3 22 Accumulator 13 (Left-Hand Partial Products I) 23 Accumulator 14 (Left-Hand Partial Products II) 24 Accumulator 15 (Right-Hand Products I) 25 Accumulator 16 (Right-Hand Products II) 26 Blank panel for new unit (100 Registers) 27 Accumulator 17 28 Accumulator 18 29 Accumulator 19 30 Accumulator 20 31, 32 Function Table 1, panels 1, 2 33, 34 Function Table 2, panels 1, 2 35, 36 Function Table 3, panels 1, 2 37-39 Constant Transmitter, panels 1, 2, 3 40-42 Printer, panels 1, 2, 3 43-45 Portable Function Tables _A_, _B_, and _C_ 46 IBM Card Reader 47 IBM Summary Punch _Note_: The accumulators from which a number can be sent to the printer are now accumulators 1, 2, and 15 to 20. In reading over the table, we find a number of words that need explaining. Some of the explanation we can give in the summary of the units of Eniac: SUMMARY OF UNITS OF ENIAC QUANTITY DEVICE SIGNIFICANCE 20 Accumulators Store, add, and subtract numbers 1 Multiplier Multiplies 1 Divider-Square-Rooter Divides, and obtains twice the _square root_ of a number (see Supplement 2) 3 Function Tables Part of the memory, for referring to tables of numbers 1 Constant Transmitter Stores numbers from the card reader and from hand-set switches 1 Printer Punches machine results into cards 1 Cycling Unit Controls the timing of the various parts of the machine 1 Initiating Unit Has controls for starting a calculation, for clearing, etc. 1 Master Programmer Holds the chief controls for coordinating the various parts of the machine An _accumulator_ is a storage counter. It can hold a number; it can clear a number; it can transmit a number either positively or negatively; and it can receive a number by adding the number in and thus holding the sum of what it held before and the number received. Eniac when first built had only 20 accumulators, and so it could remember only 20 numbers at one time (except for constant numbers set in switches). This small memory was the most serious drawback of Eniac; panel 26 was designed, therefore, to provide a great additional memory capacity. The _divider-square-rooter_, as its name tells, is a mechanism that can divide and that can find twice the square root of a number. Eniac is one of the several giant brains that have had square root capacity built into them, particularly since square root is needed for solving trajectories. Many panels of Eniac have double duty and some have triple duty. For example, panel 24 is an accumulator, but it also (1) stores the right-hand partial products (see Supplement 2) of the multiplier and (2) was a register, when Eniac was at Moore School, from which information to be punched in the printer could be obtained. Clearly, if we have a multiplication to do, we cannot also use this accumulator for storing a number that is to remain unchanged during the multiplication. Parts The total number of parts in Eniac is near half a million, even if we count electronic tubes as single parts. There are over 18,800 electronic tubes in the machine. It is interesting to note that only 10 kinds of electronic tubes are used in the calculating circuits and only about 60 kinds of _resistors_ and 30 kinds of _capacitors_. A resistor is a device that opposes the steady flow of electric current through it to a certain extent (called _resistance_ and measured in _ohms_). A capacitor is a device that can store electrical energy up to a certain extent (called _capacitance_ and measured in _farads_). All these tubes and parts are standard parts in radios. All types are identified by the color labels established in standard radio manufacturing. It is the combinations of these parts, like the combinations of pieces in a chess game, that give rise to the marvelous powers of Eniac. The combinations of parts at the first level are called _plug-in units_. A plug-in unit is a standard box or tray or chassis made of sheet steel containing a standard assembly of tubes, wires, and other parts. It can be pushed in or pulled out of a standard socket with many connections. An example of a plug-in unit is a _decade_, or, more exactly, an _accumulator decade_. This is just a counter wheel or decimal position expressed in Eniac language: it can express successively all the digits from 0 to 9 and then pass from 9 to 0, giving rise to a carry impulse. It is striking that a mechanical counter to hold 10 digits can be made up of 10 little wheels, ¼ inch wide and an inch high. But an accumulator in Eniac, to hold 10 digits, is a set of 10 decades each 2 inches wide and 2½ feet high. There are only about 20 kinds of plug-in units altogether. Each plug-in unit is interchangeable with any other of the same kind. So, if a decade, for example, shows trouble, you can pull it out of its socket and plug in a spare decade instead. Numbers Numbers in Eniac are of 10 decimal digits with a sign that may be plus or minus. The decimal point is fixed. However, when you are connecting one accumulator with another, you can shift the decimal point if you want to. Also, 2 accumulators may be coupled together so as to handle numbers of 20 digits. HOW INFORMATION GOES INTO THE MACHINE There are three ways by which information—numbers or instructions—can go into the Eniac. Numbers can be put into the machine by means of punch cards fed into the Card Reader, panel 46, or switches on the Constant Transmitter, panels 37 to 39. Numbers or instructions can also go into the machine by means of the Function Tables, panels 43 to 45. Here there are dial switches, which are set by hand. Instructions can also go into the machine by setting the switches, plugging the inputs and outputs, etc., of the wires or lines along which numbers and instructions travel. HOW INFORMATION COMES OUT OF THE MACHINE There are two ways by which numerical information can come out of the machine. Numbers can come out of the machine punched on cards by the Summary Punch, panel 47. They are then printed in another room by means of a separate IBM tabulator. Also, numbers can be read out of the machine by means of the lights in the _neon bulbs_ mounted on each accumulator. You can read in the lights of a panel the number held by the accumulator, if the panel is not computing. HOW INFORMATION IS MANIPULATED IN THE MACHINE Eniac handles information rather differently from any other of the big brains. Instead of having only one bus or “railroad line” along which numbers can be sent, Eniac has more than 10 such lines. They are called _digit trays_ and labeled A, B, C, ···. Each contains 11 _digit trunk lines_ or _digit trunks_—10 to carry the digits of a number, and the 11th to carry the sign. Instead of having only one telegraph line along which instructions can be sent, Eniac has more than 100 such lines. They are called _program trunk lines_ or _program trunks_ and labeled A1, A2, ···, A11, B1, B2, ···, B11, ···, etc. They are assembled in groups of 11 to a tray; the _program trays_, in fact, look just like the digit trays, except for their connectors and their purpose, which are different. Below, we shall make clear how the program trays carry control information. Now, actually, Eniac has many more trunk lines than we have just stated, for each of the lines we have mentioned can be divided into numerous separate sections by the removal of plug connections. How we choose to do this depends on the needs of the problem, the space between the panels, the time when the line is used, etc. Transferring Numbers, Adding, and Subtracting Basically, a number is represented in Eniac by an arrangement of on and off electronic tube elements in pairs, called _flip-flops_. There is one flip-flop enclosed in a single tube (type 6SN7) for each value 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 for each of the 10 digits stored in an accumulator. So we have at least 100 flip-flops for each accumulator, and thus at least 100 electronic tubes are required to store 10 digits. Actually, an accumulator needs 550 electronic tubes. So we see that there is not very much of a future in this type of arrangement. The newer electronic brains use different devices for storage of numbers. In order to show what number is stored in an accumulator, there are 100 little neon bulbs mounted on the face of each accumulator panel. Each bulb glows when the flip-flop that belongs to it is on. For example, suppose that the 4th decade in Accumulator 11 holds the digit 7. Then the 7th flip-flop in that decade will be on, and all the others will be off. The 7th neon bulb for that decade will glow. Now suppose that the number 7 is in the 4th decade in Accumulator 11 and is to be added into, say, the 4th decade in Accumulator 13. And suppose that it is to be subtracted from the 4th decade in Accumulator 16. What do we do, and what will Eniac do? First, we pick out 2 digit trays, say B and D. Accumulator 11 has 2 outputs, called the _add output_ and the _subtract output_. We plug B into the add output and D into the subtract output. Then we go over to Accumulators 13 and 16. They have 5 inputs, that is, 5 ways of being plugged to receive numbers from digit trunks. These inputs are named with _Greek letters_, α, β, γ, δ, ε. We choose one input, say γ, for Accumulator 13, and we plug B into that input. We choose one input, say ε, for Accumulator 16, and we plug D into that input. Now we have the “railroad” switching for numbers accomplished. We have set up a channel whereby the number in Accumulator 11 will be routed positively into Accumulator 13 and negatively into Accumulator 16. Now let us suppose that, at some definite time fixed by the control, Accumulator 11 is stimulated to transmit and Accumulators 13 and 16 are conditioned to receive. When this happens, a group of 10 _pulses_ comes along a direct trunk from the cycling unit, and a group of 9 pulses comes along another trunk. We can think of each pulse as a little surge of electricity lasting about 2 millionths of a second. The _ten-pulses_, as the first group is called, are 10 millionths of a second apart. The _nine-pulses_, as the second group is called, are also 10 millionths of a second apart but are sandwiched between the ten-pulses. When the 1st ten-pulse comes along, the 7th flip-flop in Accumulator 11 goes off, the 8th flip-flop goes on, the following nine-pulse goes through and goes out on the subtract line to Accumulator 16. Then the 2nd ten-pulse comes along, the 8th flip-flop goes off, the 9th flip-flop goes on, and the next nine-pulse goes out on the subtract line to Accumulator 16. Now the decade sits at 9, and for this reason the next ten-pulse changes an electronic switch (actually another flip-flop) so that all later nine-pulses will go out on the add line. This ten-pulse also turns off the 9th flip-flop and turns on the 0th flip-flop without causing any carry. Now the 4th of the ten-pulses comes along, turns the 0th flip-flop off, and turns the 1st flip-flop on, and the next nine-pulse goes out on the add line to Accumulator 13. The next 6 of the ten-pulses then come along and change Accumulator 11 back to the digit 7 as before, and the next 6 of the nine-pulses go out to Accumulator 13. Thus Eniac has added 7 into Accumulator 13, has added 2, the _nines complement_ of 7 (see Supplement 2), into Accumulator 16, and has left Accumulator 11 holding the same number as before. This is just the result that we wanted. In this way, the nines complement of any digit in a decade is transferred out along the subtract line, and the digit unchanged is transmitted out along the add line. As the pulses arrive at any other accumulator, they add into that accumulator. Multiplying and Dividing Eniac performs multiplication by a built-in table of the products in the 10-by-10 multiplication table, using the method of _left-hand components_ and _right-hand components_ (see Supplement 2). For example, suppose that the 3rd digit of the multiplier is 7 and that the 5th digit of the multiplicand is 6. Then, when Eniac attends to the 3rd digit of the multiplier, the right-hand digit of the 42 = 6 × 7 is gathered in one accumulator, and the left-hand digit 4 is gathered in another accumulator. After Eniac has attended to all the digits of the multiplier, then Eniac performs one more addition and transfers the sum of the left-hand digits into the right-hand digits accumulator. Eniac does division in rather a novel way. First, the divisor is subtracted over and over until the result becomes negative or 0. Then the machine shifts to the next column and adds the divisor until the result becomes positive or 0. It continues this process, alternating from column to column. For example, suppose that we divide 3 into 84 in this way. We have: ______ _ 3 ) 84 ( 32 -3 —— +54 -3 —— +24 -3 —— -6 +3 —— -3 +3 —— 0 After we subtract 3 the third time, the result becomes negative,-6; in the next column, after we add 3 twice, the result becomes 0. The quotient is _ 32, which is the same as 30 - 2, or 28; and 3 × 28 is 84. Thus the process checks. Consulting a Table Eniac has three Function Tables. Here you can store numbers or instructions for the machine to refer to. Each Function Table has 104 _arguments_ (see Supplement 2). For each argument, you can store 12 digits and 2 signs that may be plus or minus. This capacity can be devoted to one 12-digit number with a sign, or to two 6-digit numbers each with a sign, or to six 2-digit instructions. The three Function Tables are panels 43, 44, and 45. To put in the numbers or instructions, you have to go over to these panels and set the numbers or instructions, digit by digit, turning dial switches by hand. It is slow and hard to do this right, but once it is done, Eniac can refer to any number or instruction in any table in ¹/₁₀₀₀ of a second. This is much faster than the table reference time in any other of the giant brains built up to 1948. Programming We said above that Eniac has over 100 control lines or program trunks along which instructions can be sent. These instructions are expressed as pulses called _program pulses_. Now how do we make these pulses do what we want them to do? For example, how can we instruct Accumulator 11 to add what it holds into Accumulator 13? On each unit of Eniac there are plug hubs or sockets (called _program-pulse input terminals_) to which a program trunk may be connected. A program pulse received here can make the unit act in some desired way. On each accumulator of Eniac, we find 12 program-pulse input hubs. Corresponding to each of these hubs, there is a nine-way switch, called a _program-control switch_. The setting of this switch determines what the accumulator will do when the program-pulse input hub belonging to the switch receives a program pulse. For instance, there are switch settings for: receive input on the α line, receive input on the β line, etc.; and transmit output on the add line, etc. There is even a switch setting that instructs the accumulator to do nothing, and this instruction may be both useful and important. Now, in order that Accumulator 11 may transfer a number to Accumulator 13, we need: (1) a digit tray, say B, for the number to travel along; (2) a program trunk line, say G3, to tell Accumulator 11 when to send the number and Accumulator 13 when to receive it; and (3) certain plugging as follows: 1. We plug from program trunk G3 into a program-pulse input hub, say No. 5, of Accumulator 11; 2. We plug from the same program trunk G3 into a program-pulse input hub, say No. 7, of Accumulator 13; 3. We set program-control switch No. 5 of Accumulator 11 to “add”; 4. We set program-control switch No. 7 of Accumulator 13 to some input, say γ. 5. We plug from digit tray B into the add output of Accumulator 11. 6. We plug from digit tray B into the γ input of Accumulator 13. Now, when the program pulse comes along line G3, it makes Accumulator 13 transmit additively along digit tray B into Accumulator 13. And that is the result that we wanted. As each mechanism of Eniac finishes what it is instructed to do, it may or may not put out a program pulse. This pulse in turn may be plugged into any other program trunk line and may stimulate another mechanism to act. Then, when this mechanism finishes, it too may or may not put out a program pulse, and so on. In general, there are two different ways to instruct Eniac to do a problem. One way is to set all the switches, plug all the connections, etc., for the specific problem. This is a long and hard task. Very often, even with great care, it is done not quite correctly, and then the settings must be carefully checked all over again. A second method (called the _von Neumann programming method_) is to store all the instructions for a problem in one or two function tables of Eniac and then tell Eniac to read the function tables in sequence and to do what they say. The rest of the machine is then wired up in a standard fashion. This method of instructing Eniac was proposed by Dr. John von Neumann of the Institute of Advanced Study at Princeton, N. J. Eniac has been modified to the slight extent needed so that this method can be used when desired. In this method, each instruction is a selected one of 60 different standard instructions or orders—one of them, for example, being “multiplication.” Each standard order is expressed by 2 decimal digits. The 60 standard orders are sufficient so that Eniac can do any mathematical problem that does not overstrain its capacity. Since each of the 3 Function Tables can hold 600 2-digit instructions, the machine can hold a program of 1800 instructions under the von Neumann programming method. AN APPRAISAL OF ENIAC AS A COMPUTER As a general-purpose calculating machine, Eniac suffers from unbalance. That is to say, Eniac operates rapidly and successfully in some respects, and slowly and troublesomely in other respects. This is altogether to be expected, however, in a calculator as novel as Eniac and made to so large an extent out of standard radio parts. It was certainly better to finish a calculator like this one and then start on a new one, as the Moore School of Electrical Engineering did, than to prolong design and construction indefinitely in order to make improvements. Speed Eniac adds or subtracts very swiftly at the rate of 5000 a second. Eniac multiplies at the rate of 360 to 500 a second. Division, however, is slow, relatively; the rate is about 50 a second. Reading numbers from punched cards, 12 a second for 10-digit numbers, is even slower. As a result of these rates, you find, when you put a problem on Eniac, that one division delays you as long as 100 additions or 8 multiplications. Division might have been speeded somewhat by (1) _rapidly convergent approximation_ (see Supplement 2) to the _reciprocal_ of the divisor and (2) multiplying by the dividend; this might have taken 5 or 6 multiplication times instead of 8. Also, the use of a standard IBM punch-card feed and card punch slows the machine greatly. One way to overcome this drawback might be to install one or two additional sets of such equipment, which might increase input and output speed. Ease of Programming Eniac has a very rapid and flexible automatic control over the programming of operations. Eniac has more than 10 channels along which numbers can be transferred and more than 100 channels along which program-control pulses can be transferred. There are many ways for providing subroutines. Eniac has the additional advantage that there is no delay in giving the machine successive instructions: all the instructions the machine may need at any time are ready at the start of the problem, and indications occurring in the calculation can change the routine completely. All these advantages, however, are paid for rather heavily by the slow methods for changing programming. You have to plug large numbers of program trunk lines and digit trunk lines, or you have to set large numbers of switches, or both. Also, when you wish to return to a previous problem, you must do all the plugging and switch setting over again. Many delays in the operation of the machine are due to human errors in setting the machine for a new problem. Here again, we must remember that Eniac was originally designed as a special-purpose machine for solving trajectories. To calculate a large family of trajectories very little changing of wires and switches would be needed. Memory The most severe limitation on the usefulness of Eniac was, at the outset, the fact that it had only 20 registers for storing numbers. There are large numbers of problems that cannot be simply handled with so small an internal memory. Even the Harvard IBM calculator (see Chapter 6) is often strained during a problem because of the number of intermediate results that must be stored for a time before combining. The Ballistic Research Laboratories, however, contracted for extensions to Eniac to provide more memory and easier changing of instructions. Reliability Checking results with Eniac is not easy. There is no built-in guarantee that Eniac’s results are correct. A large calculator can and does make both constant and intermittent errors. Ways for checking with Eniac are: Mathematical, if and when available, and this will be seldom. Running the problem a second time, and this will, at most, prove consistency. Deliberate testing of small parts of the problem, which is very useful and is standard practice but leads only to a probability that the final result is correct. You can operate Eniac one addition at a time, and even one pulse at a time, and see what the machine shows in its little neon bulbs. This is a very useful partial check. Cost The cost of Eniac is higher than that of some of the other large mechanical brains—over half a million dollars. Because some of the work was done at the Moore School by students, the cost was probably less than it otherwise would have been. The largest part of the cost was the designing of the machine and the construction of the panels; the tubes were only a small portion of the cost. The tubes used in the calculating circuits cost only 20 to 90 cents. However, no later electronic calculator need cost as much, for many improvements can now be seen. The power required for Eniac is about 150 kilowatts or about 200 horsepower, most of which is used for the heaters of the electronic tubes. The largest number of electronic tubes mentioned for future electronic calculators is about 3000, so we can see that they are likely to use less than a quarter of the power needed for Eniac. Eniac will doubtless give a number of years of successful operation and be extremely useful for problems that employ its assets and are not excluded by its limitations. In fact, at the Ballistic Research Laboratories, for a typical week of actual work, Eniac has already proved to be equal to 500 human computers working 40 hours with desk calculating machines, and it appears that soon two or three times as much work may be obtained from Eniac. Chapter 8 RELIABILITY—NO WRONG RESULTS: BELL LABORATORIES’ GENERAL-PURPOSE RELAY CALCULATOR In 1946, Bell Telephone Laboratories in New York finished two _general-purpose relay calculators_—mechanical brains. They were twins. One was shipped in July 1946 to the National Advisory Committee for Aeronautics at Langley Field, Virginia. The other, after some months of trial operation, was shipped in February 1947 to the Ballistic Research Laboratories at the U. S. Army’s Proving Ground, Aberdeen, Md. Each machine is remarkably reliable and versatile. It can do a wide variety of calculations in a great many different ways. Yet the machine never takes a new step without a check that the old step was correctly performed. There is, therefore, a chance of better than 99.999,999,999 per cent that the machine will not let a wrong result come out. The automatic checking, of course, does not prevent (1) human mistakes—for example, instructing the machine incorrectly—or (2) mechanical failures, in which the machine stops dead in its tracks, letting no result at all come out. ORIGIN AND DEVELOPMENT In Bell Telephone Laboratories the telephone system of the country is continually studied. Their research produced the common type of dial telephone system: a masterly machine for selecting information. Now when a telephone engineer studies an electric circuit, he often finds it very convenient to use numbers in pairs: like 2, 5 or-4,-1. Here the comma is a separation sign to keep the two numbers in the pair separate and in sequence. Mathematicians call numbers of this kind, for no very good reason, _complex numbers_; of course, they are far less complex than why the sun shines or why plants grow. When Bell Laboratories test the design of new circuits, girl computers do arithmetic with complex numbers. Addition and subtraction are easy: each means two operations of addition or subtraction of ordinary numbers. For example, 2, 5, plus-4,-1 equals 2-4, 5-1, which equals-2, 4. And 2, 5 minus-4,-1 is the same as 2, 5 plus 4, 1; and this equals 2 + 4, 5 + 1, which equals 6, 6. Multiplication of two complex numbers, however, is more work. If _a_, _b_ and _c_, _d_ are two complex numbers, then the formula for their product is (_a_ × _c_)-(_b_ × _d_), (_a_ × _d_) + (_b_ × _c_). To get the answer, we need 4 multiplications, 1 subtraction, and 1 addition. Division of two complex numbers requires even more work. If _a_, _b_ and _c_, _d_ are two complex numbers, the formula for the quotient of _a_, _b_ divided by _c_, _d_ is: [(_a_ × _c_) + (_b_ × _d_)] ÷ [(_c_ × _c_) + (_d_ × _d_)], [(_b_ × _c_) - (_a_ × _d_)] ÷ [(_c_ × _c_) + (_d_ × _d_)] For example, (2, 5) ÷ (-4, -1) = [(2 × -4 = -8) + (5 × -1 = -5)] ÷ [(-4 × -4 = 16) + (-1 × -1 = 1)], [(5 × -4 = -20) - (2 × -1 = -2)] ÷ [16 + 1] = -(¹³/₁₇), -(¹⁸/₁₇) Thus, division of one complex number by another needs 6 multiplications, 2 additions, 1 subtraction, and 2 divisions of ordinary numbers—and always in the same pattern or sequence. The Complex Computer About 1939, an engineer at Bell Telephone Laboratories in New York, Dr. George R. Stibitz, noticed the great volume of this pattern arithmetic. He began to wonder why telephone switching equipment could not be used to do the multiplications and divisions automatically. He decided it could. All that was necessary was that the _relays_ (see Chapter 2) used in regular telephone equipment should have a way of remembering and calculating with numbers. Regular telephone equipment would take care of the proper sequence of operations. Regular equipment known as _teletypewriters_ would print the numbers of the answer when it was obtained. A teletypewriter consists essentially of a typewriter that may be operated by electrical impulses. It has a keyboard that may produce electrical impulses in sets corresponding to letters; and it can receive or transmit over wires. Dr. Stibitz _coded_ the numbers: each decimal digit was matched up with a group of four relays in sequence, and each of these relays could be open or closed. If 0 means open and 1 means closed, here is the pattern or code that he used: DECIMAL DIGIT RELAY CODE 0 0 0 1 1 1 0 1 0 0 2 0 1 0 1 3 0 1 1 0 4 0 1 1 1 5 1 0 0 0 6 1 0 0 1 7 1 0 1 0 8 1 0 1 1 9 1 1 0 0 With regular telephone relays and regular telephone company techniques, Dr. Stibitz and Bell Telephone Laboratories designed and constructed the machine. It was called the _Complex Computer_ and was built just for multiplying and dividing complex numbers. Six or eight panels of relays and wires were in one room. Two floors away, some of the girl computers sat in another room, where one of the teletypewriters of the machine was located. When they wished, they could type into the machine’s teletypewriter the numbers to be multiplied or divided. In a few seconds back would come the answer. In fact, there were two more computing rooms where teletypewriters of the machine were stationed. To prevent conflicts between stations, the machine had a circuit like the busy signal from a telephone. In 1940, a demonstration of the Complex Computer took place: the computing panels remained in New York, but the teletypewriter input-output station was set up at Dartmouth College in Hanover, N. H. Mathematicians gave problems to the machine in Dartmouth, it solved them in New York, and it reported the answers in Dartmouth. Special-Purpose Computers With this as a beginning, Bell Laboratories developed another machine for a wide variety of mathematical processes called _interpolating_ (see Supplement 2). Then, during World War II, Bell Laboratories made more special-purpose computing machines. They were used in military laboratories charged with testing the accuracy of instruments for controlling the fire of guns. These computers took in a set of gun-aiming directions put out by the _fire-control instrument_ in some test. They also took in the set of observations that went into the fire-control instrument on that test. Then they computed the differences between the gun-aiming produced by the fire-control instrument and the gun-aiming really required by the observations. Using these differences, the fire-control instrument could be adjusted and corrected. These special-purpose computers were also useful in checking the design of new fire-control instruments and in checking changes due to new types of guns or explosives. Regularly, after each of these special-purpose computers was finished, people began to put other problems on it. It seemed to be fated that, as soon as you had made a machine for one purpose, you wanted to use it for something else. Accordingly, in 1944, two agencies of the U. S. Government together made a contract with Bell Telephone Laboratories for two general-purpose relay computers. These two machines were finished in 1946 and are twins. ORGANIZATION OF THE GENERAL-PURPOSE COMPUTER When a man sits down at a desk to work on a computation, he has six things on his desk to work with: a work sheet; a desk calculator, to add, subtract, multiply, and divide; some rules to be followed; the tables of numbers he will need; the data for the problem; and an answer sheet. In his head, he has the capacity to make decisions and to do his work in a certain sequence of steps. These seven subdivisions of calculation are all found in the Bell Laboratories’ general-purpose relay computer. The general-purpose computer is a computing system, in fact, more than it is a single machine. The part of the system which does the actual calculating is called, in the following paragraphs, the _computer_, or else, since it is in two halves, _Computer 1_ and _Computer 2_. Physical Units The computing system delivered to the Ballistic Research Laboratories fills a room about 30 by 40 feet and consists of the following: 2 _computers_: panels of relays, wiring, etc., which add, subtract, multiply, divide, select, decide, control, etc. 4 _problem positions_: tables each holding 12 mechanisms for feeding paper tape, which read numbers and instructions punched on tape and convert them into electrical impulses. 2 _hand perforators_: keyboard devices for punching instructions and numbers on paper tape. 1 _processor_: a table holding mechanisms for feeding 2 paper tapes and punching a third paper tape, used for checking numbers and instructions punched on tape. 2 _recorders_: each a table holding a teletypewriter, a tape punch, and a tape feed, used for recording answers and, if necessary, consulting them again. The 2 computers correspond to the work sheet, the desk calculator, and the man’s capacity to make decisions and to carry out a sequence of steps. The 4 problem positions correspond to the problem data, the rules, and the tables of numbers. The 2 recorders correspond to the answer sheet. The 2 hand perforators and the processor are auxiliary machines: they translate the ordinary language of arithmetic into the machine language of punched holes in paper tape. This is the computing system as organized for the Ballistic Research Laboratories at Aberdeen. The one for the National Advisory Committee for Aeronautics has only 3 problem positions. The computer system may, in fact, be organized with 1 to 10 computers and with 1 to 20 problem positions. The great bulk of this computing system, like the mechanical brains described in previous chapters, is made up of large numbers of identical parts of only a few kinds. These are: standard telephone relays; wire; and standard _teletype transmitters_, mechanisms that read punched paper tape and produce electrical impulses. Numbers The numbers that the Bell machine contains range from 0.1000000 to 0.9999999 times a _power_ of 10 varying from 10,000,000,000,000,000,000 to 0.000,000,000,000,000,000,1, or, in other words, from 10¹⁹ to 10⁻¹⁹. The machine also contains zero and _infinity_: zero arises when the number is smaller than 10⁻¹⁹, and infinity arises when the number is equal to or greater than 9,999,999,000,000,000,000. (See Supplement 2.) The system used in the machine to represent numbers on relays is called _biquinary_—the _bi_-, because it is partly twofold like the hands, and the -_quinary_ because it is partly fivefold like the fingers. This system is used in the abacus (see Chapter 2 and Supplement 2). In the machine, for each decimal digit, 7 relays are used. These relays are called the 00 and 5 relays, and the 0, 1, 2, 3, and 4 relays. If, as before, 0 indicates a relay that is not energized and 1 indicates a relay that is energized, then each decimal digit is represented by the positioning of the 7 relays as follows: DECIMAL DIGIT RELAYS 00 5 0 1 2 3 4 0 1 0 1 0 0 0 0 1 1 0 0 1 0 0 0 2 1 0 0 0 1 0 0 3 1 0 0 0 0 1 0 4 1 0 0 0 0 0 1 5 0 1 1 0 0 0 0 6 0 1 0 1 0 0 0 7 0 1 0 0 1 0 0 8 0 1 0 0 0 1 0 9 0 1 0 0 0 0 1 Then, for any decimal digit, one and only one of the 00 and 5 relays is energized, and one and only one of the 0, 1, 2, 3, and 4 relays is energized. If more or less than exactly one relay in each set is energized, then the machine knows that it has made a mistake, and it stops dead in its tracks. Thus any accidental failure of a relay is at once caught, and the chance of two compensating failures occurring at the same time is extremely small. HOW INFORMATION GOES INTO THE MACHINE In order to put a problem into this machine—just as with the other machines—first a mathematician who knows how the problem is to be solved, and who knows how to organize it for the machine, lays out the scheme of calculation. Then, a girl goes to one of the hand perforators. Sitting at the keyboard, she presses keys and punches out feet or yards of paper tape expressing the instructions and numbers for the calculation. Each character punched—digit, letter, or sign—has one or more of a maximum of 6 holes across the tape. Another girl, using the other hand perforator, also punches out the instructions and numbers for the calculation. If she wishes to erase a wrong character, she can press an _erase key_ that punches all 6 holes, and then the machine will pass by this row as if it were not there. Three kinds of tapes are produced for the machine: _Problem tapes_, which contain information belonging to the particular problem. _Table tapes_, which contain tables of numbers to be referred to from time to time. _Routine tapes_, which contain the program, or routine, or sequence of steps that the machine is to carry out. In each of these tapes one character takes up ⅒ of an inch along the tape. In the case of a table tape, however, an ordinary 1-digit number requires 4 characters on the tape, and a 7-digit number requires 11 characters on the tape. On a table tape there will be on the average about 1 inch of tape per number. The Processor The two paper tapes prepared on the perforator should agree. But whether or not they agree, a girl takes them over to the processor and puts them both in. The processor has two tape feeds, and she puts one tape on each and starts the machine. The processor compares them row by row, making sure that they agree, and punches a new tape row by row. If the two input tapes disagree, the processor stops. You can look to see which tape is right, and then you can put the correct punch into the new tape with a keyboard mounted on the processor. As the processor compares the two input tapes, it also converts any number written in the usual way into machine language. For example, the processor will automatically translate 23,188 into +.231 8800 × 10⁺⁵. The processor also puts in certain safeguards. If you want it to, the processor will also make a printed record of a tape. Also, when a tape becomes worn from use in the machine, you can put it into the processor and make a fresh copy. The Problem Positions Next, the girl takes the punched tape made by the processor over to a problem position that is idle. Two of the problem positions are always busy guiding the two computers. The other two problem positions stand by, ready to be loaded with problems. A problem position looks like a large covered-over table. Under the covers are 12 tape feeds, or _tape transmitters_. All these transmitters look exactly alike except for their labels and consist of regular teletype transmitters. Six-hole paper tape can be fed into any transmitter. Six metal fingers sense the holes in the paper tape and give out electrical impulses at proper times. At the front of the problem position is a small group of switches that provide complete control over the problem while it is on the machine. These are switches for starting, disconnecting, momentary stop, etc. One tape transmitter is the problem tape transmitter. It takes in all the data for the problem such as the starting numbers. The first thing it does at the start of a problem is to check (by comparing tape numbers) that the right tapes are in the right feeds. Five transmitters are routine tape transmitters. Each of these takes in the sequence of computing steps. The routine tapes also contain information for referring to table tapes and instructions for printing and punching tape. The machine can choose according to instructions between the five routine tapes and can choose between many different sections on each tape. Therefore, we can use a large number of different routines in a calculation, and this capacity makes the machine versatile and powerful. Six transmitters are table tape transmitters. They read tables of numbers when directed to. A table tape can be as long as 100 feet and will hold numbers at the rate of 1 inch per number, so that about 1200 numbers of seven decimal digits can be stored on a table tape. When we look up a number in a table, such as the following, 2½ 3 3½ ··· +———————————————————————————— 1 |1.02500 1.03000 1.03500 2 |1.05063 1.06090 1.07123 3 |1.07689 1.09273 ··· 4 |1.10381 ··· ··· 5 |1.13141 ··· 6 |1.15969 7 | ··· 8 | ··· 9 | ··· 10 | ···| ··· we look along the top and down the side until we find the column and row of the number we are looking for. These are called the _arguments_ of the _tabular value_ that we are looking for (see Supplement 2). Now when we put this table on a tape to go into the Bell Laboratories machine, we write it all on one line, one figure after another, and we punch it as follows: 2-½ 1-5 1.02500 1.05063 1.07689 1.10381 1.13141 6-10 1.15969 ··· 11-15 ··· ··· ··· 3 1-5 1.03000 1.06090 ··· ··· 3½ 1-5 1.03500 ··· You will notice that the column labels 2½, 3, 3½ have been put on the tape, each in front of the group of numbers they apply to. The row labels 1 to 5, 6 to 10, ··· have also been put on the tape, each in front of the group of numbers they apply to. The appropriate column and row numbers, or arguments, must be put often on every table tape, so that it is easy for the machine to tell what part of the table tape it is reading. In the Bell Laboratories machine, we do not need to put equal _blocks_ of arguments like 1-5, 6-10 ··· on the table tape. Instead we can put individual arguments like 1, 2, 3, 4 ···, or, if we wish, we can use blocks of different sizes, like 1-3, 4-15, 16-30···. For some tables, such as income tax tables, it is very useful to have varying-sized blocks of arguments. The machine, when hunting for a certain value in the table, makes a comparison at each block of arguments. The machine needs about 6 seconds to search a foot of tape. If we want to set up a table economically, therefore, we need to consider the average length of time needed for searching. [Illustration: FIG. 1. Scheme of a recorder.] HOW INFORMATION COMES OUT OF THE MACHINE At either one of the two recorders (Fig. 1), information comes out of the machine, either in the form of printed characters or as punched tape. The recorder consists of a _printer_, a _reperforator_, and a tape transmitter. One recorder table belongs to each computer and records the results it computes. The printer is a regular teletypewriter connected to the machine. It translates information produced by the machine as electrical impulses and prints the information in letters and digits on paper. The reperforator is an automatic tape punch. It translates information produced by the machine in the form of electrical impulses and punches the information on paper tape. Next to the tape punch is a tape transmitter. After the tape comes through the punch, it is fed into the transmitter. Here the machine can hunt for a previous result punched in the tape, read that result, and use it again. HOW INFORMATION IS MANIPULATED IN THE MACHINE The main part of the computing system consists of 27 large frames loaded with relays and wiring, called the _computer_, or _Computer 1_ and _Computer 2_. In this “telephone central station,” all the “phone calls” from one number to another are attended to. There are 8 types of these frames in the computer: FRAMES NUMBER Storing register frames 6 Printer frames 2 Problem frames 2 Position frames 2 Calculator frames 6 Control frames 2 Routine frames 4 BTL (Block-Trig-Log) frames 2 Permanent table frames 1 —— Total 27 In most but not quite all respects, the two halves, _Computer 1_ and _Computer 2_, can compute independently. The _storing register frames_ hold enough relays to store 30 numbers. The registers for these numbers are named _A, B, C, D_, ···, _M, N, O_ in two groups of 15 each. One group belongs to Computer 1 and the other to Computer 2. In each Computer, the _calculator frames_ hold enough relays for storing two numbers (held in the _X_ and _Y_ registers) and for performing addition, subtraction, multiplication, division, and square root. In each Computer, the _problem frame_ stores the numbers that are read off the problem tape and the table tapes, and the _printer frame_ stores the numbers that are read into the printer. The printer frame also stores indications, for example, the signs of numbers, plus or minus, for purposes of combining them. These frames also hold the relays that control the printer, the problem tape, and the table tapes. Jointly for both Computers, the _position frames_ connect a problem in some problem position to a Computer that becomes idle. For example, one problem may finish in the middle of the night; the machine automatically and unattended switches to another problem position and proceeds with the instructions there contained. A backlog of computing on hand can be stored in two of the problem positions, while the other two control the two Computers. In each Computer, the _routine frames_ hold the relays that make the Computer follow the routine instructions. Jointly for both Computers, the remaining frames—the _control frames_, the _BTL frames_, and the _permanent table frames_—hold the relays that control: the alarms and lights for indicating failures; some circuits called the BTL controls; the tape processor; and the mathematical tables that are permanently wired into the machine. The permanent table frames hold the following mathematical functions (see Supplement 2): _sine_, _cosine_, _antitangent_, _logarithm_, and _antilogarithm_. Storing Numbers can be stored in the machine in the 30 regular storing registers of both Computers together. They can also be stored, at the cost of tying up some machine capacity, in the other registers: the 4 calculator registers, the 2 problem registers, the 2 table registers, and the 2 printer registers. Numbers can also be punched out on tape, in either of the two printers, and later read again from the tape. Labels identifying the numbers can also be punched and read again from the tape. Each register in the machine stores a number in the biquinary notation, as explained above. In programming the machine, after mentioning a register it is necessary—as a part of the scheme for checking—to tell the machine specifically whether to hold the number in the register or to clear it. Addition and Subtraction The calculator frames can add two numbers together, if so instructed in the routine tape. Suppose that the two numbers are in the registers _B_ and _D_ and that we wish to put the sum in register _F_. Suppose that we wish to clear the _D_ number but hold the _B_ number after using them. The code on the routine tape is _B H_ + _D C_ = _F_. _H_ and _C_ coming right after the names of the registers always designate “hold” and “clear,” respectively. The calculator frames can, likewise, subtract a number. The routine instruction _B H_-_D C_ = _F_ means: Take the number in register _B_ (hold it); subtract the number in _D_ (clear it); put the result in _F_ Multiplication and Division The calculator frames perform multiplication by storing the digits of the multiplier, adding the multiplicand over and over, and shifting, until the product is obtained. However, if the multiplier is 1989, for example, the calculator treats it as 2000-11. This short-cut applies to digits 6, 7, 8, 9 and cuts the time required for multiplying. The routine instruction is _B H_ × _D C_ = _F_. The calculator performs division by repeated subtraction. The routine instruction is _B H_ ÷ _D C_ = _F_. The operation signs +,-, ×, ÷ actually appear on the keyboard of the perforator and on the printed tape produced by the printer. Discrimination _Discrimination_ is the term used in the Bell Laboratories computer for what we have previously called selection, or comparison, or sequencing. The _discriminator_ is a part of the calculator that compares or selects or decides—“discriminates.” The discriminator can decide whether a number is zero or not zero. In the language of the _algebra of logic_ (see Chapter 9 and Supplement 2), if _a_ is a number, the discriminator can find _T_(_a_ = 0). The discriminator can also decide whether a number is positive or negative. In the language of logic, it can find _T_(_a_ > 0) or _T_(_a_ < 0). The actions that a discriminator can cause to be taken are: Stop the machine. Stop the problem, and proceed to another problem. Stop the routine going on, and proceed with a new routine. Permit printing, or prevent printing; etc. In this way the discriminator can: Distinguish between right and wrong results. Tell that a certain result is impossible. Recognize a certain result to be the answer. Control the number of repetitions of a formula. Change from one formula to another formula. Check a number against a tolerance; etc. PROBLEMS Among the problems that have been placed on the machine successfully are: solving the _differential equation_ of a _trajectory_ (see Chapter 5) and solving 32 _linear simultaneous equations_ in 32 _unknowns_ (see Supplement 2). In the second case, the routine tapes were designed to apply equally well to 11 to 100 linear equations in 11 to 100 unknowns. However, the machine can do a very broad class of problems, including, for example, computing a personal income tax. This calculation with all its complexity of choices cannot be placed on any of the mechanical brains described in previous chapters. The machine can, of course, be used to calculate any tables that we may wish to refer to. AN APPRAISAL OF THE CALCULATOR The Bell Telephone Laboratories general-purpose relay computer is probably the best mechanical brain made up to the end of 1947, in regard to the two important factors of reliability and versatility. Reliability The machine produces results that are practically 100 per cent reliable, for the machine checks each step before taking the next one. The checking principle is that exactly a certain number of relays must be energized. For example, as we said before, for each decimal digit there are 7 relays. Exactly 2 of these relays must be energized—no more, no less. If this does not happen, the machine stops at once without losing any numbers. Lights shine for many circuits in the control panel, and, if you compare what they ought to show with what they do show, you can usually find at once the location of the mistake. The trouble may be a speck of dirt between two contact points on a relay, and, when it is brushed away, the machine can go right ahead from where it stopped. According to a statement by Franz L. Alt, director of the computing laboratory at the Ballistic Research Laboratories, in December 1947, “the Bell machine had not given a single wrong result in eight months of operation, except when operators interfered with its normal running.” To guard against the risk of putting tapes in the wrong transmitters, the machine will check by the instructions contained in the tapes that the right tapes are in the right places. Time Required The time required to do problems on this mechanical brain is perhaps longer than on the others. The numbers are handled digit by digit on the input tapes, and the typewriter in the recorder moves space by space in order to get to the proper writing point. These are slow procedures. The speeds of numerical operation are: addition, ³/₁₀ second; multiplication, 1 second on the average; division, 2.7 seconds on the average; square root, 4.5 seconds on the average; logarithm, about 15 seconds. Staff In order to operate the machine, the staff required is: one maintenance man; one mathematical engineer; about six girls for punching tape, etc., depending on the number of problems to be handled at the rate of about one problem per week per girl. Unlike any of the other mechanical brains built by the end of 1947, this machine will run unattended. Maintenance The relays in the machine will operate for years with no failure; they have the experience of standard telephone techniques built into them. Under laboratory conditions this type of relay had by 1946 operated successfully much more than 100 million times. The tape feeding and reading equipment in the machine may be maintained by periodic inspection and service. The total number of teletype transmitters in the machine is 38. If one fails, it is easy to plug in a spare. The total power required for the machine is about 28 horsepower. Batteries are furnished so that, if the power supply should be interrupted, the machine can still operate for as long as a half-hour. Cost The cost of production of this machine in the size of 4 problem positions and 2 computers has been roughly estimated as half a million dollars. This cost includes material, manufacture, installation, and testing. No development cost is included in this figure. Instead, the cost of development has been reckoned as squaring with patents and other contributions of the work to the telephone switching art. It is unlikely that the general-purpose relay computer will be manufactured generally. The pressure of orders for telephones, the need to catch up with the backlog of demand, and the development of electronic computers—all indicate that the Bell system will hardly go further with this type of computer. In an emergency, however, the Bell system would probably construct such machines for the government, if requested. In the meantime, many principles first used in the general-purpose relay computer are likely to find applications in telephone system work. In fact, a present major development being pursued in the telephone sections of Bell Laboratories is the application of the computer principles to the automatic computation of telephone bills. Chapter 9 REASONING: THE KALIN-BURKHART LOGICAL-TRUTH CALCULATOR So far we have talked about mechanical brains that are mathematicians. They are fond of numbers; their main work is with numbers; and the other kinds of thinking they do are secondary. We now come to a mechanical brain that is a logician. It is fond of reasoning—logic; its main work is with what is logically true and what is logically false; and it does not handle numbers. This mechanical brain was finished in June 1947. It is called the _Kalin-Burkhart Logical-Truth Calculator_. As its name tells, it calculates _logical truth_. Now what do we mean by that? TRUTH To be true or false is a property of a statement. Usually we say that a statement is true when it expresses a fact. For example, take the statement “Salt dissolves in water.” We consider this statement to be true because it expresses a fact. Actually, in this case we can roughly prove the fact ourselves. We take a bowl, put some water in it, and put in a little salt. After a while we look into the water and notice that no salt whatever is to be seen. Of course, this statement, like many another, occurs in a _context_ where certain things are understood. One of the understandings here, for example, is “a small amount of salt in a much larger amount of water.” For if we put a whole bag full of salt in just a little water, not all the salt will dissolve. Nearly every statement occurs in a context that we must know if we are to decide whether the statement is true or false. LOGICAL TRUTH Logical truth is different from ordinary truth. With logical truth we appeal not to facts but to suppositions. Usually we say that a statement is logically true when it follows logically from certain suppositions. In other words, we play a game that has useful, even wonderful, results. The game starts with “if” or “suppose” or “let us assume.” While the game lasts, any statement is logically true if it follows logically from the suppositions. For example, let us take five statements: 1. “The earth is flat like a sheet of paper.” 2. “The earth is round like a ball.” 3. “John Doe travels as fast as he can, without turning to left or to right, for many days.” 4. “John Doe will fall off the earth.” 5. “John Doe will arrive back at his starting point.” Let us also take a certain context in which: We know what we mean by such words as “earth,” “flat,” “falling,” etc.; we have other statements and understandings such as “if John Doe walks off the edge of a cliff, he will fall,” “a flat sheet of paper has an edge,” etc. In this context, if statements 1 and 3 are supposed, then statement 4 is logically true. On the other hand, if statements 2 and 3 are supposed, then statement 5 is logically true. Of course, for many centuries, nearly all men believed statement 1; and the importance of the years 1492 to 1521 (Columbus to Magellan) is linked with the final proof that statement 2 expresses a fact. So, depending on the game, or the context, whichever we wish to call it, almost any statement can be logically true. What we become interested in, therefore, is the connections between statements which make them _follow logically_. LOGICAL PATTERNS Perhaps the most familiar example of “following logically” is a pattern of words like the following: 1. All igs are ows. 2. All ows are umphs. 3. Therefore, all igs are umphs. If statements 1 and 2 are supposed, then statement 3 is logically true. In other words, statement 3 logically follows from statements 1 and 2. This word pattern is logically true, no matter what substitutions we make for igs, ows, and umphs. For example, we can replace igs by men, ows by animals, and umphs by mortals, and obtain: 4. All men are animals. 5. All animals are mortals. 6. Therefore, all men are mortals. The invented words “igs,” “ows,” “umphs” mark places in the _logical pattern_ where we can insert any names we are interested in. The words “all,” “are,” “therefore” and the ending s mark the logical pattern. Of course, instead of using invented words like “igs,” “ows,” “umphs” we would usually put _A_’s, _B_’s, _C_’s. This logical pattern is called a _syllogism_ and is one of the most familiar. But there are even simpler logical patterns that are also familiar. THE SIMPLEST LOGICAL PATTERNS Many simple logical patterns are so familiar that we often use them without being conscious of doing so. The simple logical patterns are marked by words like “and,” “or,” “else,” “not,” “if,” “then,” “only.” In the same way, simple arithmetical patterns are marked by words like “plus,” “minus,” “times,” “divided by.” Let us see what some of these simple logical patterns are. Suppose that we take two statements about which we have no factual information that might interfere with logical supposing: 1. John Doe is eligible for insurance. 2. John Doe requires a medical examination. In practice, we might be concerned with such statements when writing the rules governing a plan of insurance for a group of employees. Here, we shall play a game: (1) We shall make up some new statements from statements 1 and 2, using the words “and,” “or,” “else,” “not,” “if,” “then,” “only.” (2) We shall examine the logical patterns that we can make. (3) We shall see what we can find out about their logical truth. Suppose we make up the following statements: 3. John Doe is not eligible for insurance. 4. John Doe does not require a medical examination. 5. John Doe is eligible for insurance and requires a medical examination. 6. John Doe is eligible for insurance, and John Doe is eligible for insurance. 7. John Doe is eligible for insurance, or John Doe requires a medical examination. 8. If John Doe is eligible for insurance, then he requires a medical examination. 9. John Doe requires a medical examination if and only if he is eligible for insurance. 10. John Doe is eligible for insurance or else he requires a medical examination. Now clearly it is troublesome to repeat quantities of words when we are interested only in the way that “and,” “or,” “else,” “not,” “if,” “then,” “only” occur. So, let us use just 1 and 2 for the two original statements, remembering that “1 AND 2” means here “statement 1 AND statement 2” and does not mean 1 plus 2. Then we have: 3: NOT-1 4: NOT-2 5: 1 AND 2 6: 1 AND 1 7: 1 OR 2 8: IF 1, THEN 2 9: 1 IF AND ONLY IF 2 10: 1 OR ELSE 2 Here then are some simple logical patterns that we can make. CALCULATION OF LOGICAL TRUTH Now what can we find out about the logical truth of statements 3 to 10? If we know something about the truth or falsity of statements 1 and 2, what will logically follow about the truth or falsity of statements 3 to 10? In other words, how can we calculate the logical truth of statements 3 to 10, given the truth or falsity of statements 1 and 2? For example, 3 is NOT-1; that is, statement 3 is the negative or the _denial_ of statement 1. It follows logically that, if 1 is true, 3 is false; if 1 is false, 3 is true. Suppose that we use _T_ for logically true and _F_ for logically false. Then we can show our calculation of the logical truth of statement 3 in Table 1. Table 1 Table 2 1 | NOT-1 = 3 2 | NOT-2 = 4 | | _T_ | _F_ _T_ | _F_ _F_ | _T_ _F_ | _T_ Our rule for calculation is: For _T_ put _F_; for _F_ put _T_. Of course, exactly the same rule applies to statements 2 and 4 (see Table 2). The _T_ and _F_ are called _truth values_. Any meaningful statement can have truth values. This type of table is called a _truth table_. For any logical pattern, we can make up a truth table. Let us take another example, “AND.” Statement 5 is the same as statement 1 AND statement 2. How can we calculate the logical truth of statement 5? We can make up the same sort of a table as before. On the left-hand side of this table, there will be 4 cases: 1. Statement 1 true, statement 2 true. 2. Statement 1 false, statement 2 true. 3. Statement 1 true, statement 2 false. 4. Statement 1 false, statement 2 false. On the right-hand side of this table, we shall put down the truth value of statement 5. Statement 5 is true if both statements 1 and 2 are true; statement 5 is false in the other cases. We know this from our common everyday experience with the meaning of “AND” between statements. So we can set up the truth table, and our rule for calculation of logical truth, in the case of AND, is shown on Table 3. Table 3 1 2 | 1 AND 2 = 5 | _T_ _T_ | _T_ _F_ _T_ | _F_ _T_ _F_ | _F_ _F_ _F_ | _F_ “AND” and the other words and phrases joining together the original two statements to make new statements are called _connectives_, or _logical connectives_. The connectives that we have illustrated in statements 7 to 10 are: OR, IF ··· THEN, IF AND ONLY IF, OR ELSE. Table 4 shows the truth table that applies to statements 7, 8, 9, and 10. This truth table expresses the calculation of the logical truth or falsity of these statements. Table 4 1 IF AND 1 OR 2 IF 1, THEN 2 ONLY IF 2 1 OR ELSE 2 1 2 | = 7 = 8 = 9 = 10 | _T_ _T_ | _T_ _T_ _T_ _F_ _F_ _T_ | _T_ _T_ _F_ _T_ _T_ _F_ | _T_ _F_ _F_ _T_ _F_ _F_ | _F_ _T_ _T_ _F_ The “OR” (as in statement 7) that is defined in the truth table is often called the _inclusive “or”_ and means “AND/OR.” Statement 7, “1 OR 2,” is considered to be the same as “1 OR 2 OR BOTH.” There is another “OR” in common use, often called the _exclusive “or,”_ meaning “OR ELSE” (as in statement 10). Statement 10, “1 OR ELSE 2,” is the same as “1 OR 2 BUT NOT BOTH” or “EITHER 1 OR 2.” In ordinary English, there is some confusion over these two “OR’s.” Usually we rely on the context to tell which one is intended. Of course, such reliance is not safe. Sometimes we rely on a necessary conflict between the two statements connected by “OR” which prevents the “both” case from being possible. In Latin the two kinds of “OR” were distinguished by different words, _vel_ meaning “AND/OR,” and _aut_ meaning “OR ELSE.” The “IF ··· THEN” that is defined in the truth table agrees with our usual understanding that (1) when the “IF clause” is true, the “THEN clause” must be true; and (2) when the “IF clause” is false, the “THEN clause” may be either true or false. The “IF AND ONLY IF” that is defined in the truth table agrees with our usual understanding that (1) if either clause is true, the other is true; and (2) if either clause is false, the other is false. In statement 6, there are only two possible cases, and the truth table is shown in Table 5. Table 5 1 | 1 AND 1 = 6 | _T_ | _T_ _F_ | _F_ We know that 6 is true if and only if 1 is true. In other words, the statement “1 AND 1 IF AND ONLY IF 1” is true, no matter what statement 1 may refer to. It is because of this fact that we never use a statement in the form “1 and 1”: it can always be replaced by the plain statement “1.” LOGICAL-TRUTH CALCULATION BY EXAMINING CASES AND REASONING Now you may say that this is all very well, but what good is it? Almost anybody can use these connectives correctly and certainly has had a great deal of practice using them. Why do we need to go into truth values and truth tables? When we draft a contract or a set of rules, we often have to consider several conditions that give rise to a number of cases. We must avoid: 1. All _conflicts_, in which two statements that disagree apply to the same case. 2. All _loopholes_, in which there is a case not covered by any statement. If we have one statement or condition only, we have to consider 2 possible cases: the condition satisfied or the statement true; the condition not satisfied or the statement false. If we have 2 conditions, we have to consider 4 possible cases: true, true; false, true; true, false; false, false. If we have 3 conditions, we have to consider 8 possible cases one after the other (see Table 6). Table 6 CASE 1ST CONDITION 2ND CONDITION 3RD CONDITION 1 _T_ _T_ _T_ 2 _F_ _T_ _T_ 3 _T_ _F_ _T_ 4 _F_ _F_ _T_ 5 _T_ _T_ _F_ 6 _F_ _T_ _F_ 7 _T_ _F_ _F_ 8 _F_ _F_ _F_ Instead of _T_’s and _F_’s, we would ordinarily use _check-marks_ (✓) and _crosses_ (✕), which, of course, have the same meaning. We may consider and study each case individually. In any event, we must make sure that the proposed contract or set of rules covers all the cases without conflicts or loopholes. The number of possible cases that we have to consider doubles whenever one more condition is added. Clearly, it soon becomes too much work to consider each case individually, and so we must turn to a second method, thoughtful classifying and reasoning about classes of cases. Now suppose that the number of conditions increases: 4 conditions give rise to 16 possible cases; 5, 6, 7, 8, 9, 10, ··· conditions give rise to 32, 64, 128, 256, 512, 1024, ··· cases respectively. Because of the large number of cases, we soon begin to make mistakes while reasoning about classes of cases. We need a more efficient way of knowing whether all cases are covered properly. LOGICAL-TRUTH CALCULATION BY ALGEBRA One of the more efficient ways of reasoning is often called the _algebra of logic_. This algebra is a part of a new science called _mathematical logic_. Mathematical logic is a science that has the following characteristics: It studies chiefly nonnumerical reasoning. It seeks accurate meanings and necessary consequences. Its chief instruments are efficient symbols. Mathematical logic studies especially the logical relations expressed in such words as “or,” “and,” “not,” “else,” “if,” “then,” “only,” “the,” “of,” “is,” “every,” “all,” “none,” “some,” “same,” “different,” etc. The algebra of logic studies especially only the first seven of these words. The great thinkers of ancient Greece first studied the problems of logical reasoning as these problems turned up in philosophy, psychology, and debate. Aristotle originated what was called _formal logic_. This was devoted mainly to variations of the logical pattern shown above called the syllogism. In the last 150 years, the fine symbolic techniques developed by mathematicians were applied to the problems of the calculation of logical truth, and the result was mathematical logic, much broader and much more powerful than formal logic. A milestone in the development of mathematical logic was _The Laws of Thought_, written by George Boole, a great English mathematician, and published in 1854. Boole introduced the branch of mathematical logic called the algebra of logic, also called _Boolean algebra_. In late years, all the branches of mathematical logic have been improved and made easier to use. We can give a simple numerical example of Boolean algebra and how it can calculate logical truth. Suppose that we take the truth value of a statement as 1 if it is true and 0 if it is false. Now we have numbers 1 and 0 instead of letters _T_ and _F_. Since they are numbers, we can add them, subtract them, and multiply them. We can also make up simple numerical formulas that will let us calculate logical truth. If _P_ and _Q_ are statements, and if _p_ and _q_ are their truth values, respectively, we have Table 7. Table 7 STATEMENT TRUTH VALUE NOT-_P_ 1 - _p_ _P_ AND _Q_ _pq_ _P_ OR _Q_ _p_ + _q_ - _pq_ IF _P_, THEN _Q_ 1 - _p_ + _pq_ _P_ IF AND ONLY IF _Q_ 1 - _p_ - _q_ + 2_pq_ _P_ OR ELSE _Q_ _p_ + _q_ - 2_pq_ For example, suppose that we have two statements _P_ and _Q_: _P_: John Doe is eligible for insurance. _Q_: John Doe requires a medical examination. To test that the truth value of “_P_ OR _Q_” is _p_ + _q_-_pq_, let us put down the four cases, and calculate the result (see Table 8). Table 8 _p_ _q_ | _p_ + _q_ - _pq_ | 1 1 | 1 + 1 - 1 = 1 0 1 | 0 + 1 - 0 = 1 1 0 | 1 + 0 - 0 = 1 0 0 | 0 + 0 - 0 = 0 Now we know that _P_ or _Q_ is true if and only if either one or both of _P_ and _Q_ are true, and thus we see that the calculation is correct. The algebra of logic (see also Supplement 2) is a more efficient way of calculating logical truth. But it is still a good deal of work to use the algebra. For example, if we have 10 conditions, we shall have 10 letters like _p_, _q_ to handle in calculations. Thus we need a still more efficient way. CALCULATION OF CIRCUITS BY THE ALGEBRA OF LOGIC In 1937 a research assistant at Massachusetts Institute of Technology, Claude E. Shannon, was studying for his degree of master of science. He was enrolled in the Department of Electrical Engineering. He was interested in automatic switching circuits and wondered why an algebra should not apply to them. He wrote his thesis on the answer to this question and showed that: (1) There is an algebra that applies to switching circuits. (2) It is the algebra of logic. A paper, based on his thesis, was published in 1938 in the _Transactions of the American Institute of Electrical Engineers_ with the title “A Symbolic Analysis of Relay and Switching Circuits.” [Illustration: FIG. 1. Switches in series.] For a simple example of what Shannon found out, suppose that we have two switches, 1, 2, in series (see Fig. 1). When do we get current flowing from the source to the sink? There are 4 possible cases and results (see Table 9). Table 9 SWITCH 1 IS CLOSED SWITCH 2 IS CLOSED CURRENT FLOWS Yes Yes Yes No Yes No Yes No No No No No Now what does this table remind us of? It is precisely the truth table for “AND.” It is just what we would have if we wrote down the truth table of the statement “Switch 1 is closed AND switch 2 is closed.” [Illustration: FIG. 2. Switches in parallel.] [Illustration: FIG. 3. Switch open—current flowing.] Suppose that we have two switches 1, 2 in parallel (see Fig. 2). When do we get current flowing from the source to the sink? Answer: when either one or both of the switches are closed. Therefore, this circuit is an exact representation of the statement “Switch 1 is closed or switch 2 is closed.” Suppose that we have a switch that has two positions, and at any time must be at one and only one of these two positions (see Fig. 3). Suppose that current flows only when the switch is open. There are two possible cases and results (see Table 10). Table 10 SWITCH 1 IS CLOSED CURRENT FLOWS Yes No No Yes This is like the truth table for “NOT”; and this circuit is an exact representation of the statement “Switch 1 is NOT closed.” (_Note_: These examples are in substantial agreement with Shannon’s paper, although Shannon uses different conventions.) We see, therefore, that there is a very neat correspondence between the algebra of logic and automatic switching circuits. Thus it happens that: 1. The algebra of logic can be used in the calculation of some electrical circuits. 2. Some electrical circuits can be used in the calculations of the algebra of logic. This fact is what led to the next step. LOGICAL-TRUTH CALCULATION BY MACHINE In 1946 two undergraduates at Harvard University, Theodore A. Kalin and William Burkhart, were taking a course in mathematical logic. They noticed that there were a large number of truth tables to be worked out. To work them out took time and effort and yet was a rather tiresome automatic process not requiring much thinking. They had had some experience with electrical circuits. Knowing of Shannon’s work, they said to each other, “Why not build an electrical machine to calculate truth tables?” They took about two months to decide on the essential design of the machine: 1. The machine would have dial switches in which logical connectives would be entered. 2. It would have dial switches in which the numbers of statements like 1, 2, 3 ··· would be entered. 3. It would scan the proper truth table line by line by sending electrical pulses through the dial switches. 4. It would compute the truth or falsehood of the whole expression. CONSTRUCTION AND COMPLETION OF THE KALIN-BURKHART LOGICAL-TRUTH CALCULATOR With the designs in mind, Kalin and Burkhart bought some war surplus materials, including relays, switches, wires, lights, and a metal box about 30 inches long by 16 inches tall, and 13 inches deep. From March to June, 1947, they constructed a machine in their spare time, assembling and mounting the parts inside the box. The total cost of materials was about $150. In June the machine was demonstrated in Cambridge, Mass., before several logicians and engineers, and in August it was moved for some months to the office of a life insurance company. There some study was made of the possible application of the machine in drafting contracts and rules. GENERAL ORGANIZATION OF THE MACHINE The logical-truth calculator built by Kalin and Burkhart is not giant in size, although giant in capacity. Like other mechanical brains, the machine is made up of many pieces of a rather small number of different kinds of parts. The machine contains about 45 dial switches, 23 snap switches (or two-position switches), 85 relays, 6 push buttons, less than a mile of wire, etc. The lid of the metal box is the front, vertical panel of the machine. UNITS OF THE MACHINE The machine contains 16 units. These units are listed in Table 11, in approximately the order in which they appear on the front panel of the machine—row by row from top to bottom, and from left to right in each row. Table 11 UNITS, THEIR NAMES, AND SIGNIFICANCE UNIT ROW PART NO. MARK NAME SIGNIFICANCE 1 1 Small red 12 — _Statement truth-_ Output: glows if lights _value lights_ statement is assumed true in the case 2 1 2-position 12 ~ _Statement denial_ Input: if up, snap switches _switches_ statement is denied 3 2 14-position 12 _V_ _Statement_ Input of dial switches _switches_ statements 4 3 4-position 11 _k_ _Connective_ Input of dial switches _switches_ connectives: ∧ (and), ∨ (or), ▲ (if-then), ▼ (if and only if) 5 4 11-position 11 _A_ _Antecedent_ Input of dial switches _switches_ antecedents 6 5 11-position 11 _C_ _Consequent_ Input of dial switches _switches_ consequents 7 6 2-position 11 _S_ _Stop switches_ Input: if up, snap switches associates connective to main truth-value light 8 6 2-position 11 ~ _Connective denial_ Input: if up, snap switches _switches_ statement produced by connective is denied 9 7 Red light and 1 Start _Automatic start_ Input: causes the large button calc. to start down a truth table automatically 10 7 Red light and 1 Start _Power switch_ Input: turns the 2 buttons Stop power on or off 11 7 2-position 1 Stop “_Stop-on-true-or-_ Input: causes the snap switch _false_” _switch_ calc.to stop and red either on true button cases or on false cases 12 7 Yellow light 1 — _Main truth-value_ Output: glows if _light_ the statement produced by the main connective is true for the case 13 7 Large button 1 Man. _Manual pulse_ Input: causes the Pulse _button_ calc. to go to the next line of a truth table 14 7 11-position 1 _kⱼ_ _Connective check_ Output: glows when dial switch _switch and light_ any specified connective is true 15 7 13-position 1 TT “_Truth-table-row-_ Input: causes the dial switch Row _stop_” _switch_ calc. to stop on Stop last row of the the truth table 16 Be- Continuous 1 — _Timing control_ Input: controls the tween dial knob _knob_ speed at which 6 & 7 and button the calculator scans rows of the truth table Some of the words appearing in this table need to be defined. _Connective_ here means “AND,” “OR,” “IF ··· THEN,” “IF AND ONLY IF.” Only these four connectives appear on the machine; others when needed can be constructed from these. The symbols used for these connectives in mathematical logic are ∧, ∨, ▲, ▼. These signs serve as labels for the connective switch points. In this machine, when there is a connective between two statements, the statement that comes before is called the _antecedent_ and the statement that comes after is called the _consequent_. HOW INFORMATION GOES INTO THE MACHINE Of the 16 units 13 are input units. They control the setup of the machine so that it can solve a problem. Of the 13 input units, those that have the most to do with taking in the problem are shown in Table 12. Table 12 Name of KIND OF UNIT SWITCHES MARK SWITCH SWITCH SETTINGS 3 Statement _V_₁ to Dial Statements 1 to 12 or constant _V_₁₂ _T_ or _F_ 2 Statement ~ Snap Affirmative (down) or negative denial (up) 4 Connective _k_₁ to Dial ∧ (AND), _k_₁₁ ∨ (OR), ▲ (IF-THEN), ▼ (IF AND ONLY IF) 8 Connective ~ Snap Affirmative (down) or negative denial (up) 5 Antecedent _A_₁ to Dial _V_ or various _k_’s _A_₁₁ 6 Consequent _C_₁ to Dial _V_ or various _k_’s _C_₁₁ 7 Stop _S_₁ to Snap Not connected (down) or _S_₁₁ connected (up) The first step in putting a problem on the machine is to express the whole problem as a single compound statement that we want to know the truth or falsity of. We express the single compound statement in a form such as the following: _V k V k V k V k V k V k V k V k V k V k V k V_ where each _V_ represents a statement, each _k_ represents a connective, and we know the grouping, or in other words, we know the antecedent and consequent of each connective. For example, let us choose a problem with an obvious answer: PROBLEM. Given: statement 1 is true; and if statement 1 is true, then statement 2 is true; and if statement 2 is true, then statement 3 is true; and if statement 3 is true, then statement 4 is true. Is statement 4 true? How do we express this whole problem in a form that will go on the machine? We express the whole problem as a single compound statement that we want to know the truth or falsity of: If [1 and (if 1 then 2) and (if 2 then 3) and (if 3 then 4)], then 4 The 8 statements occurring in this problem are, respectively: 1 1 2 2 3 3 4 4. These are the values at which the _V_ switches (the statement dial switches, Unit 2) from _V_₁ to _V_₈ are set. The 7 connectives occurring in this problem are, respectively: AND, IF-THEN, AND, IF-THEN, AND, IF-THEN, IF-THEN. These are the values at which the _k_ switches (the connective dial switches, Unit 4) from _k_₁ to _k_₇ are set. A grouping (one of several possible groupings) that specifies the antecedent and consequent of each connective is the following: 1 AND 1 IF-THEN 2 AND 2 IF-THEN 3 AND 3 IF-THEN 4 IF-THEN 4 | | | | | | +—————————+ +—————————+ +—————————+ _k_₂ _k_₄ _k_₆ | | | | +———————————————+ +—————————————————————————+ _k_₁ _k_₅ | | +———————————————————————————————————————————————+ _k_₃ | | +—————————————————————————————————————————————————————————+ _k_₇ The grouping has here been expressed graphically with lines but may be expressed in the normal mathematical way with parentheses and brackets as follows: {[1 AND (1 IF-THEN 2)] AND [(2 IF-THEN 3) AND (3 IF-THEN 4)]} IF-THEN 4. So the values at which the antecedent and consequent dial switches are set are as shown in Table 13. Table 13 ANTECEDENT CONSEQUENT CONNECTIVE SWITCH SET AT SWITCH SET AT _k_₁ _A_₁ _V_ _C_₁ _k_₂ _k_₂ _A_₂ _V_ _C_₂ _V_ _k_₃ _A_₃ _k_₁ _C_₃ _k_₅ _k_₄ _A_₄ _V_ _C_₄ _V_ _k_₅ _A_₅ _k_₄ _C_₅ _k_₆ _k_₆ _A_₆ _V_ _C_₆ _V_ _k_₇ _A_₇ _k_₃ _C_₇ _V_ In any problem, statements that are different are numbered one after another 1, 2, 3, 4 ···. A statement that is repeated bears always the same number. In nearly all cases that are interesting, there will be repetitions of the statements. If any statement appeared with a “NOT” in it, we would turn up the denial switch for that statement (Unit 2). The different connectives available on the machine are “AND,” “OR,” “IF ··· THEN,” “IF AND ONLY IF.” If a “NOT” affected the compound statement produced by any connective, we would turn up the denial switch for that connective (Unit 8). The last step in putting the problem on the machine is to connect the main connective of the whole compound statement to the yellow light output (Unit 12). In this problem the last “IF-THEN,” _k_₇, is the main connective, the one that produces the whole compound statement. So we turn Stop Switch 7 (in Unit 7) that belongs to _k_₇ into the up position. There are a few more things to do, naturally, but the essential part of putting the information of the problem into the machine has now been described. HOW INFORMATION COMES OUT OF THE MACHINE Of the 16 units listed in Table 11, 3 are output units, and only 2 of these are really important, as shown in Table 14. Table 14 UNIT NAME OF LIGHT MARK KIND OF LIGHT 1 Statement truth value _V_₁ to _V_₁₂ Small, red 13 Main truth value Large, yellow The answer to a problem is shown by a pattern of the lights of Units 1 and 13. The pattern of lights is equivalent to a row of the truth table. Each little red light (Unit 1) glows when its statement is assumed to be true, and it is dark when its statement is assumed to be false. The yellow light (Unit 13) glows when the whole compound statement is calculated to be logically true, and it is dark when the whole compound statement is calculated to be logically false. The machine turns its “attention” automatically to each line of the truth table one after the other, and pulses are fed in according to the pattern of assumed true statements. We can set the machine to stop on true cases or on false cases or on every case, so as to give us time to copy down whichever kind of results we are interested in. When we have noted the case, we can press a button and the machine will then go ahead searching for more cases. A COMPLETE AND CONCRETE EXAMPLE The reader may still be wondering when he will see a complete and concrete example of the application of the logical-truth calculator. So far we have given only pieces of examples in order to illustrate some explanation. Therefore, let us consider now the following problem: PROBLEM. The A. A. Adams Co., Inc., has about 1000 employees. About 600 of them are insured under a contract for group insurance with the I. I. Insurance Co. Mr. Adams decides that more of his employees ought to be insured. As a part of his study of the change, he asks his manager in charge of the group insurance plan, “What are the possible statuses of my employees who are not insured?” The manager replies, “I can tell you the names of the men who are not insured, and all the data you may want to know about them.” Mr. Adams says, “No, John, that won’t be enough, for I need to know whether there are any groups or classes that for some basic reason I should exclude from the change I am considering.” So the manager goes to work with the following 5 statuses and the following 5 rules, and he produces the following answer. Our question is, “Is he right, or has he made a mistake?” _Statuses._ A status for any employee is a report about that employee, answering all the following 5 questions with “yes” or “no.” 1. Is the employee eligible for insurance? 2. Has the employee applied for insurance? 3. Has the employee’s application for insurance been approved? 4. Does the employee require a medical examination for insurance? 5. Is the employee insured? _Rules._ The rules applying to employees are: _A._ Any employee, to be insured, must be eligible for insurance, must make application for insurance, and must have such application for insurance approved. _B._ Only eligible employees may apply for insurance. _C._ The application of any person eligible for insurance without medical examination is automatically approved. _D._ (Naturally) an application can be approved only if the application is made. _E._ (Naturally) a medical examination will not be required from any person not eligible for insurance. _Answer by the Manager._ There are 5 possible combinations of statuses for employees who are not insured, as shown in Table 15. Table 15 POSSIBLE STATUS 3, STATUS 4, COMBINATION STATUS 1, STATUS 2, APPLICATION EXAMINATION STATUS 5, OF STATUSES ELIGIBLE APPLIED APPROVED REQUIRED INSURED 1 Yes Yes Yes Yes No 2 Yes Yes Yes No No 3 Yes Yes No Yes No 4 Yes No Yes No No 5 No No No No No The question may be asked why employees who are eligible, who have applied for insurance, who have had their applications approved, and who require no medical examination (combination 2) are yet not insured. The answer is that the rules given do not logically lead to this conclusion. As a matter of fact, there might be additional rules, such as: any sick employee must first return to work; or any period from date of approval of application to the first of the following month must first pass. The first step in putting this problem on the Kalin-Burkhart Logical-Truth Calculator is to rephrase the rules, using the language of the connectives that we have on the machine. The rules rephrased are: _A._ If an employee is insured, then he is eligible, he has applied for insurance, and his application has been approved. IF 5, THEN 1 AND 2 AND 3 _B._ If an employee has applied (under these rules) for insurance, then he is eligible. IF 2, THEN 1 _C._ If an employee is eligible for insurance, has applied, and requires no medical examination, his application is automatically approved. IF 1 AND 2 AND NOT-4, THEN 3 _D._ If an employee’s application has been approved, then he has applied. IF 3, THEN 2 _E._ If an employee is not eligible, then he does not require a medical examination (under these rules). IF NOT-1, THEN NOT-4 To get the answer we seek, we must add one more rule _for this answer only_: _F._ The employee is not insured. NOT-5 We now have a total of 4 + 2 + 4 + 2 + 2 + 1 occurrences of statements, or 15 occurrences. This is beyond the capacity of the existing machine. But fortunately Rule _F_ and Rule _A_ cancel each other; they may both be omitted; and this gives us 10 occurrences instead of 15. In other words, all the possible statuses under “Rule _B_ AND Rule _C_ AND Rule _D_ AND Rule _E_” will give us the answer we seek. The rephrasing and reasoning we have done here is perhaps not easy. For example, going from the logical pattern Only igs may be ows to the logical pattern If it is an ow, then it is an ig as we did in rephrasing Rule _B_, deserves rather more thought and discussion than we can give to the subject here. A person who is responsible for preparing problems for the Logical-Truth Calculator should know the algebra of logic. Choosing an appropriate grouping, we now set on the machine: {(IF 2, THEN 1) AND [IF (1 AND 2) AND NOT-4, THEN 3]} AND [(IF 3, THEN 2) AND (IF NOT-1, THEN NOT-4)] The setting is as shown in Table 16. After this setting, the machine is turned on and set to stop on the “true” cases. The Table 16 SETTING OF THE PROBLEM ON THE LOGICAL-TRUTH CALCULATOR UNIT 3 Statement Dial No. _V_₁ _V_₂ _V_₃ _V_₄ _V_₅ _V_₆ 3 Statement Dial Setting 2 1 1 2 4 3 2 Statement Denial Switch Setting — — — — up — 4 Connective Dial No. _k_₁ _k_₂ _k_₃ _k_₄ _k_₅ _k_₆ 4 Connective Dial Setting ▲ ∧ ∧ ∧ ▲ ∧ 8 Connective Denial Switch Setting — — — — — — 5 Antecedent Dial No. _A_₁ _A_₂ _A_₃ _A_₄ _A_₅ _A_₆ 5 Antecedent Dial Setting _V_ _k_₁ _V_ _k_₃ _k_₄ _k_₂ 6 Consequent Dial No. _C_₁ _C_₂ _C_₃ _C_₄ _C_₅ _C_₆ 6 Consequent Dial Setting _V_ _k_₅ _V_ _V_ _V_ _k_₈ 7 Stop Switches, associating connective to Main Truth-Value Light — — — — — up ----------------------------------------------------------------- 3 Statement Dial No. _V_₇ _V_₈ _V_₉ _V_₁₀ _V_₁₁ _V_₁₂ 3 Statement Dial Setting 3 2 1 4 _F_ _F_ 2 Statement Denial Switch Setting — — up up — — 4 Connective Dial No. _k_₇ _k_₈ _k_₉ _k_₁₀ _k_₁₁ 4 Connective Dial Setting ▲ ∧ ▲ off off 8 Connective Denial Switch Setting — — — — — 5 Antecedent Dial No. _A_₇ _A_₈ _A_₉ _A_₁₀ _A_₁₁ 5 Antecedent Dial Setting _V_ _k_₇ _V_ off off 6 Consequent Dial No. _C_₇ _C_₈ _C_₉ _C_₁₀ _C_₁₁ 6 Consequent Dial Setting _V_ _k_₉ _V_ off off 7 Stop Switches, associating connective to Main Truth-Value Light — — — — — possible statuses of employees who are not insured are shown in Table 17. As we look down the last column in Table 17, we observe 6 occurrences of _T_, instead of 5 as the manager determined (see Table 15). Thus, when we compare the manager’s result with the machine result, we find an additional possible combination to be reported to Mr. Adams, combination 7: Employee eligible, employee has not applied, employee’s application not approved, employee requires a medical examination, employee not insured. Table 17 SOLUTION OF THE PROBLEM BY THE CALCULATOR LEGEND: {A} THE EMPLOYEE IS ELIGIBLE FOR INSURANCE {B} THE EMPLOYEE HAS APPLIED FOR INSURANCE {C} THE EMPLOYEE’S APPLICATION FOR INSURANCE HAS BEEN APPROVED {D} THE EMPLOYEE REQUIRES A MEDICAL EXAMINATION {E} THE EMPLOYEE IS INSURED {F} CASE, OR COMBINATION NO. {G} THE COMBINATION DOES NOT CONTRADICT THE RULES, I.E., THE YELLOW LIGHT IS ON {A} {B} {C} {D} {E} {F} {G} _Status_: 1 2 3 4 5 _T_ _T_ _T_ _T_ _F_ 1 _T_ _F_ _T_ _T_ _T_ _F_ 2 _F_ _T_ _F_ _T_ _T_ _F_ 3 _F_ _F_ _F_ _T_ _T_ _F_ 4 _F_ _T_ _T_ _F_ _T_ _F_ 5 _T_ _F_ _T_ _F_ _T_ _F_ 6 _F_ _T_ _F_ _F_ _T_ _F_ 7 _T_ _F_ _F_ _F_ _T_ _F_ 8 _F_ _T_ _T_ _T_ _F_ _F_ 9 _T_ _F_ _T_ _T_ _F_ _F_ 10 _F_ _T_ _F_ _T_ _F_ _F_ 11 _F_ _F_ _F_ _T_ _F_ _F_ 12 _F_ _T_ _T_ _F_ _F_ _F_ 13 _F_ _F_ _T_ _F_ _F_ _F_ 14 _F_ _T_ _F_ _F_ _F_ _F_ 15 _T_ _F_ _F_ _F_ _F_ _F_ 16 _T_ Because of the medical examination, this additional class of employee would need to be considered rather carefully in any change of the group insurance plan. AN APPRAISAL OF THE CALCULATOR In appraising the Kalin-Burkhart Logical-Truth Calculator, we must remember that this is a first model. It was the only machine of its kind up to the end of 1948; and it worked. The cost of the machine, as stated before, was about $150 of parts and perhaps $1000 of labor. This is less than ¹/₁₀₀ of the cost of the other giant brains described in previous chapters. Yet we can properly call this machine a mechanical brain because it transfers information automatically from one part to another of the machine, has automatic control over the sequence of operations, and does certain kinds of reasoning. The machine is swift. It can check up to a 100 cases against a set of rules in less than 1 minute. It can check: 128 cases for 7 conditions in 1¼ minutes, 256 cases for 8 conditions in 2½ minutes, and 4096 cases for 12 conditions in 38 minutes. That is the limit of the present machine. Of course, setting up the machine to do a problem takes some more time. The programming of this machine to do a problem is less complicated than the programming of most of the big machines previously described. Of course, in order to prepare a problem for the machine, the preparer needs to know a fair amount of the algebra of logic. This, however, is not very hard. As to reliability, the machine has in practice been out of order less than 2 per cent of operating time. The big barrier to wide use of the machine, of course, is lack of understanding of the field of problems in which it can be applied. Even in this modern world of ours, we are in rather a primitive stage in regard to recognizing problems in logical truth and knowing how to calculate it. Here, however, is an electrical instrument for logical reasoning, and it seems likely that its applications will multiply. Chapter 10 AN EXCURSION: THE FUTURE DESIGN OF MACHINES THAT THINK In the previous chapters we have described four giant mechanical brains finished by the end of 1946: Massachusetts Institute of Technology’s Differential Analyzer No. 2, Harvard’s IBM Automatic Sequence-Controlled Calculator, Moore School of Electrical Engineering’s Electronic Numerical Integrator and Calculator (Eniac), and Bell Telephone Laboratories’ General-Purpose Relay Computer. All these brains have actually worked long enough to have demonstrated thoroughly some facts of great importance. WHAT EXISTING MACHINES HAVE PROVED The existing mechanical brains have proved that information can be automatically transferred between any two registers of a machine. No human being is needed to pick up a physical piece of information produced in one part of the machine, personally move it to another part of the machine, and there put it in again. We can think of a mechanical brain as something like a battery of desk calculators or punch-card machines all cabled together and communicating automatically. The existing mechanical brains have also proved that flexible, automatic control over long sequences of operations is possible. We can lay out the whole routine to solve a problem, translate it into machine language, and put it into the machine. Then we press the “start” button; the machine starts whirring and prints out the answers as it obtains them. Mechanical brains have removed the limits on complexity of routine: the machine can carry out a complicated routine as easily as a simple one. The existing giant brains have shown that a machine with hundreds of thousands of parts will work successfully. It will operate accurately, it will run unattended, and it will have remarkably few mechanical troubles. These machines have shown that enormous speeds can be realized: 5000 additions a second is Eniac’s record. High speed is needed for many problems in science, government, and business. In fact, there are economic and statistical problems, now settled by armchair methods, for which high-speed mechanical brains may make it possible to compute answers rather than guess them. Also, these machines have been shown to be reasonable in cost. The cost of each of the large calculators is in the neighborhood of $250,000 to $500,000. If we assume a ten-year life, which is conservative, the cost is about $3 to $6 an hour for 24-hour operation. Since each mechanical brain can, for problems for which it is suited, do the work of a hundred human computers, such a machine can save its cost half a dozen times. And these machines are only engineers’ models, built without the advantages of production-line assembly. The cost of giant mechanical brains under design in 1947 and 1948 is in the neighborhood of $100,000 to $200,000. The main reason for the reduction from the previous cost is the use of cheaper automatic memory. As designs improve and charges for research and development are paid off, the cost should continue to go down. NEW DEVICES FOR HANDLING INFORMATION In the laboratories working on new mechanical and electronic brains, scientists are doing a lot of thinking about new devices for handling information. Research into devices for storing information shows that _magnetic wire_ as used in sound recording is a rather good storage medium. Magnetic Wire For example, on a hundredth of an inch of fine steel wire we can “write” a _magnetized spot_ by means of a small “writing” _electromagnet_. The electromagnet is simply some copper wire coiled around some soft iron shaped in a U. When current flows through the coil, the iron becomes a magnet, and the tips of the U magnetize the little section of the wire between them. The magnetized spot can be of two kinds, say north-south or south-north, depending on which way the current flows. We can “read” this difference by means of another small “reading” electromagnet. We can erase the spot by means of a stronger “erasing” magnet that produces a uniform magnetic state throughout the wire. The difference between north-south and south-north corresponds to the difference between 1 and 0, or “yes” and “no,” etc., and is a _unit of information_ (see Chapter 2). Many other variations are possible. For example, the presence or absence of a magnetized spot may be the unit of information, or the “writing,” “reading,” and “erasing” electromagnets all may be the same. Magnetic wire sound recordings made in the 1890’s are still good. This fact shows that magnetic wire may be a more permanent medium for storing information than is paper. Stray magnetic forces are likely to have no harmful effect on information stored on magnetic wire, for these forces would not be strong enough or detailed enough to change greatly the difference between the magnetized spot and its neighboring neutral area. A reel of magnetic wire a mile long and ³/₁₀₀₀ of an inch thick costs about $5. At 80 magnetized spots to the inch, a mile of wire can store about 5 million units of information. Hence, the cost of storing one unit of information is about ¹/₁₀₀₀₀ of a cent. The time needed for changing a magnetized spot from 1 to 0 or from 0 to 1 is about ¹/₁₀₀₀₀ of a second. Magnetic Tape There is, however, a storage device that may be even more useful, and this is _magnetic tape_ (see Fig. 1). The usual size of such tape is ¼ inch wide and 2 or 3 thousandths of an inch thick. Magnetic tape may be made of plastic with magnetic powder all through it, or it may be of paper coated with magnetic powder, or it may be of stainless steel or a magnetic alloy, or it may be of brass or a nonmagnetic alloy coated with a magnetic plating. Magnetic tape has the added advantage that from 4 to 20 channels across the tape can be filled with magnetized spots, and the cost then becomes about ¹/₁₀₀₀₀₀ of a cent per spot. It seems possible that 1000 units of information can be stored in a quarter of a square inch of magnetic tape. This means that more than 1 million units of information can be stored in a cubic inch of space filled with magnetic tape, and about 2 billion units of information in a cubic foot, except that some of the space should be allotted to the reels and other equipment that hold the tape (see Fig. 2). This is closer packing than printed information in the telephone book, and yet with magnetic tape we can get to the information automatically. [Illustration: FIG. 1. Magnetic tape.] [Illustration: FIG. 2. Tape reels.] Think of the enormous files in libraries, government, and business. Think of the problems of space and cost and access which these files imply. We can then see that this new development may well be of extraordinary importance. Mercury Tanks [Illustration: FIG. 3. Mercury tank.] Scientists are investigating other storage devices having still more remarkable properties, but these have the disadvantage that, when the power goes off, the information vanishes. One of these new storage devices is called a _mercury tank_ (see Fig. 3). It consists mainly of a section of iron or steel pipe filled with mercury. At each end of this pipe, touching the mercury, is a thin slab of a crystal of _quartz_. Quartz, which is a common stone, and which nearly all sand is made of, changes its shape when pulsed with electricity. We put a pattern of electrical pulses into the quartz slab at one end of the mercury tank; for example, we could have the pattern 1101 meaning “pulse, pulse, no pulse, pulse.” The electrical pulses going into the quartz slab make the quartz vibrate. Thus ripples are produced in the mercury, and waves in the pattern 1101 meaning “wave, wave, no wave, wave” travel down the tank and strike the quartz slab at the far end. The quartz slab there changes its shape in the rhythm 1101, and it converts the waves back into electrical pulses in the same pattern. Then we take the pulses out of the far end along a wire, make them stronger again with an amplifier, give them the right form again, and feed them back into the front end of the mercury tank. The mercury tank is a clever use of the principle of an _echo_, as when you call across a valley and the rocks answer you back. We can store a pattern of 400 pulses (each a unit of information, a 1 or a 0, and each a millionth of a second in duration), in a mercury tank about 20 inches long. A mercury tank and an echo are examples of _delay lines_—“lines” along which waves are “delayed.” Electrostatic Storage Tube Another of the memory devices being developed is called an _electrostatic storage tube_ (see Fig. 4). This is a big electronic tube with a _screen_ across one end. The screen may be of two layers: one of copper, which conducts electricity, and one of _mica_, a material that does not. In the other end of the tube is a _beam_ of electrons, which we can turn on and off and shoot at any of 2 or 3 thousand specific points or _spots_ on the screen. [Illustration: FIG. 4. Electrostatic storage tube.] There are two sizes of _electric charge_ or quantity of electrons; we can call these 1 and 0. In about a millionth of a second, we can put either size of charge on one of the spots of the screen. With other circuits we can keep it there as long as we want, if the power does not flicker off. We can “remember” perhaps 2 or 3 thousand units of information in one of these electronic tubes. We can read, write, or erase any unit of information in a few millionths of a second. Neither the mercury tank nor the electrostatic storage tube had, by the end of 1947, been put into a working mechanical brain. But there is good reason to believe that they will be successful devices and will open up a new era of speed in storing and referring to information. In fact, several laboratories are developing electronic calculating circuits using these devices which will perform up to 100,000 additions a second or 10,000 multiplications a second. Our minds certainly stagger at the thought of such speeds. NEW OPERATIONS Many kinds of combining operations have already been built into one or more mechanical brains. The operations may be arithmetical: addition, subtraction, multiplication, division, looking up numbers in tables, etc. Or the operations may be logical: comparing, selecting, checking, etc. Additional logical operations will be built into some of the mechanical brains now being constructed: sorting, collating, matching, merging, etc. NEW IDEAS IN PROGRAMMING _Programming_—the way to give instructions to machines—is also being studied in the laboratories. Several new ideas of importance have developed as a result. One idea is that the machine should be able to store its instructions or _program_ or _routine_ in its memory in just the same physical ways as it stores numbers. There is basically no reason why numbers only should be stored in some registers, and instructions only stored in other registers. Another idea is that the machine should have in its permanent memory any subroutine it may need. For example, a subroutine should always be available in the machine for finding _square root_. At any time when a square root was needed, we would only have to call on the machine for the subroutine of square root. The machine would then consult the right part of its memory and carry out the subroutine for square root. A third idea, and one of the most interesting, is that the machine should be able to compute its own instructions. For example, consider a program for finding the product of two _matrices_ (see Supplement 2), each of 100 terms in an array of 10 columns and 10 rows, resulting in a new _matrix_ of 100 terms. The whole program can be made to consist of about 50 orders. Only one of them is “multiply,” and only one of them is “add”; the other orders consist of how to choose expressions to be multiplied or added, etc. Such problems as these are often fascinating to mathematicians, who love to play with the intricate ideas needed. NEW IDEAS IN RELIABILITY Reliability has a number of aspects: 1. No wrong results allowed out of the machine. 2. Few failures. 3. Rapid location of failures. 4. Quick repair or replacement of parts that fail. 5. Easy maintenance. 6. Unattended operation overnight. For example, Bell Laboratories proved that mechanical brains can be built so that no wrong results are allowed to come out. In other words, the machine checks itself all the time as it goes along and stops at once if the check shows that something is wrong. This is likely to be a standard feature of new automatic thinking machinery. The frequency of failures in the machinery being designed in the laboratories may be of the order of one or two mechanical failures a week. For any type of failure an alarm circuit and trouble lights will show what part of the machine needs attention. Plug-in parts for replacement are already in use in at least two of the four mechanical brains described and should be available in all the new machines. It is possible to build a machine that will automatically change from failing equipment to properly functioning equipment. For some years though, this may be too expensive to be reasonable. The use of magnetic tape for storage reduces greatly the number of parts and so increases reliability. For example, instead of 18,000 electronic tubes in an electronic brain, there may be less than 3000. A final degree of reliability is gained when most of the time the machine operates unattended. Then, there is no human operator standing by who may fail to do the correct thing at the moment when the machine needs some attention. In fact, the motto for the room housing a mechanical brain should become, “Don’t think; let the machine do it for you.” Unattended operation from the end of one working day to the beginning of the next, with the machine changing itself from one problem to another problem, has already been proved possible on the Bell Laboratories machine. AUXILIARY DEVICES In order to use a mechanical brain, we have to give it and take from it language that it understands, _machine language_. A mechanical brain that can do 10,000 additions a second can very easily finish almost all its work at once. How can we, slow as we are, keep our friend, the giant brain, busy? We have found so far several answers to this question, none of them yet very good. Devices for preparing input will be very important. For each brain, we shall need a great many of these devices. For, at best, we type at a rate, say, of 4 characters a second, selecting any one of some 38 keys, each of which is equivalent to about 6 units of information. This is about 800 units of information per second. The machine, however, is likely to be able to gulp information from its input mechanism at the amazing rate of 60,000 units of information per second, equal to 75 people typing with no mistakes and no resting. Fortunately, at least some of the time the machine will be busy computing! For an input-preparation device, we may get something that can be fastened to an ordinary typewriter and that will produce magnetic tape agreeing with what is printed by the typewriter. Since the input information must be carefully verified, we shall need a second magnetic tape device such as exists for paper tape on the Bell Laboratories machine: the _processor_. The processor takes two hand-prepared tapes, compares them, reports any differences, and produces a third tape. The third tape copies the two original tapes if they agree, and it receives corrected information as furnished by a girl at a keyboard if the two original tapes disagree. For information already on punch cards, we need an input device that will read punch cards and write on magnetic tape. Where information is on punched paper tape, we need a machine that will read punched paper tape and write on magnetic tape. Problem data, tables of numbers, and routine instructions will go into the mechanical brain. They will all be prepared on regular input devices. The machine will accept information in the form in which it is most convenient for you and me to prepare it. Then, the machine will be instructed to change the information into the form with which it is most convenient for the machine to operate. Many output devices will also be needed, since the machine will be able to produce information very swiftly. These output devices might be cabled to the machine. A kind of traffic control system would govern them. Each will have a magnetic tape that will be loaded up swiftly with information. Then the output device will unload its information more slowly, in any form that we may desire: printing, graphs, film, punch cards, or punched paper tape. The machine is likely to be able to put out information on magnetic tape at the same high speed of 60,000 units of information per second or 10,000 characters per second. But the best printing speed of an electric typewriter is about 10 or 12 characters a second. Card-punching speed is about 130 characters a second. Punch-card tabulator speed can reach a maximum of about 200 characters a second. Thus we see that here, too, we may be snowed under with the information that the giant brain puts out, if we fail to ask the giant only for what we really want. MECHANICAL BRAINS UNDER CONSTRUCTION This chapter would not be complete without mention of the great mechanical brains that were actually under construction at the end of 1947. In power they are intermediate between the machinery now being designed, described in this chapter, and the earlier machines described in the previous chapters of this book. The mechanical brains under construction on December 31, 1947, were: Harvard’s Sequence-Controlled Relay Calculator _Mark II_, constructed at the Harvard Computation Laboratory, tested there July 1947 to January 1948, and delivered to the Naval Proving Ground, Dahlgren, Va., in 1948. The _IBM Selective-Sequence Electronic Calculator_, constructed in the IBM laboratories, Endicott, N. Y., and installed in 1947 at the office of International Business Machines, 590 Madison Ave., New York, N. Y. Moore School of Electrical Engineering’s _EDVAC_ (Electronic Digital Variable Automatic Computer) being constructed partly at Moore School and partly elsewhere, and to be delivered to the Ballistic Research Laboratories, Aberdeen, Md. Harvard’s Sequence-Controlled Electronic Calculator _Mark III_, being constructed at the Harvard Computation Laboratory, and to be delivered to the Naval Proving Ground, Dahlgren, Va. We shall cover briefly (and perhaps a little technically) some of the main features of the first two of these machines; for, during 1948, they began to do problems. The other two had not been finished by the end of 1948 and so would be difficult to describe correctly, for mechanical brains _grow_, and design changes go on until they are finished—and even afterwards. Some information about these machines can be obtained from the organizations referred to above and from reports that should appear from time to time in some of the journals mentioned in Supplement 3. There is also a regular section entitled “Automatic Computing Machinery” in the quarterly _Mathematical Tables and Other Aids to Computation_, where it is likely that current information may be found. Harvard’s Mark II The Harvard Sequence-Controlled Calculator Mark II began to do problems under test during July 1947. This machine is at least twelve times as powerful as Mark I (see Chapter 6) and was constructed entirely by the Harvard Computation Laboratory. The machine contains about 13,000 relays of a new type that will operate reliably within ¹/₁₀₀ of a second. Numbers in the machine are regularly of 10 decimal digits between 1.000,000,000 and 9.999,999,999, inclusive, multiplied by a power of 10 between 1,000,000,000,000,000 and 0.000,000,000,000,001, inclusive. For storage of numbers, the machine has 100 relay registers totaling about 1200 decimal digits. Also, it can consult any one of 8 tape feeds for numbers and any one of 4 tape feeds for instructions. Effectively, the machine can read one number and one instruction from paper tape in ¹/₃₀ of a second. The machine performs all arithmetical and most logical operations. In every second it can carry out 4 multiplications, 8 additions (or subtractions), and 12 transfers. Division is performed by rapid approximation using the other operations. In each second the machine can perform 30 instructions. An instruction is expressed by 6 digits between 0 and 7 which you can select and, in effect, by 3 more digits fixed by the time (within the second) when the machine reads the instruction. For example, in the 9th instruction of the 30 instructions in each second, we can specify a multiplicand. But, if we do not want to multiply right then—a rare event if we are coding wisely—we leave the 9th instruction empty. The machine may operate as a whole, attending to one problem; or the machine may be separated into halves, and each half will attend to its own problem. The IBM Selective-Sequence Electronic Calculator The IBM Selective-Sequence Electronic Calculator was announced publicly on January 27, 1948, after some months of trial running. It is a large and powerful mechanical brain, and it is the intention of International Business Machines to devote it to solving scientific problems. The staff of the Watson Scientific Computing Laboratory in New York will be mainly in charge of the machine. The machine contains about 12,500 electronic tubes and about 21,500 relays. Numbers in the machine are regularly of either 14 or 19 decimal digits. Instructions are expressed as numbers. For storage of information, the machine has a capacity of 8 registers totaling 160 decimal digits of very rapid memory in electronic tubes. Also, it has about 150 registers totaling 3000 decimal digits of less rapid memory in relays. Also, it can consult any one of 66 paper tape feeds; each row on a paper tape can hold up to 78 punched holes or 19 decimal digits, and the machine can consult 25 rows on one tape in one second. These paper tapes together give the machine about 400,000 decimal digits of memory. For arithmetical and logical operations, the machine has an arithmetical unit using electronic tubes. This unit can carry out about 50 multiplications or about 250 additions per second, including the transfers of numbers. In each second the machine can read and perform 50 instructions, and each instruction consists, usually, of getting two numbers out of two relay registers, performing an operation, and putting the result into a third relay register. Eckert-Mauchly’s Binac As this book went to press, another mechanical brain, the Electronic Binary Automatic Computer, or BINAC, was announced on August 22, 1949. This machine was constructed by the Eckert-Mauchly Computer Corporation, Philadelphia, Pa., for Northrop Aircraft, Inc., Hawthorne, Calif. This machine has some remarkable properties. It does addition or subtraction at the rate of 3500 per second. It does multiplication or division at the rate of 1000 per second. The input is from a keyboard or magnetic tape; the output is to magnetic tape or an electric typewriter. Binac has 512 registers of very rapid memory in mercury tanks, and each register holds 30 binary digits. The machine actually is a pair of twins: the storage, the computing element, and the control are double, and each twin runs in step with the other and checks every operation of the other. In tests in July the machine ran over 10 consecutive hours with no error. Each twin has only 700 electronic tubes. Binac handles all numbers in binary notation, except that the keyboard and the typewriter express numbers in _octal notation_ (see Supplement 2). Finally, Binac is only 5 feet high, 4 feet long, and one foot wide. Chapter 11 THE FUTURE: MACHINES THAT THINK, AND WHAT THEY MIGHT DO FOR MEN The pen is mightier than the sword, it is often said. And if this is true, then the pen with a motor may be mightier than the sword with a motor. In the Middle Ages, there were few kinds of weapons, and it was easy for a man to protect himself against most of them by wearing armor. As gunpowder came into use, a man could no longer carry the weight of armor that would protect him, and so armor was given up. But in 1917, armor, equipped with a motor and carrying the man and his weapons, came back into service—as the tank. In much the same way, in the Middle Ages, there were few books, and it was easy for a man to handle nearly all the information that was in books. As the printing press came into use, man’s brain could no longer handle all recorded information, and the effort to do so was given up. But in 1944, a brain to handle information, equipped with a motor and supporting the man and his reasoning, came into existence—as the sequence-controlled calculator. In previous chapters we have examined some of the giant mechanical brains that have been finished; we have also considered the design of such machines. Now in this chapter we shall discuss the future significance of machines that think, of motorized information. We shall discuss what we can foresee if we look with imagination into the future. There are two questions we need to ask: What types of machines that think can we foresee? What types of problems to be solved by these machines can we foresee? FUTURE TYPES OF MACHINES THAT THINK The machines that already exist show that some processes of thinking can already be performed very quickly: Calculating: adding, subtracting,... Reasoning: comparing, selecting,... Referring: looking up information in lists,... We can expect other processes of thinking to come up to high speed through the further development of thinking machines. Automatic Address Book Nowadays when we wish to send out announcements of an event, like going to South America for a year, we may copy the addresses of our friends onto the envelopes by hand. In the future, we can see our address book as a spool of magnetic tape. When we wish to send out announcements, we put a stack of blank envelopes into the machine that will read the magnetic tape, and we press a button. Out will come the envelopes addressed. If we wish to select only those friends of ours whose last names we put down on a list, we can write the list on another magnetic tape, place it also in the machine, and set a few switches. Then the machine will read the names on the list, find their addresses in the address-book tape, and prepare only the envelopes we want. If a friend’s address changes, we can notify the machine. It will find his old address, erase it, and enter the new address. Automatic Library We can foresee the development of machinery that will make it possible to consult information in a library automatically. Suppose that you go into the library of the future and wish to look up ways for making biscuits. You will be able to dial into the catalogue machine “making biscuits.” There will be a flutter of movie film in the machine. Soon it will stop, and, in front of you on the screen, will be projected the part of the catalogue which shows the names of three or four books containing recipes for biscuits. If you are satisfied, you will press a button; a copy of what you saw will be made for you and come out of the machine. After further development, all the pages of all books will be available by machine. Then, when you press the right button, you will be able to get from the machine a copy of the exact recipe for biscuits that you choose. We are not yet at the end of foreseeable development. There will be a third stage. You will then have in your home an automatic cooking machine operated by program tapes. You will stock it with various supplies, and it will put together and cook whatever dishes you desire. Then, what you will need from the library will be a program or routine on magnetic tape to control your automatic cook. And the library, instead of producing a pictorial copy of the recipe for you to read and apply, will produce a routine on magnetic tape for controlling your cooking machine so that you will actually get excellent biscuits! Of course, you may have other kinds of automatic producing machinery in your home or office. The furnishing of routines to control automatic machinery will become a business of importance. Automatic Translator Another machine that we can foresee would be used for translating from one language to any other. We can call it an _automatic translator_. Suppose that you want to say “How much?” in Swedish. You dial into the machine “How much?” and press the button “Swedish,” and the machine will promptly write out “Hur mycket?” for you. It also will pronounce it, if you wish, for there would be little difficulty in recording on magnetic tape the pronunciation of the word as spoken by a good speaker of the language. The machine could be set to repeat the pronunciation several times so that the student could really learn the sound. He could learn it better, probably, by hearing it and trying to say it than he could by using any set of written symbols. Automatic Typist We now come to a possible machine that uses a new principle. This principle is that of being able to _recognize_ signs. This machine would perceive writing on a piece of paper and recognize that all the _a_’s that appear on the paper are cases of _a_, and that all the _b_’s that appear on it are instances of _b_, and so forth. The machine could then control an electric typewriter and copy the marks that it sees. The first stage of this machine would be one in which only printed characters of a high degree of likeness could be recognized. In later stages, handwriting, even rather illegible handwriting, might be recognizable by the machine. We can call it an _automatic typist_. The elements of the automatic typist would be the following: 1. _Phototubes_ (electronic tubes sensitive to the brightness of light), which could sense the difference between black and white (these already exist). 2. A memory of the shapes of 52 letters, 10 digits, and punctuation marks. Fine distinctions would be required of this memory in some cases—like the difference between the numeral 5 and the capital letter S. 3. A control that would cause the machine to _tune_ itself, so that a good matching between the marks it observed and the shapes it remembered would be reached. 4. A _triggering control_ so that, when the machine had reached good enough matching between its observations and its memory, the machine would proceed to identify the marks, read them, and transfer them. 5. An electric typewriter, which would respond to the transferred instructions. (This also already exists.) This machine is perhaps not so farfetched as it might seem. During World War II, gun-aiming equipment using the new technique _radar_ reached a high stage of development. Many shots that disabled and sank enemy ships were fired in total darkness by radar-controlled guns. On the glowing screen in the control room, there were two spots, one that marked the target and one that reported the point at which the gun was aimed. These two spots could be brought almost automatically into agreement. In the same way, a report from a phototube telling the shape of an observed mark and a report from the memory of the machine telling the shape of a similar mark could be compared by the machine for likeness and, if judged enough alike, could be approved as identical. Even the phrase “enough alike” can be applied by a machine. During World War II, tremendous advances were made in machinery for deciphering enemy messages. Machines observed various features and patterns in enemy messages, swiftly counted the frequency of these features, and carried out statistical tests. Then the machines selected those few cases in which the patterns showed meaning instead of randomness. A machine like the automatic typist, if made flexible enough, would be, of course, extremely useful. A great load of dull office work is now being thrown on clerks whose task is to translate from writing and typing into languages that machines can read, such as punch cards. At the present time, if punch-card machines are widely used in a big company, the company must employ large numbers of girls whose sole duty is to read papers and punch up cards. A still bigger chore is the work of typists in all kinds of businesses whose main duty is to read handwriting, etc., and then copy the words on a typewriter. [Illustration: Each square in the grill is watched by a phototube. FIG. 1. Scheme for distinguishing _A_ and _H_ by 15 phototubes.] Research has already begun on various features of the automatic typist because of its obvious labor-saving value. For example, many patents have been issued on schemes for dividing the area occupied by a letter or a digit into an array of spots, with a battery of phototubes each watching a spot. The reports from the phototubes together will distinguish the letter or digit. For example, if we consider _A_ and _H_ placed in a grill of fifteen spots, 5 long by 3 wide (see Fig. 1), then the phototubes can distinguish between _A_ and _H_ by sensing black or white in the spot in the middle of the top row. When we consider how easily and swiftly a human being does this, we can once more marvel at the recognizing machine we all carry around with us in our heads. Automatic Stenographer Another development that we can foresee is one that we can call the _automatic stenographer_. This is a machine that will listen to sounds and write them down in properly spelled English words. The elements of this machine can be outlined: 1. Microphones, which can sense spoken sounds (these already exist). 2. A memory storing the 40 (more or less) phonetic units or sounds that make up English, such as the 23 consonant sounds, _p_ _b_ _l_ _ng_ _f_ _v_ _m_ _th_ _t_ _d_ _n_ _r_ _s_ _z_ _h_ _y_ _k_ _g_ _w_ _ch_ _j_ _sh_ _zh_ (heard in “pleasure”) and the 17 vowel sounds, LONG SHORT OTHER _A_ (“ate”) _a_ (“cat”) _ar_ (“are”) _E_ (“eat”) _e_ (“end”) _aw_ (“awe”) _I_ (“isle”) _i_ (“in”) _er_ (“err”) _O_ (“owe”) _o_ (“on”) _ow_ (“owl”) _U_ (“cute”) _u_ (“up”) _oi_ (“oil”) _OO_ (“roof”) _oo_ (“book”) 3. A collection of the rules of spelling in English, containing many statements like The sound _b_ is always spelled _b_ The sound _sh_ may be spelled _sh_ (ship), _s_ (sugar), _ti_ (station), _ci_ (physician), _ce_ (ocean) or _tu_ (picture) and other statements based on context, word lists, derivation, etc. These are the statements by means of which a good English speller knows how to spell even words that he hears for the first time. 4. A triggering control so that, when the machine reaches good enough matching between its observations of sounds, its memory of sounds, and its knowledge of spelling rules, the machine will identify groups of sounds as words, determine their spelling, and report the letters determined. 5. An electric typewriter, which would type the reported letters. With this type of machine, you would dictate your letters into a machine (now existing) that would record your voice. Then the record would be placed on the automatic stenographer, and out would come your letters written and spaced as they should be. Automatic Recognizer We can foresee a recognizing machine with very general powers. Suppose that we call it an _automatic recognizer_ (see Fig. 2). It will have the following elements: 1. _Input._ This element will consist of a set of observing instruments, capable of perceiving sights, sounds, etc. There will be ways of positioning or _tuning_ these instruments. 2. _Memory._ This element will store knowledge. It may store the patterns of observations that we are interested in; or it may store general rules on how to find patterns of observations that we will be interested in. It will contain knowledge about acceptable groups of patterns, about actions to be performed in response to patterns, etc. 3. _Program 1._ The element “Program 1” performs a set of standard instructions. Under these instructions, the machine: Compares group after group of observations with the information in the memory. Compares these groups with patterns furnished, or seeks to organize the observations into patterns. Counts cases and tests frequencies. Finds out how much matching with patterns there is. Tunes the observing instruments in ways to increase matching. [Illustration: FIG. 2. Scheme of an automatic recognizer.] 4. _Program 2._ The element “Program 2” performs another set of standard instructions. Under these instructions, the machine, if it is tuned well, matches sets of observations one after another with the patterns and so reads them. 5. _Triggering Control._ This element shifts the control of the machine from Program 1 to Program 2. It does this when the machine reaches “good matching.” We shall set the meaning of this into the machine in much the same way as we set “warm” into a thermostat. 6. _Output._ This element performs any action that we want, depending on recognized patterns read and any other knowledge or instructions stored in the memory. The automatic recognizer will be capable of extraordinary tasks. With microphones and a large memory, this type of machine would be able to hear a foreign language spoken and translate it into spoken or written English. With phototubes and with an expanded filtering and decoding capacity as in deciphering machines, the automatic recognizer should be able to read a dead language, even those (such as Minoan or Etruscan) that have so far resisted efforts to read it. The machine would derive rules for the translation of the language and translate any sample. An automatic recognizer could perhaps be equipped with many sensitive, tiny observing instruments that could be placed around or in the brain and nervous systems of animals. Then the machine might enable us to find out what activity in the nervous system corresponds with what activity in the animal. TYPES OF PROBLEMS THAT MACHINES WILL SOLVE IN THE FUTURE We turn now to the second question regarding the future of machines that think: What types of problems can we foresee as solved by these machines? Problems of Control Probably the foremost problem which machines that think can solve is automatic control over all sorts of other machines. This involves controlling a machine that is running so that it will do the right thing at the right time in response to information. For example, suppose that you are mowing a lawn with a mowing machine. You watch the preceding strip so as to stay next to it. You watch the ends of the strips, where you turn around. If a stick is caught in the cutting blade, you stop and take it out. Now it is entirely possible to put devices on the mowing machine so that all these things will be taken care of automatically. In fact, in the case of plowing a large field, a tractor-plow can be equipped with a device that guides it next to the preceding furrow. Thus, once the first furrow around the edge has been made, riderless tractors will plow a whole field and stop in the middle. For another example, take a gas furnace for heating steam to keep a house warm. Such a furnace has automatic controls, which respond to the following information whenever reported: House too warm. House not warm enough. Too much steam pressure. Not enough water in boiler. Gas flame not lit. Daytime. Nighttime. In fact, your own meaning of “warm” can be put into the control system: you set the dial on your thermostat at the temperature that “warm” is to be for you. In the future many kinds of automatic control will be common. We shall have automatic pilots for flying and landing airplanes. We shall have automatic missiles for destructive purposes, such as bombing and killing, and for constructive purposes, such as delivering mail and fast freight. An article in the magazine _Fortune_ for November 1946 described the automatic factory (see Supplement 3). This is a factory in which there would be automatic arms for holding stuff being manufactured, and automatic feed lines for supplying material just where it is needed. All this factory would be controlled by machines that handle information automatically and produce actions that respond to information. This prospect fills us with concern as well as with amazement. How shall we control these automatic machines, these robots, these Frankensteins? What will there be left for us to do to earn our living? But more of this in the next chapter. Problems of Science Other problems for which we can foresee the use of machines that think are the understanding, and later the controlling, of nature. One of these problems is weather forecasting and weather control. The Weather Brain We can imagine the following type of machine—a _weather brain_. A thousand weather observatories all over the country observe the weather at 8 A.M. The observations are fed automatically through a countrywide network of communication lines into a central station. Here a giant machine, containing a great deal of scientific knowledge about the weather, takes in all the data reported to it. At 8:15 the weather brain starts to calculate; in half an hour it has finished, having produced an excellent forecast of the weather for the whole country. Then it proceeds to transmit its forecast all over the country. By 8:50 every weather station, newspaper, radio station, and airport in the country has the details. In October 1945, Dr. V. K. Zworykin of the Princeton Laboratories of the Radio Corporation of America proposed solving the problem of weather forecasting in this way by a giant brain. The weather brain will have a second stage of application. From time to time and here and there, the weather is unstable: it can be triggered to behave in one way or another. For example, recently, pellets of _frozen carbon dioxide_—often called Dry Ice—have been dropped from planes and have caused rain. In fact, a few pounds of Dry Ice have apparently caused several hundred tons of rain or snow. In similar ways, we may, for example, turn away a hail storm so that hail will fall over a barren mountain instead of over a farming valley and thus protect crops. Or we may dispel conditions that would lead to a tornado, thus avoiding its damage. Both these examples involve local weather disturbances. However, even the greatest weather disturbances, like hurricanes and blizzards, may eventually be directed to some extent. Thus the weather may become to some degree subject to man’s control, and the weather brain will be able to tell men where and when to take action. Psychological Testing Another scientific problem to which new machinery for handling information applies is the problem of understanding human beings and their behavior. This increased understanding may lead to much wiser dealing with human behavior. For example, consider tests of aptitudes. If you take one of these tests, you may be asked to mark which word out of five suggested ones is nearest in meaning to a given word. Or your test may be 40 simple arithmetical problems to be solved in 25 minutes. Or you may be given a sheet with 20 circles, and be asked to put 3 dots in the first, 7 dots in the second, 4 dots in the third, 11 dots in the fourth, and so on, irregularly; you may be given a total of 45 seconds to do this as well as you can. Now, if a vocational counselor gives you one of these tests, and if you get 84 out of 100 on it, he needs to know just what he has measured about you. Also, he needs to know whether he can reasonably forecast that, as a result of your grade of 84, you will be good at writing articles, or good at supervising the work of other people, or good at designing in a machine shop. He needs to know the records of people with scores of about 84 on this test and to have evidence supporting his forecasts. If we wish to make the most use of the tests, we need to carry out a good deal of statistics, mathematics, and logic. For example, it will turn out that answers to some questions are much more significant than answers to others, and so we can greatly improve the quality of the tests by keeping only the more significant questions. Powerful machinery for handling calculations will be very useful in the field of aptitude testing. But, you may ask, what if the person analyzing your answers has to use interpretations and judgments? If the judgments and interpretations can be expressed in words, and if the words can be translated into machine language, then the machine can carry out the analysis. Usually the difference between a rule and a judgment is simply this: a rule in a case in which it is hard to express all the factors being considered is called a judgment. Psychological Trainer It is conceivable that machines that think can eventually be applied in the actual treatment of mental illness and maladjustment. Consider what a physician does. In treating a psychiatric case, such as a _neurosis_, a physician uses words almost entirely. He asks questions. He listens to the patient’s answers. Each answer takes the physician nearer and nearer to a diagnosis. By and by the physician knows what most of the difficulty is. Then he must present his knowledge slowly to the patient, gradually guiding the patient to understanding. It is a psychological truth that telling a man in ten minutes what is wrong with him does not cure him. The physician seeks to free the patient from the tormenting circles of habit and worry in which he has been trapped. Often the diagnosis is short and the treatment is long; the reasons for the neurosis may soon be clear to the physician, but they may take months to become clear to the patient. Now let us consider the following kind of machine as an aid to the physician. We might call this kind of machine a _psychological trainer_, for in many ways it is like the training machines used in World War II for training a pilot to fly an airplane. The psychological trainer would have the following properties: 1. The machine is able to show sound movies—produce pictures and utter words. 2. It is able to put before the patient: situations, problems, questions, experiences, etc. 3. It is able to take in responses from the patient. 4. It is able to receive a program of instructions from the physician. 5. Depending on the responses of the patient and on the program from the physician, the training machine can select more material to put before the patient. 6. The training machine produces a record of what it presented and of how the patient responded, so that the physician and the patient can study the record later. What sort of films would the machine hold? The machine could be loaded with a number of films which would help in the particular type of neurosis from which the patient was suffering. What sort of responses could the patient make? The patient might have buttons in front of him which he could press to indicate such answers as: Yes I don’t know Repeat No It depends Go ahead Also, the patient might hold a device—like a lie detector, perhaps—which would report his state of tenseness, etc., and so report what he really felt. Where would the machine’s questions come from? From one or more physicians very clever in the treatment of mental illness. Suppose that the patient is inconsistent in his answers? The machine, discovering the inconsistencies, could return to the subject and ask related questions in a different way. As soon as several questions related to the same point are answered consistently, the machine could exclude groups of questions that no longer apply and could proceed to other questions that would still apply. Patients would vary in their ability to go as fast as the machine could. So from time to time the machine would ask questions to test the effect of what it had presented; and, depending on the answers, the machine would go faster or would bring in additional material to clarify some point. This machine might have a few advantages over ordinary treatment. For example, with the machine, treatment does not depend on the physician’s making the right answer in a split second, as it may in a personal interview. Also, the patient might be franker with the machine than with the physician, for it might be arranged that the patient could review his record, and then decide whether to confess it to his physician. Such a machine would enable physicians to treat many more patients than they now can. In fact, it is estimated that nearly 50 per cent of persons who consult physicians are suffering only from mental illness. Such a machine would therefore be a great help. Problems of Business Another large group of problems for which we can foresee the use of machines that think is found in business and economics. For example, consider production scheduling in a business or a factory. The machine takes in a description of each order received by the business and a description of its relative urgency. The machine knows (that is, has in its memory) how much of each kind of raw material is needed to fill the order and what equipment and manpower are needed to produce it. The machine makes a schedule showing what particular men and what particular equipment are to be set to work to produce the order. The machine turns out the best possible production schedule, showing who should do what when, so that all the orders will be filled in the best sequence. What is the “best” sequence? We can decide what we think is the best sequence, and we can set the machine for making that kind of selection, in the same way as we decide what is “warm” and set the thermostat to produce it! On a much larger scale, we can use mechanical brains to study economic relations in a society. Everything produced in a society is made by consuming some materials, labor, equipment, and skill. The output produced by one man or factory or industry becomes the input for other men, factories, industries. In this way all economic units are linked together by many different kinds and degrees of dependence. The situation is, of course, complicated: it changes as time goes on and as people want different things produced. Economists have already set up simple models of economic societies and have studied them. But with machines that think, it will be possible to set up and study far more complicated models—models that are very much like the society we live in. We can then answer questions of economics by calculation instead of by arguments and counting noses. We shall be able to solve definitely such problems as: “How will a rise in the price of steel affect the farming industry?” “How much money must be paid out as wages and salaries so that consumer purchasing power will buy back what industry produces?” Machines and the Individual What about the ordinary everyday effects of these machines upon you and me as an individual? We can see that the new machinery will apply on a small scale even to us. Small machines using a few electronic tubes—much like a radio set, for example—and containing spools of magnetic wire or magnetic tape will doubtless be available to us. We shall be able to use them to keep addresses and telephone numbers, to figure out the income tax we should pay, to help us keep accounts and make ends meet, to remember many things we need to know, and perhaps even to give us more information. For there are a great many things that all of us could do much better if we could only apply what the wisest of us knows. We can even imagine what new machinery for handling information may some day become: a small pocket instrument that we carry around with us, talking to it whenever we need to, and either storing information in it or receiving information from it. Thus the brain with a motor will guide and advise the man just as the armor with a motor carries and protects him. Chapter 12 SOCIAL CONTROL: MACHINES THAT THINK AND HOW SOCIETY MAY CONTROL THEM It is often easier for men to create a device than to guide it well afterwards: it is often easier for a scientist to study his science than to study the results for good or evil that his discoveries may lead to. But it is not right nor proper for a scientist, a man who is loyal to truth as an ideal, to have no regard for what his discoveries may lead to. This principle is now being widely recognized. Many scientists today—both as individuals and as groups, and especially the atomic scientists—are considering the results of their scientific discoveries; and they are sharing in the effort to render those results truly useful to humanity. It would be easy to leave out of this book any discussion of how machines that think may be controlled, any consideration of how they may be made truly useful to humanity. But that would be hardly right or proper. In concluding a book such as this one, that touches on many aspects of machines that think, we need to consider what can and should be done to make such machines of true benefit to all of humanity. So, we come to the most important of all our questions: What sort of control over machines that think do we need in human society? MACHINE THAT BOTH THINKS AND ACTS From a narrow point of view, a machine that only thinks produces only information. It takes in information in one state, and it puts out information in another state. From this viewpoint, information in itself is harmless; it is just an arrangement of marks; and accordingly, a machine that thinks is harmless, and no control is necessary. Although it is true that the information produced only becomes good or evil after other machinery or human beings act on the information, in reality a machine with the power to produce information is constructed only for the reason of its use. We want to know what such machines can tell us only because we can then proceed to act much more efficiently than before. For example, a guided missile needs a mechanical brain only because then it can reach its target. In all cases mechanical brains are inseparable from their uses. For the purposes of this chapter, the narrow view will be rejected because it dodges the issue. We shall be much concerned with the combination of a machine that thinks with another machine that acts; and we shall often call this combination the _robot machine_. READING THIS CHAPTER Now, before launching further into the discussion, we need to say that the conclusions suggested in this chapter are not final. Even if they are expressed a little positively in places, they are nevertheless subject to change as more information is discovered and as the appraisal of information changes with time. Also, almost any conclusions about social control—including, certainly, the conclusions in this chapter—are subject to controversy. But controversy is good: it leads to thought. The more minds that go to work on solving the problem of social control over robot machines and other products of the new technology—which is rushing upon us from the discoveries of the scientists—the better off we all will be. If, while stimulating disagreement, the ideas expressed in this chapter should succeed in stimulating thought and deliberation, the purpose of this chapter will be well fulfilled. Up to this point in this book, the emphasis has been on possibilities of benefits to humanity that may arise from machines that think. In this chapter, devoted as it is to the subject of control, the emphasis is on possibilities for harm. Both possibilities are valid, and the happening of either depends upon the actions of men. In much the same way, atomic energy is a great possibility for benefit and for harm. It is the nature of control to put a fence around danger; and so it is natural in this chapter that the weight of attention should shift to the dangerous aspects of machines that think. Perhaps a reader may feel that a chapter of this kind is rather out of place in a book, such as this one, that seeks to be scientific. If so, he is reminded that, in accordance with the general suggestions for reading this book stated in the preface, he should omit this chapter. FRANKENSTEIN Perhaps the first study of the consequences of a machine that thinks is a prophetic novel called _Frankenstein_, written more than a hundred years ago, in 1818. The author, then only 21 years old, was Mary W. Godwin, who became the wife of the poet Percy Bysshe Shelley. According to the story, a young Swiss, an ardent student of physiology and chemistry, Victor Frankenstein, finds the secret of life. He makes an extremely ugly, clever, and powerful monster, with human desires. Frankenstein promptly flees from his laboratory and handiwork. The monster, after seeking under great hardships for a year or two to earn fair treatment among men, finds himself continually attacked and harmed on account of his ugliness, and he becomes embittered. He begins to search for his creator for either revenge or a bargain. When they meet: “I expected this reception,” said the daemon. “All men hate the wretched; how then must I be hated who am miserable beyond all living things! Yet you my creator detest and spurn me, thy creature, to whom thou art bound by ties only dissoluble by the annihilation of one of us. You purpose to kill me. How dare you sport thus with life? Do your duty towards me, and I will do mine towards you and the rest of mankind. If you will comply with my conditions, I will leave them and you at peace; but if you refuse, I will glut the maw of death, until it be satiated with the blood of your remaining friends.” Frankenstein starts to comply with the main condition, which is to make a mate for the monster; but Frankenstein cannot bring himself to do it. So the monster causes the death one after another of all Frankenstein’s family and closest friends; and the tale finally ends with the death of Frankenstein and the disappearance of the monster. As the dictionary says about Frankenstein, “The name has become a synonym for one destroyed by his own works.” ROSSUM’S UNIVERSAL ROBOTS Perhaps the next study of the consequences of a machine that thinks is a remarkable play called _R.U.R._ (for Rossum’s Universal Robots), first produced in Prague in 1921. Karel Čapek, the Czech dramatist who wrote it, was then only 31. The word “robot” comes from the Czech word “robota,” meaning compulsory service. According to the play, Rossum the elder, a scientist, discovered a “method of organizing living matter” that was “more simple, flexible, and rapid” than the method used by nature. Rossum the younger, an engineer, founded a factory for the mass production of artificial workmen, robots. They had the form of human beings, intelligence, memory, and strength; but they were without feelings. In the first act, the factory under Harry Domin, General Manager, is busy supplying robots to purchasers all over the world—for work, for fighting, for any purpose at all, to anyone who could pay for them. Domin declares: “... in ten years, Rossum’s Universal Robots will produce so much corn, so much cloth, so much everything that things will be practically without price. There will be no poverty. All work will be done by living machines. Everybody will be free from worry and liberated from the degradation of labor. Everybody will live only to perfect himself.... It’s bound to happen.” In the second act, ten years later, it turns out that Domin and the others in charge of the factory have been making some robots with additional human characteristics, such as the capacity to feel pain. The newer types of robots, however, have united all the robots against man, for the robots declare that they are “more highly developed than man, stronger, and more intelligent, and man is their parasite.” In the last act, the robots conquer and slay all men except one—an architect, Alquist, who in the epilogue provides a final quirk to the plot. FACT AND FANCY Now what is fact and what is fancy in these two warnings given to us a hundred years apart? Of course, it is very doubtful that a Frankenstein monster or a Rossum robot will soon be constructed with nerves, flesh, and blood like an animal body. But we know that many types of robot machines can even now be constructed out of hardware—wheels, motors, wires, electronic tubes, etc. They can handle many kinds of information and are able to perform many kinds of actions, and they are stronger and swifter than man. Of course, it is doubtful that the robot machines, by themselves and of their own “free will,” will be dangerous to human beings. But as soon as antisocial human beings have access to the controls over robot machines, the danger to society becomes great. We want to escape that danger. Escape from Danger A natural longing of many of us is to escape to an earlier, simpler life on this earth. Victor Frankenstein longed to undo the past. He said: “Learn from me, if not by my precepts, at least by my example, how dangerous is the acquirement of knowledge, and how much happier that man is who believes his native town to be the world, than he who aspires to become greater than his nature will allow.” Any sort of return to the past is, of course, impossible. It is doubtful that men could, even if they wanted to, stop the great flood of technical knowledge that science is now producing. We all must now face the fact that the kind of world we used to live in, even so recently as 1939, is gone. There now exist weapons and machines so powerful and dangerous in the wrong hands that in a day or two most of the people of the earth could be put to death. Giant brains are closely related to at least two of these weapons: scientists have already used mechanical brains for solving problems about atomic explosives and guided missiles. In addition, thinking mechanisms designed for the automatic control of gunfire were an important part of the winning of World War II. They will be a still more important part of the fighting of any future war. Nor can we escape to another part of the earth which the new weapons will not reach. At 300 miles an hour, any spot on earth can be reached from any other in less than 48 hours. A modern plane exceeds this speed; a rocket or guided missile doubles or trebles it. Nor can we trust that some kind of good luck will pull us through and help men to escape the consequences of what men do. Both Frankenstein and Domin reaped in full the consequences of what they did. The history of life on this earth that is recorded in the rocks is full of evidence of races of living things that have populated the earth for a time and then become extinct, such as the dinosaurs. In that long history, rarely does a race survive. In our own day, insects and fungi rather than men have shown fitness to survive and spread over the earth: witness the blight that destroyed the chestnut trees of North America, in spite of the best efforts of scientists to stop it. There seems to be no kind of escape possible. It is necessary to grapple with the problem: How can we be safe against the threat of physical harm from robot machines? UNEMPLOYMENT The other chief threat from robot machines is against our economic life. Harry Domin, in _R.U.R._, you remember, prophesied: “All work will be done by living machines.” As an example, in the magazine _Modern Industry_ for Feb. 15, 1947, appeared a picture of a machine for selling books, and under the picture were the words: _Another new product in robot salesmen_—Latest in the parade of mechanical vending machines is this book salesman.... It is designed for use in hospitals, rail terminals, and stores. It offers 15 different titles, selected manually, and obtained by dropping quarter in slot. Cabinet stores 96 books. Can you feel the breath of the robot salesman, workman, engineer,—--, on the back of your neck? At the moment when we combine automatic producing machinery and automatic controlling machinery, we get a vast saving in labor and a great increase in technological unemployment. In extreme cases, perhaps, the effect of robot machines will be the disappearance of men from a factory. Such a factory will be like a modern power plant that turns a waterfall into electricity: once the machinery is installed, only one watchman is ordinarily needed. But, in most cases, this will be the effect: in a great number of factories, mines, farms, etc., the labor force needed will be cut by a great proportion. The effect is not different in quality, because the new development is robot machinery; but the amount of technological unemployment coming from robot machines is likely to be considerably greater than previously. The robot machine raises the two questions that hang like swords over a great many of us these days. The first one is for any employee: What shall I do when a robot machine renders worthless all the skill I have spent years in developing? The second question is for any businessman: How shall I sell what I make if half the people to whom I sell lose their jobs to robot machines? SOCIAL CONTROL AND ITS TWO SIDES The two chief harmful effects upon humanity which are to be expected from robot machines are physical danger and unemployment. These are serious risks, and some degree of social control is needed to guard against them. There will also be very great advantages from robot machines. The monster in _Frankenstein_ is right when he says, “Do your duty towards me, and I will do mine towards you and the rest of mankind.” And Harry Domin in _R.U.R._ is right as to possibility when he says, “There will be no poverty.... Everybody will be free from worry.” Social control must also be concerned with how the advantages from robot machines are to be shared. The problem of social control over men and their devices has always had two sides. The first side deals with what we might plan for control if men were reasonable and tolerant. This part of the problem seems relatively easy. The other side deals with what we must ordinarily arrange, since most men are often unreasonable and prejudiced and, as a result, often act in antisocial ways. This part of the problem is hard. Let us begin with the easier side first. TYPES OF CONTROL—IF MEN WERE REASONABLE In seeking to fulfill wants and achieve safety, men have used hundreds of types of control. The main types are usually called political and economic systems, but there are always great quantities of exceptions. The more mature and freer the society, the greater the variety of types of control that can be found in it. Probably the most widely used type of control in this country is private and public control working together, as private ownership and public regulation—for example, railroads, banks, airlines, life insurance companies, telephone systems, and many others. It would be reasonable to expect private ownership and public regulation of a great many classes of robot machines, to the end that they would never threaten the safety of people. Another common type of control is public ownership and operation; examples are toll bridges, airports, city transit systems, and water-supply systems. Atomic energy was so clearly fraught with serious implications that in 1946 the Congress of the United States placed it entirely under public control expressed as the Atomic Energy Commission. There is a class of robot machinery which has already reached the stage of acute public concern: guided missiles and automatic fire-control. It would be reasonable that in this country all activity in this subdivision should be under close control by the Department of Defense. In the international arena, again, the problem becomes soluble if we assume men to be reasonable. An international agency, such as an organ of the United Nations, would take over inspection and control of robot machine activities closely affecting the public safety anywhere in the world. Particularly, this agency would concern itself with guided missiles, robot pilots for planes, automatic gunfire control, etc. Much manufacturing skill is needed to make such products as these: the factories where they could be manufactured would thereby be determined. Also, a giant brain is a useful device for solving scientific problems about weapons of mass destruction. So the agency would need to inspect the problems being solved on such machines. This agency would be responsible to a legislature or an executive body representing all the people in the world—if men were reasonable. In regard to the effects of robot machines on unemployment, again, if men were reasonable, the problem would be soluble. The problem is equivalent to the problem of abundance: how should men distribute the advantages of a vast increase in production among all the members of society in a fair and sensible way? A vast increase in production is not so impossible as it may seem. For example, in 1939, with 45 million employed, the United States index of industrial production was at 109, and, in 1943, with 52½ million employed, the index of production was at 239. If men were reasonable, the net profits from robot machinery would be divided among (1) those who had most to do with devising the new machinery, and (2) all of society. A rule would be adopted (probably it could be less complicated than some existing tax rules) which would take into account various factors such as rewards to the inventors, incentives to continue inventing, adequate assistance to those made unemployed by the robot machines, reduction of prices to benefit consumers, and contributions to basic and applied scientific research. In fact, under the assumption “if men were reasonable,” it would hardly be necessary to devote a chapter to the problem of social control over robot machines! OBSTACLES The discussion above of how robot machines could be controlled supposing that men were reasonable, seems, of course, to be glaringly impractical. Men are not reasonable on most occasions most of the time. If we stopped at this point, again we would be dodging the issue. What are the obstacles to reasonable control? There are, it seems, two big obstacles and one smaller one to reasonable types of social control over robot machines. The smaller one is ignorance, and the two big obstacles are prejudice and a narrow point of view. Ignorance By ignorance we mean lack of knowledge and information. Now mechanical brains are a new and intricate subject. A great many people will, through no fault of their own, naturally remain uninformed about mechanical brains and robot machines for a long time. However, there is a widespread thirst for knowledge these days: witness in magazines, for example, the growth of the article and the decline of the essay. There is also a fairly steady surge of knowledge from the austere scientific fountain of new technology. We can thus see both a demand and a supply for information in such fields as mechanical brains and robot machines. We can expect, therefore, a fairly steady decline in ignorance. Prejudice Prejudice is a much more serious obstacle to reasonable control over robot machines. It will be worth our while to examine it at length. Prejudice is frequent in human affairs. For example, in some countries, but not in all, there is conflict among men, based on their religious differences. Again, in other countries, but not in all, there is wide discrimination among men, based on the color of their skin. Over the whole world today, there is a sharp lack of understanding between conservatives, grading over to reactionaries, on the one hand, and liberals, grading over to radicals, on the other hand. All these differences are based on men’s attitudes, on strongly held sets of beliefs. These attitudes are not affected by “information”; the “information” is not believed. The attitudes are not subject to “judgment”; they come “before judgment”: they are prejudices. Even in the midst of all the science of today, prejudice is widespread. In Germany, from 1933 to 1939, we saw one of the most scientific of countries become one of the most prejudiced. Prejudice is often difficult to detect. We find it hard to recognize even in ourselves. For a prejudice always seems, to the person who has it, the most natural attitude in the world. As we listen to other people, we are often uncertain how to separate information, guesses, humor, prejudice, etc. Circumstances compel us to accept provisionally quantities of statements just on other people’s say-so. A good test of a statement for prejudice, however, is to compare it with the scientific view. Prejudice is most dangerous for society. Its more extreme manifestations are aggressive war, intolerance (especially of strange people and customs), violence, race hatred, etc. In the consuming hatred that a prejudiced man has towards the object of his prejudice, he is likely to destroy himself and destroy many more people besides. In former days, the handy weapon was a sword or a pistol; not too much damage could be done when one man ran amuck. But nowadays a single use of a single weapon has slain 70,000 people (the atom bomb dropped at Hiroshima), and so a great many people live anxious and afraid. What is prejudice? How does it arise? How can it be cured, and thus removed from obstructing reasonable control over robot machines and the rest of today’s amazing scientific developments? Prejudice is a disease of men’s minds. It is infectious. The cause and development of the disease are about as follows: Deprive someone of something he deeply needs, such as affection, food, or opportunity. In this way hurt him, make him resentful, hostile; but prevent him from expressing his resentments in a reasonable way, giving him instead false outlets, such as other people to hurt, myths to believe, hostile behavior patterns to imitate. He will then break out with prejudices as if they were measles. The process of curing the disease of prejudice is about as follows: Make friends with the patient; win his trust. Encourage him to pour out his half-forgotten hates. Help him to talk them over freely, by means of questions but not criticisms, until finally the patient achieves insight, sees through his former prejudices, and drops them. In these days prejudice is a cardinal problem of society. It is perhaps conservative to say that a chief present requirement for the survival of human society—with the atom bomb, bacterial warfare, guided missiles, etc., near at hand—is cure of prejudice and its consequences, irrational and unrestrained hate. Narrow Point of View A narrow point of view regarding what is desirable or good is the third obstacle to rational control over robot machines. What do we mean by this? Our point of view as a two-year-old is based on pure self-interest. If we see a toy, we grab it. There is no prejudice about this; it is entirely natural—for two-year-olds. As we grow older, our point of view concerning what is good or desirable rapidly broadens: we think of others and their advantage besides our own. For example, we may become interested in a conservation program to conserve birds, or soil, or forests, and our point of view expands, embraces these objectives, which become part of our personality and loyalties. Unfortunately, it seems to be true that the expanding point of view, the expanding loyalties, of most people as they grow up are arrested somewhere along the line of: self, family, neighborhood, community, section of country, nation. An honorable exception is the scientists’ old and fine tradition of world-wide unity and loyalty in the search for objective truth. Now the problem of rational control over robot machines and other parts of the new technology is no respecter of national boundaries. To be solved it requires a world-wide point of view, a loyalty to human society and its best interests, a social point of view. Almost all that you and I have and do and think is the result of a long history of human society on this earth. All men on the earth today are descendants of other men who lived 1000, 2000, 3000 ... years ago, whether they were Romans or Chinese or Babylonians or Mayas or members of any other race. To ride in a subway or an airplane, to talk on the telephone, to speak a language, to calculate, to survive smallpox or the black death, etc.—all these privileges are our inheritance from countless thousands of other human beings, of many countries, and nearly all of whom are now dead. During our lives we pass on to our own children an inheritance in which our own contribution is remarkably small. Since each person is the child of two others, the number of our forefathers is huge, and we are all undoubtedly blood cousins. Because of this relationship, and because we owe to the rest of society nearly all that we are, we have a social responsibility—we need to hold a social point of view. Each of us needs to accept and welcome a world-wide social responsibility, as a member of human society, as a beneficiary and trustee of our human inheritance. Otherwise we are drones, part of the hive without earning our keep. The social point of view is equitable, it is inspiring, and it is probably required now in order for human beings to survive. We need to let go of a narrow point of view. CONCLUSION We have now outlined the problem of social control over robot machines, supposing that human beings were reasonable. We have also discussed the practical obstacles that obstruct reasonable control. It is not easy to think of any yet organized group of people anywhere that would have both the strength and the vision needed to solve this problem through its own efforts. For example, a part of the United Nations might have some of the vision needed, but it does not have the power. Consequently, it is necessary and desirable for individuals and groups everywhere to take upon themselves an added load of social responsibility—just as they tend to do in time of war. People often “want to do their share.” Through encouragement and education, the basic attitude of a number of people can contain more of “This is our business; we have a responsibility for helping to solve this problem.” We also need public responsibility; we need a public body responsible for study, education, advice, and some measure of control. It might be something like an Atomic Energy Commission, Bacterial Defense Commission, Mental Health Commission, and Robot Machine Commission, all rolled into one. When, at last, there is an effective guarantee of the two elements physical safety and adequate employment, then at last we shall all be free from the threat of the robot machine. We can then welcome the robot machine as our deliverer from the long hard chores of many centuries. Supplement 1 WORDS AND IDEAS The purpose of this book is to explain machines that think, without using technical words any more than necessary. This supplement is a digression. Its purposes are to consider how to explain in this way and to discuss the attempt made in this book to achieve simple explanation. WORDS AS INSTRUMENTS FOR EXPLAINING Words are the chief instruments we use for explaining. Of course, many other devices—pictures, numbers, charts, models, etc.—are also used; but words are the prime tools. We do most of our explaining with them. Words, however, are not very good instruments. Like a stone arrow-head, a word is a clumsy weapon. In the first place, words mean different things on different occasions. The word “line,” for example, has more than fifty meanings listed in a big dictionary. How do we handle the puzzle of many meanings? As we grow older we gather experience and we develop a truly marvelous capacity to listen to a sentence and then fit the words together into a pattern that makes sense. Sometimes we notice the time lag while our brain hunts for the meaning of a word we have heard but not grasped. Then suddenly we guess the needed meaning, whereupon we grasp the meaning of the sentence as a whole in much the same way as the parts of a puzzle click into place when solved. Another trouble with words is that often there is no good way to tell someone what a word means. Of course, if the word denotes a physical object, we can show several examples of the object and utter the word each time. In fact, several good illustrations of a word denoting a physical thing often tell most of its meaning. But the rest of its meaning we often do not learn for years, if ever. For instance, two people would more likely disagree than agree about what should be called a “rock” and what should be called a “stone,” if we showed them two dozen examples. In the case of words not denoting physical objects, like “and,” “heat,” “responsibility,” we are worse off. We cannot show something and say, “That is a ···.” The usual dictionary is of some help, but it has a tendency to tell us what some word _A_ means by using another word _B_, and when we look up the other word _B_ we find the word _A_ given as its meaning. Mainly, however, to determine the meanings of words, we gather experience: we soak up words in our brains and slowly establish their meanings. We seem to use an unconscious reasoning process: we notice how words are used together in patterns, and we conclude what they must mean. Clearly, then, words being clumsy instruments, the more experience we have had with a word, the more likely we are to be able to use it, work with it, and understand it. Therefore explanation should be based chiefly on words with which we have had the most experience. What words are these? They will be the well-known words. A great many of them will be short. SET OF WORDS FOR EXPLAINING Now what is the set of all the words needed to explain simply a technical subject like machines that think? For we shall need more words than just the well-known and short ones. This question doubtless has many answers; but the answer used in this book was based on the following reasoning. In a book devoted to explanation, there will be a group of words (1) that are supposed to be known already or to be learned while reading, and (2) that are used as building blocks in later explanation and definitions. Suppose that we call these words the _words for explaining._ There are at least three groups of such words: _Group 1._ Words not specially defined that are so familiar that every reader will know all of them; for example, “is,” “much,” “tell.” _Group 2._ Words not specially defined that are familiar, but perhaps some reader may not know some of them; for example, “alternative,” “continuous,” “indicator.” _Group 3._ Words that are not familiar, that many readers are not expected to know, and that are specially defined and explained in the body of the book; for example, “abacus,” “trajectory,” “torque.” In writing this book, it was not hard to keep track of the words in the third group. These words are now listed in the index, together with the page where they are defined or explained. (The index, of course, also lists phrases that are specially defined.) But what division should be made between the other two groups? A practical, easy, and conservative way to separate most words between the first and second groups seemed to be on the basis of number of syllables. All words of one syllable—if not specially defined—were put in Group 1. Also, if a word became two syllables only because of the addition of one of the endings “-es,” “-ed,” “-ing,” it was kept in Group 1, for these endings probably do not make a word any harder to understand. In addition, there were put into Group 1: 1. Numbers; for example, “186,000”; “³/₁₀”. 2. Places: “Philadelphia”; “Massachusetts”. 3. Nations, organizations, people, etc.: “Swedish”; “Bell”. 4. Years and dates: “February”; “1946”. 5. Names of current books or articles and their authors. Of course, not all these words would be familiar to every reader (for example, “Maya”), but in the way they occur, they are usually not puzzling, for we can tell from the context just about what they must mean. All remaining words for explaining—chiefly, words of two or more syllables and not specially defined—were put in Group 2 and were listed during the writing of this book. Many Group 2 words, of course, would be entirely familiar to every reader; but the list had several virtues. No hard words would suddenly be sprung like a trap. The same word would be used for the same idea. Every word of two or more syllables was continually checked: is it needed? can it be replaced by a shorter word? It is perhaps remarkable that there were fewer than 1800 different words allowed to stay in this list. This fact should be a comfort to a reader, as it was to the author. Now there are more words in this book than _words for explaining_. So we shall do well to recognize: _Group 4._ Words that do not need to be known or learned and that are not used in later explanation and definitions. These words occur in the book in such a way that understanding them, though helpful, is not essential. One subdivision of Group 4 are names that appear just once in the book, as a kind of side remark, for example, “a chemical, called _acetylcholine_.” Such a name will also appear in the index, but it is not a _word for explaining_. Another subdivision of Group 4 are words occurring only in quotations. For example, in the quotation from _Frankenstein_ on page 198, a dozen words appear that occur nowhere else in the book, including “daemon,” “dissoluble,” “maw,” “satiate.” Clearly we would destroy the entire flavor of the quotation if we changed any of these words in any way. But only the general drift of the quotation is needed for understanding the book, and so these words are Group 4 words. In this way the effort to achieve simple explanation in this book proceeded. But even supposing that we could reach the best set of words for explaining, there is more to be done. How do we go from simple explanation to understanding? UNDERSTANDING IDEAS _Understanding_ an idea is basically a standard process. First, we find the name of the idea, a word or phrase that identifies it. Then, we collect true statements about the idea. Finally, we practice using them. The more true statements we have gathered, and the more practice we have had in applying them, the more we understand the idea. For example, do you understand zero? Here are some true statements about zero. 1. Zero is a number. 2. It is the number that counts none or nothing. 3. It is marked 0 in our usual numeral writing. 4. The ancient Romans, however, had no numeral for it. Apparently, they did not think of zero as a number. 5. 0 is what you get when you take away 17 from 17, or when you subtract any number from itself. 6. If you add 0 to 23, you get 23; and if you add 0 to any number, you get that number unchanged. 7. If you subtract 0 from 48, you get 48; and if you subtract 0 from any number, you get that number unchanged. 8. If you multiply 0 by 71, you get 0; and if you multiply together 0 and any number, you get 0. 9. Usually you are not allowed to divide by 0: that is against the rules of arithmetic. 10. But if you do, and if you divide 12 by 0, for example—and there are times when this is not wrong—the result is called _infinity_ and is marked ∞, a sign that is like an 8 on its side. This is not all the story of zero; it is one of the most important of numbers. But, if you know these statements about zero, and have had some practice in applying them, you have a good _understanding_ of zero. Incidentally, a mechanical brain knows all these statements about zero and a few more; they must be built into it. For us to understand any idea, then, we pursue three aims: 1. We find out what it is called. 2. We collect true statements about it. 3. We apply those statements—we use them in situations. We can do this about any idea. Therefore, we can understand any idea, and the degree of our understanding increases as the number of true statements mastered increases. Perhaps this seems to be a rash claim. Of course, it may take a good deal of time to collect true statements about many ideas. In fact, a scientist may spend thirty years of his life trying to find out from experiment the truth or falsehood of one statement, though, when he has succeeded, the fact can be swiftly told to others. Also, we all vary in the speed, perseverance, skill, etc., with which we can collect true statements and apply them. Besides, some of us have not been taught well and have little faith in our ability to carry out this process: this is the greatest obstacle of all. But, there is in reality no idea in the field of existing science and knowledge which you or I cannot understand. The road to understanding lies clear before us. Supplement 2 MATHEMATICS In the course of our discussion of machines that think, we have had to refer without much explanation to a number of mathematical ideas. The purpose of this supplement is to explain a few of these ideas a little more carefully than seemed easy to do in the text and, at the end of the supplement, to put down briefly some additional notes for reference. DEVICES FOR MULTIPLICATION Suppose that we have to multiply 372 by 465. With the ordinary school method, we write 465 under the 372 and proceed about as follows: 5 times 2 is 10, put down the 0 and carry the 1; 5 times 7 is 35, 35 and 1 is 36, put down the 6 and carry the 3; 5 times 3 is 15, 15 and 3 is 18, put down the 8 and carry the 1; ... The method is based mainly on a well-learned subroutine of continually changing steps: 1. Select a multiplicand digit. 2. Select a multiplier digit. 3. Refer to the multiplication table with these digits. 4. Obtain the value of their product, called a _partial product_. 5. Add the preceding carry. 6. Set down the right-hand digit. 7. Carry the left-hand digit. We can, however, simplify this subroutine for a machine by delaying the carrying. We collect in one place all the right-hand digits of partial products, collect in another place all the left-hand digits, and delay all addition until the end. For example, let us multiply 372 by 465 with this method: RIGHT-HAND LEFT-HAND USUAL METHOD, DIGITS DIGITS FOR COMPARISON 372 372 372 × 465 × 465 × 465 —————— —————— —————— 550 131 1860 822 141 2232 288 120 1488 ————— ————— —————— 37570 13541 172980 FINAL ADDITION 37570 + 13541 ———————— 172980 37570 is called the _right-hand component_ of the product. It is convenient to fill in with 0 the space at the end of 13541 and to call 135410 the _left-hand component_ of the product. This process is called _multiplying by right- and left-hand components_. It has the great advantage that no carrying is necessary to complete any line of the original multiplications. Some computing machines use this process. Built into the hardware of the machine is a multiplication table up to 9 × 9. The machine, therefore, can find automatically the right-hand digit and the left-hand digit of any partial product. In a computing machine that uses this process, all the left-hand digits are automatically added in one register, and all the right-hand digits are added in another register. The only carrying that is needed is the carrying as the right-hand digits are accumulated and as the left-hand digits are accumulated. At the end of the multiplication, one of the registers is automatically added into the other, giving the product. Another device used in computing machines for multiplying is to change the multiplier into a set of digits 0 to 5 that are either positive or negative. For example, suppose that we want to multiply 897 by 182. We note that 182 equals 200 minus 20 plus 2, and so we can write it as _ 222. The minus over the 2 marks it as a _negative digit_ 2. Then to multiply we have: 897 _ 222 ———— 1794 - 1794 1794 —————— 163254 The middle 1794 is subtracted. This process is usually called _short-cut multiplication_. Everybody discovers this trick when he decides that multiplying by 99 is too much work, that it is easier to multiply by 100 and subtract once. BINARY OR TWO NUMBERS We are well accustomed to decimal notation in which we use 10 decimal digits 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 and write them in combinations to designate decimal numbers. In _binary notation_ we use two binary digits 0, 1 and write them in combinations to designate _binary numbers_. For example, the first 17 numbers, from 0 to 16 in the decimal notation, correspond with the following numbers in binary notation: DECIMAL BINARY DECIMAL BINARY 0 0 1 1 9 1001 2 10 10 1010 3 11 11 1011 4 100 12 1100 5 101 13 1101 6 110 14 1110 7 111 15 1111 8 1000 16 10000 In decimal notation, 101 means one times a hundred, no tens, and one. In binary notation, 101 means one times four, no twos, and one. The successive digits in a decimal number from right to left count 1, 10, 100, 1000, 10000, ...—successive _powers_ of 10 (for this term, see the end of this supplement). The successive digits in a binary number from right to left count 1, 2, 4, 8, 16, ...—powers of 2. The decimal notation is convenient when equipment for computing has ten positions, like the fingers of a man, or the positions of a counter wheel. The binary notation is convenient when equipment for computing has just two positions, like “yes” or “no,” or current flowing or no current flowing. Addition, subtraction, multiplication, and division can all be carried out unusually simply in binary notation. The addition table is simple and consists only of four entries. + 0 1 +—————— 0 | 0 1 | 1 | 1 10 The multiplication table is also simple and contains only four entries. × 0 1 +—————— 0 | 0 0 | 1 | 0 1 Suppose that we add in binary notation 101 and 1001: BINARY ADDITION CHECK 101 5 + 1001 9 —————— ——— 1110 14 We proceed: 1 and 1 is 10; write down 0 and carry 1; 0 and 0 is 0, and 1 to carry is 1; and 1 and 0 is 1; and then we just copy the last 1. To check this we can convert to decimal and see that 101 is 5, 1001 is 9, and 1110 is 14, and we can verify that 5 and 9 is 14. One of the easiest ways to subtract in binary notation is to add a _ones complement_ (that is, the analogue of the nines complement) and use end-around-carry (for these two terms, see the end of this supplement). A ones complement can be written down at sight by just putting 1 for 0 and 0 for 1. For example, suppose that we subtract 101 from 1110: SUBTRACTION BY DIRECT ADDING ONES SUBTRACTION CHECK COMPLEMENT 1110 14 1110 - 101 -5 + 1010 ————— ———— —————— 1001 9 (1)1000 ↓ ⎯→ 1 —————— 1001 Multiplication in the binary notation is simple. It amounts to (1) adding if the multiplier digit is 1 and not adding if the multiplier digit is 0, and (2) moving over or shifting. For example, let us multiply 111 by 101: BINARY MULTIPLICATION CHECK 111 7 × 101 × 5 —————— 111 111 —————— ——— 100011 35 The digit 1 in the 6th (or _n_th) _binary_ place from the right in 100011 stands for 1 times 2 to the 5th (or _n_-1 th) power, 2 × 2 × 2 × 2 × 2 = 32. The result 100011 is translated into 32 plus 2 plus 1, which equals 35 and verifies. Division in the binary notation is also simple. It amounts to (1) subtracting (yielding a quotient digit 1) or not subtracting (yielding a quotient digit 0), and (2) shifting. We never need to try multiples of the divisor to find the largest that can be subtracted yet leave a positive remainder. For example, let us divide 1010 (10 in decimal) into 10001110 (142 in decimal): 1110 (14 in decimal) —————————— 1010)10001110 1010 —————— 1111 1010 ————— 1011 1010 ————— 10 (remainder, 2 in decimal) In decimal notation, digits to the right of the decimal point count powers of ⅒. In binary notation, digits to the right of the _binary point_ count powers of ½: ½, ¼, ⅛, ¹/₁₆.... For example, 0.1011 equals ½ + ⅛ + ¹/₁₆, or ¹¹/₁₆. If we were accustomed to using binary numbers, all our arithmetic would be very simple. Furthermore, binary numbers are in many ways much better for calculating machinery than any other numbers. The main problem is converting numbers from decimal notation to binary. One method depends on storing the powers of 2 in decimal notation. The rule is: subtract successively smaller powers of 2; start with the largest that can be subtracted, and count 1 for each power that goes and 0 for each power that does not. For example, 86 in decimal becomes 1010110 in binary: 86 64 64 goes 1 ——— 22 32 does not go 0 16 16 goes 1 ——— 6 8 does not go 0 4 4 goes 1 ——— 2 2 goes 1 2 1 does not go 0 ——— 0 It is a little troublesome to remember long series of 1’s and 0’s; in fact, to write any number in binary notation takes about 3⅓ times as much space as decimal notation. For this reason we can separate binary numbers into triples beginning at the right and label each triple as follows: TRIPLE LABEL 000 0 001 1 010 2 011 3 100 4 101 5 110 6 111 7 For example, 1010110 would become 1 010 110 or 126. This notation is often called _octal notation_, because it is notation in the scale of eight. BIQUINARY OR _TWO-FIVE_ NUMBERS Another kind of notation for numbers is _biquinary notation_, so called because it uses both 2’s and 5’s. Essentially this notation is very like Roman numerals, ancient style. By ancient style we mean, for example, VIIII instead of IX. In the following table we show the first two dozen numbers in decimal, biquinary, and ancient Roman notation: DECIMAL BIQUINARY ROMAN 0 0 1 1 I 2 2 II 3 3 III 4 4 IIII 5 10 V 6 11 VI 7 12 VII 8 13 VIII 9 14 VIIII 10 100 X 11 101 XI 12 102 XII 13 103 XIII 14 104 XIIII 15 110 XV 16 111 XVI 17 112 XVII 18 113 XVIII 19 114 XVIIII 20 200 XX 21 201 XXI 22 202 XXII 23 203 XXIII The biquinary columns alternate in going from 0 to 4 and from 0 to 1. The digits from 0 to 4 are not changed. The digits from 5 to 9 are changed into 10 to 14. We see that the _biquinary digits_ are 0 to 4 in odd columns and 0, 1 in even columns, counting from the right. This is the notation actually expressed by the _abacus_. The beads of the abacus show by their positions groups of 2 and 5 (see Fig. 1). [Illustration: FIG. 1. Abacus and notations.] SOME OPERATIONS OF ALGEBRA One of the operations of algebra that is important for a mechanical brain is _approximation_, the problem of getting close to the right value of a number. Take, for example, finding _square root_ (see the end of this supplement). The ordinary process taught in school is rather troublesome. We can set down another process, however, using a desk calculator to do division, which gives us square root with great speed. Suppose that we want to find the square root of a number _N_, and suppose that we have _x_₀ as a guessed square root correct to one figure. For example, _N_ might be 67.2 and _x_₀ might be 8, chosen because 8 × 8 is 64, and 9 × 9 is 81, and it seems as if 8 should be near the square root of 67.2. Here is the process: 1. Divide _x_₀ into _N_, and obtain _N_/_x_₀. 2. Multiply _x_₀ + _N_/_x_₀ by 0.5 and call the result _x_₁. Now repeat: 1. Divide _x_₁ into _N_ and obtain _N_/_x_₁. 2. Multiply _x_₁ + _N_/_x_₁ by 0.5 and call the result _x_₂. Every time this process is repeated, the new _x_ comes a great deal closer to the correct square root. In fact it can be shown that, if _x_₀ is correct to one figure, then: APPROXIMATION IS CORRECT TO ··· FIGURES _x_₁ 2 _x_₂ 4 _x_₃ 8 _x_₄ 16 Let us see how this actually works out with 67.2 and a 10-column desk calculator. Round 1: 8 divided into 67.2 gives 8.4. One half of 8 plus 8.4 is 8.2. This is _x_₁. Round 2: 8.2 divided into 67.2 gives 8.195122. One half of 8.2 plus 8.195122 is 8.197561. This is _x_₂. Round 3: 8.197561 divided into 67.2 gives 8.197560225. One half of 8.197561 and 8.197560225 is 8.1975606125. This is _x_₃. Checking _x_₃, we find that 8.1975606125 divided into 67.2 gives 8.1975606126 approximately. In this case, then, _x_₃ is correct to more than 10 figures. In other words, with a reasonable guess and two or three divisions we can obtain all the accuracy we can ordinarily use. This process is called _rapid approximation_, or _rapidly convergent approximation_, since it _converges_ (points or comes together) very quickly to the number we are seeking. Another important operation of algebra is _interpolation_, the problem of putting values smoothly in between other values. For example, suppose that we have the table: _x y_ 5 26 6 37 7 50 8 65 9 82 Suppose that we want to find the value that _y_ (or _yₓ_) ought to have when _x_ has the value of 7.2. This is the problem of _interpolating y_ so as to find _y_ at the value of 7.2, _y_₇ˌ₂. One way of doing this is to discover the formula that expresses _y_ and then to put _x_ into that formula. This is not always easy. Another way is to take the difference between _y_₇ and _y_₈, 15, and share the difference appropriately over the distance 7 to 7.2 and 7.2 to 8. We can, for example, take ²/₁₀ of 15 = 3, add that to _y_₇ = 50, and obtain an estimated _y_₇ˌ₂ = 53. This is called _linear interpolation_, since the difference 0.2 in the value of _x_ is used only to the first power. It is a good practical way to carry out most interpolation quickly and approximately. Actually here _y_ = _x_² + 1, and so the true value of _y_₇ˌ₂ is (7.2 × 7.2) + 1, or 52.84, which is rather close to 53. Types of interpolation procedures more accurate than linear interpolation will come much nearer still to the true value. ALGEBRA OF LOGIC We turn now to the _algebra of logic_. The first half of Chapter 9, “Reasoning” (through the section “Logical-Truth Calculation by Algebra”), introduces this subject. There the terms _truth values_, _truth tables_, _logical connectives_, and _algebra of logic_ are explained. The part of Chapter 3, “A Machine That Will Think,” that discusses the operations _greater-than_ and _selection_, also explains some of the algebra of logic. It introduces, for example, the formula _p_ = _T_(_a_ > _b_) = 1, 0 This is a way of saying briefly that the truth value of the statement “_a_ is greater than _b_” equals _p_; _p_ is 1 if the statement is true and 0 if the statement is false. The truth value 1 corresponds with “yes.” The truth value 0 corresponds with “no.” With mechanical brains we are especially interested in handling mathematics and logic without any sharp dividing line between them. For example, suppose that we have a register in which a ten-digit number like 1,765,438,890 may be stored. We should be able to use that register to store a number consisting of only 1’s and 0’s, like 1,100,100,010. Such a number may designate the answers to 10 successive questions: yes, yes, no, no, yes, no, no, no, yes, no. Or it may tell 10 successive binary digits. The register then is three times as useful: it can store either decimal numbers or truth values or binary digits. We need, of course, a way to obtain from the register any desired digit. For this purpose we may have two instructions to the machine: (1) read the left-hand end digit; (2) shift the number around in a circle. The second instruction is the same as multiplying by 10 and then putting the left-most digit at the right-hand end. For example, suppose that we want the 3rd digit from the left in 1,100,100,010. The result of the first circular shift is 1,001,000,101; the result of the second circular shift is 0,010,001,011; and reading the left-most digit gives 0. A process like this has been called _extraction_ and is being built into the newest mechanical brains. Using truth values, we can put down very neatly some truths of ordinary algebra. For example: (the _absolute value_ of _a_) = _a_ × (the truth of _a_ greater than or equal to 0) - _a_ × (the truth of _a_ less than 0) ⎮_a_⎮ = _a_ · _T_(_a_ ≥ 0) - _a_ · _T_(_a_ < 0) For another example: Either _a_ is greater than _b_, or else _a_ equals _b_, or else _a_ is less than _b_ _T_(_a_ > _b_) + _T_(_a_ = _b_) + _T_(_a_ < _b_) = 1 Many common logical operations, like selecting and comparing, and the behavior of many simple mechanisms, like a light or a lock, can be expressed by truth values. Chapter 4, on punch-card mechanisms, contains a number of examples. * * * * * pronoun, variable In ordinary language, a _pronoun_, like “he,” “she,” “it,” “the former,” “the latter,” is a word that usually stands for a noun previously referred to. A pronoun usually stands for the last preceding noun that the grammar allows. In mathematics, a _variable_, like “_a_,” “_b_,” “_x_,” “_m₁_,” “_m₂_” closely resembles a pronoun in ordinary language. A variable is a symbol that usually stands for a number previously referred to, and usually it stands for the same number throughout a particular discussion. multiplicand, dividend, augend, etc. IN THE THE NAME THE NAME THE NAME EQUATION: OF _a_ IS: OF _b_ IS: OF _c_ IS: _a_ + _b_ = _c_ augend addend sum _a_ - _b_ = _c_ minuend subtrahend remainder _a_ × _b_ = _c_ multiplicand multiplier product _a_ ÷ _b_ = _c_ dividend divisor quotient _Augend_ and _addend_ are names of registers in the Harvard Mark II calculator (see Chapter 10). subtraction by adding, nines complement Two digits that add to 9 (0 and 9, 1 and 8, 2 and 7, 3 and 6, 4 and 5) are called _nines complements_ of each other. The _nines complement_ of a number _a_ is the number _b_ in which each digit of _b_ is the nines complement of the corresponding digit of _a_; for example, the nines complement of 173 is 826. Ordinary subtraction is the same as addition as of the nines complement, with a simple correction; for example, 562 less 173 (equal to 389) is the same as 562 plus 826 (equal to 1388) less 1000 plus 1. end-around-carry The correction “less 1000 plus 1” of the foregoing example may be thought of as carrying the 1 (in the result 1388) around from the left-hand end to the right-hand end, where it is there added. So the 1 is called _end-around-carry_. tens complement Two digits that add to 10 are called _tens complements_ of each other. The _tens complement_ of a number _a_, however, is equal to the nines complement of the number plus 1. For example, the tens complement of 173 is 827. When subtracting by adding a tens complement, the left-most digit 1 in the result is dropped. For example, 562 less 173 (equal to 389) is the same as 562 plus 827 (equal to 1389) less 1000. power, square, cube, reciprocal, etc. A _power_ of any number _a_ is _a_ multiplied by itself some number of times. _a_ × _a_ × _a_ ... × _a_ where _a_ appears _b_ times is written _a_ᵇ and is read _a_ to the _b_th power. _a_², a to the 2nd power, is _a_ × _a_ and is called _a squared_ or the _square_ of _a_. _a_³, _a_ to the 3rd power, _a_ × _a_ × _a_, is called _a cubed_, or the _cube_ of _a_. _a_⁰, _a_ to the zero power, is equal to 1 for every _a_. _a_¹, _a_ to the power 1, is _a_ itself. The first power is often called _linear_. _a_ to some negative power is the same as 1 divided by that power; that is, _a_⁻ᵇ = 1/_a_ᵇ. _a_⁻¹, _a_ to the power minus 1, is 1/_a_, and is called the _reciprocal_ of _a_. _a_¹ᐟ², _a_ to the one-half power, is a number _c_ such that _c_ × _c_ = _a_, and is called the _square root_ of _a_ and often denoted by √_a_. table, tabular value, argument, etc. An example of a _table_ is: 0.025 0.03 +—————————————————— 1 | 1.02500 1.03000 | 2 | 1.05063 1.06090 | 3 | 1.07689 1.09273 The numbers in the body of the table, called _tabular values_, depend on or are determined by the numbers along the edge of the table, called _arguments_. In this example, if 1, 2, 3 are choices of a number _n_, and if 0.025, 0.03 are choices of a number _i_, then each tabular value _y_ is equal to 1 plus _i_ raised to the _n_th power. _n_ and _i_ are also called _independent variables_, and _y_ is called the _dependent variable_. The table expresses a _function_ or _formula_ or _rule_. The rule could be stated as: add _i_ to 1; raise the result to the _n_th power. constant A number is said to be a _constant_ if it has the same value under all conditions. For example, in the formula: (area of a circle) = π × (radius)², π is a constant, equal to 3.14159 ..., applying equally well to all circles. infinity Mathematics recognizes several kinds of infinity. One of them occurs when numbers become very large. For example, the quotient of 12 divided by a number _x_, as _x_ becomes closer and closer to 0, becomes indefinitely large, and the limit is called _infinity_ and is denoted ∞. equation, simultaneous, linear An example of two linear simultaneous _equations_ is: 7_x_ + 8_t_ = 22 3_x_ + 5_t_ = 11 _x_ and _t_ are called _unknowns_—that is, unknown variables—because the objective of solving the equations is to find them. These equations are called _simultaneous_ because they are to be solved together, at the same time, for values of _x_ and _t_ which will fit in both equations. The equations are called _linear_ because the only powers of the unknowns that appear are the first power. Values that solve equations are said to _satisfy_ them. It is easy to solve these two equations and find that _x_ = 2 and _t_ = 1 is their solution. But it is a long process to solve 10 linear simultaneous equations in 10 unknowns, and it is almost impossible (without using a mechanical brain) to solve 100 linear simultaneous equations in 100 unknowns. derivative, integral, differential equation, etc. See the sections in Chapter 5 entitled “Differential Equations,” “Physical Problems,” and “Solving Physical Problems.” There these ideas and, to some extent, also the following ideas were explained: formula, equation, function, differential function, instantaneous rate of change, interval, inverse, integrating. See also a textbook on calculus. If _y_ is a function of _x_, then a mathematical symbol for the derivative of _y_ with respect to _x_ is _Dₓ y_, and a symbol for the integral of _y_ with respect to _x_, is ∫_y dx_. An integral with given initial conditions (see p. 83) is a _definite integral_. exponential A famous mathematical function is the _exponential_. It equals the constant _e_ raised to the _x_ power, _eˣ_, where _e_ equals 2.71828.... The exponential lies between the powers of 2 and the powers of 3. It can be computed from: _x_² _x_³ _eˣ_ = 1 + _x_ + —————— + ————————— + ... 1 · 2 1 · 2 · 3 It is a solution of the differential equation _Dₓy_ = _y_. See also a textbook on calculus. The _exponential to the base 10_ is 10ˣ. logarithm Another important mathematical function is the _logarithm_. It is written log _x_ or logₑ _x_ and can be computed from the two equations: log _uv_ = log _u_ + log _v_ _x_² _x_³ log(1 + _x_) = _x_ - —————— + —————— - ..., _x_² < 1 2 3 It is a solution of the differential equation _Dₓy_ = 1/_y_. If _y_ is the logarithm of _x_, then _x_ is the _antilogarithm_ of _y_. The _logarithm to the base 10_ of _x_, log₁₀ _x_, equals the _logarithm to the base e_ of _x_, logₑ _x_, divided by logₑ 10. See also textbooks on algebra and calculus. sine, cosine, tangent, antitangent These also are important mathematical functions. The _sine_ and _cosine_ are solutions of the differential equation _Dₓ_(_Dₓy_) =-_y_ and are written as sin _x_ and cos _x_. They can be computed from _x_³ _x_⁵ sin _x_ = _x_ - —————— + ————————— - ... 1·2·3 1·2·3·4·5 _x_² _x_₄ cos _x_ = 1 - —————— + —————— - ... 1·2 1·2·3·4 The _tangent_ of _x_ is simply sine of _x_ divided by cosine of _x_. If _y_ is the tangent of _x_, then _x_ is the _antitangent_ of _y_. See also references on trigonometry and on calculus. _Trigonometric_ tables include sine, cosine, tangent, and related functions. Bessel functions These are mathematical functions that were named after Friedrich W. Bessel, a Prussian astronomer who lived from 1784 to 1846. Bessel functions are found as some of the solutions of the differential equation _x_² _Dₓ_(_Dₓy_) + x _Dₓy_ + (_x_² - _n_²)_y_ = O This equation arises in a number of physical problems in the fields of electricity, sound, heat flow, air flow, etc. matrix A _matrix_ is a table (or _array_) of numbers in rows and columns, for which addition, multiplication, etc., with similar tables is specially defined. For example, the matrix ⎮1 2⎮ ⎮ ⎮ ⎮3 4⎮ plus the matrix ⎮5 20⎮ ⎮ ⎮ ⎮60 100⎮ equals the matrix ⎮6 22⎮ ⎮ ⎮ ⎮63 104⎮. (Can you guess the rule defining addition?) Calculations using matrices are useful in physics, engineering, psychology, statistics, etc. To add a _square matrix_ of 100 terms in an array of 10 columns and 10 rows to another such matrix, 100 ordinary additions of numbers are needed. To multiply one such matrix by another, 1000 ordinary multiplications and 900 ordinary additions are needed. See references on matrix algebra and matrix calculus. differences, smoothness, checking On p. 221, a sequence of values of _y_ is shown: 26, 37, 50, 65, 82. Suppose, however, the second value of _y_ was reported as 47 instead of 37. Then the _differences_ of _y_ as we pass down the sequence would not be 11, 13, 15, 17 (which is certainly regular or _smooth_) but 21, 3, 15, 17 (which is certainly not smooth). The second set of differences would strongly suggest a mistake in the reporting of _y_. The _smoothness_ of differences is often a useful check on a sequence of reported values. Supplement 3 REFERENCES A book like the present one can cover only a part of the subject of machines that think. To obtain more information about these machines and other topics to which they are related there are many references that may be consulted. There are still few books directly on the subject of machines that think, but there are many articles and papers, most of them rather specialized. The purpose of this supplement is to give a number of these references and to provide a brief, general introduction to some of them. The references are subdivided into groups, each dealing with a branch of the subject. The references in each group are in alphabetical order by name of author (with “anonymous” last), and under each author they are in chronological order by publication date. Some publications, especially a forum or symposium, are listed more than once, according as the topic discussed falls in different groups. In this supplement, the sign three dots ( ...) next to the page numbers for an article indicates that the article is continued on later, nonconsecutive pages. It seemed undesirable to try to make the group of references dealing with a subject absolutely complete, so long as enough were given to provide a good introduction to the subject. It proved impractical to try to make the citation of every single reference technically complete, so long as enough citation was given so that the reference could certainly be found. Furthermore, in a list of more than 250 references, errors are almost certain to occur. If any reader should send me additions or corrections, I shall be more than grateful. THE HUMAN BRAIN No one yet knows specifically how particular ideas are thought about in the human brain. The references listed in this section, however, contain some information about such topics as: The structural differences, development, and evolution of the brains of animals, apes, primitive man, and modern man. The effect on the brain of blood composition, body temperature, supply of oxygen, and other biochemical factors. The structure and physiology of the brain, the nervous system, and nerve impulses. The theory of learning, intelligence, and memory. BARCROFT, JOSEPH, _The Brain and Its Environment_, New Haven: Yale University Press, 1948, 117 pp. BEACH, FRANK A., Payday for Primates, _Natural History_, vol. 56, no. 10, Dec. 1947, pp. 448-451. BEACH, FRANK A., Can Animals Reason? _Natural History_, vol. 57, no. 3, Mar. 1948, pp. 112-116 ... BERRY, R. J. A., _Brain and Mind, or the Nervous System of Man_, New York: The Macmillan Co., 1928, 608 pp. BORING, EDWIN G., _A History of Experimental Psychology_, New York: Century Co., 1929, 699 pp. FRANZ, SHEPHERD I., _The Evolution of an Idea; How the Brain Works_, Los Angeles: University of California, 1929, 35 pp. HERRICK, C. JUDSON, _The Thinking Machine_, Chicago: University of Chicago Press, 1929, 374 pp. HERRICK, C. JUDSON, _Brains of Rats and Men_, Chicago: University of Chicago Press, 1930, 382 pp. LASHLEY, KARL S., _Brain Mechanisms and Intelligence_, Chicago: University of Chicago Press, 1929, 186 pp. PIERON, HENRI, _Thought and the Brain_, London: Kegan, Paul, Trench, Trübner & Co., 1927, 262 pp. Also New York: Harcourt, Brace & Co. SCHRÖDINGER, ERWIN, _What is Life?_, New York: The Macmillan Co., 1945, 90 pp. SHERRINGTON, CHARLES S., _The Brain and Its Mechanism_, Cambridge, England: The University Press, 1933, 35 pp. TILNEY, FREDERICK, _The Brain from Ape to Man_, New York: P. B. Hoeber, Inc., 1928, 2 vol., 1075 pp. WIENER, NORBERT, _Cybernetics, or Control and Communication in the Animal and the Machine_, New York: John Wiley & Sons, 1948, 194 pp. ANONYMOUS, Ten Billion Relays, _Time_, Feb. 14, 1949, p. 67. MATHEMATICAL BIOPHYSICS There has recently been another approach to the problem: How does a brain think? A group of men, many of them in and near Chicago, have been saying: “We know the properties of nerves, nerve impulses, and simple nerve networks. We know the activity of the brain. What mathematical model of nerve networks is necessary to account for the activity of the brain?” These men have used mathematics, statistics, and mathematical logic in the effort to attack this problem, and they support a _Bulletin of Mathematical Biophysics_. HOUSEHOLDER, ALSTON S., A Neural Mechanism for Discrimination, _Psychometrika_, vol. 4, no. 1, Dec. 1939, pp. 45-58. HOUSEHOLDER, ALSTON S., and Herbert D. Landahl, _Mathematical Biophysics of the Central Nervous System_, Bloomington, Ind.: Principia Press, 1945. LANDAHL, HERBERT D., Contributions to the Mathematical Biophysics of the Central Nervous System, _Bulletin of Mathematical Biophysics_, vol. 1, no. 2, June 1939, pp. 95-118. LANDAHL, HERBERT D., WARREN S. MCCULLOCH, and WALTER PITTS, A Statistical Consequence of the Logical Calculus of Nervous Nets, _Bulletin of Mathematical Biophysics_, vol. 5, no. 4, Dec. 1943, pp. 135-137. LANDAHL, HERBERT D., A Note on the Mathematical Biophysics of Central Excitation and Inhibition, _Bulletin of Mathematical Biophysics_, vol. 7, no. 4, Dec. 1945, pp. 219-221. LETTVIN, JEROME Y., and WALTER PITTS, A Mathematical Theory of the Affective Psychoses, _Bulletin of Mathematical Biophysics_, vol. 5, no. 4, Dec. 1943, pp. 139-148. MCCULLOCH, WARREN S., and WALTER PITTS, A Logical Calculus of the Ideas Immanent in Nervous Activity, _Bulletin of Mathematical Biophysics_, vol. 5, no. 4, Dec. 1943, pp. 115-133. RASHEVSKY, N., _Mathematical Biophysics_, Chicago: University of Chicago Press. Revised edition, 1948, 669 pp. RASHEVSKY, N., Mathematical Biophysics of Abstraction and Logical Thinking, _Bulletin of Mathematical Biophysics_, vol. 7, no. 3, Sept. 1945, pp. 133-148. RASHEVSKY, N., Some Remarks on the Boolean Algebra of Nervous Nets in Mathematical Biophysics, _Bulletin of Mathematical Biophysics_, vol. 7, no. 4, Dec. 1945, pp. 203-211. RASHEVSKY, N., A Suggestion for Another Statistical Interpretation of the Fundamental Equations of the Mathematical Biophysics of the Central Nervous System, _Bulletin of Mathematical Biophysics_, vol. 7, no. 4, Dec. 1945, pp. 223-226. RASHEVSKY, N., The Neural Mechanism of Logical Thinking, _Bulletin of Mathematical Biophysics_, vol. 8, no. 1, Mar. 1946, pp. 29-40. LANGUAGES: WORDS AND SYMBOLS FOR THINKING Hardly any field of techniques for thinking is more fascinating than language. The following list of references, of course, is short; it is meant chiefly as an introduction pointing out a number of different paths into the field of language and languages. Such topics as the following are introduced by the references in this list: The origin of languages and alphabets. The languages of the world, and speech communities. The comparison of words and structure from language to language. The significance of grammar and syntax. The problem of clear meanings. Writing and speaking that is easy to understand. BLOOMFIELD, LEONARD, _Language_, New York: Henry Holt & Co., 1933, 564 pp. BODMER, FREDERICK, and LAUNCELOT HOGBEN, _The Loom of Language_, New York: W. W. Norton & Co., 1944, 692 pp. FLESCH, RUDOLF, _The Art of Plain Talk_, New York: Harper & Brothers, 1946, 210 pp. GRAFF, WILLEM L., _Language and Languages: An Introduction to Linguistics_, New York: D. Appleton & Co., 1932, 487 pp. HAYAKAWA, S. I., _Language in Action_, New York: Harcourt, Brace & Co., 1941, 345 pp. JESPERSEN, OTTO, _The Philosophy of Grammar_, New York: Henry Holt & Co., 1929 (third printing), 359 pp. JESPERSEN, OTTO, _Analytic Syntax_, In this book, by means of a well-contrived system of letters and signs, the great linguistic scholar Jespersen depicts all the important inter-relations of English words and parts of words in connected speech. OGDEN, C. K., _The System of Basic English_, New York: Harcourt, Brace & Co., 1934, 320 pp. SCHLAUCH, MARGARET, _The Gift of Tongues_, New York: Modern Age Books, 1942, 342 pp. WALPOLE, HUGH R., _Semantics: The Nature of Words and Their Meanings_, New York: W. W. Norton & Co., 1941, 264 pp. LANGUAGES: MACHINES FOR THINKING For many years, nearly all references about machines as a language for thinking have been specialized and limited. Colleges with scholars who write textbooks usually have not had a variety of expensive and versatile computing machinery. As a result, the main environment for stimulating possible authors has until recently been missing. The list of references is accordingly brief. AIKEN, HOWARD H., and others, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, 302 pp. COMRIE, JOHN LESLIE, The Application of Commercial Calculating Machines to Scientific Computing, _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 16, Oct. 1946, pp. 149-159. CREW, E. W., Calculating Machines, _The Engineer_, vol. 172, Dec. 1941, pp. 438-441. FRY, MACON, _Designing Computing Mechanisms_, Cleveland, Ohio: Penton Publishing Co., 1946, 48 pp. (Reprinted from _Machine Design_, Aug. 1945 through Feb. 1946.) HARTREE, D. R., _Calculating Machines: Recent and Prospective Developments and Their Impact on Mathematical Physics_, Cambridge, England: The University Press, 1947, 40 pp. HORSBURGH, E. H., _Modern Instruments and Methods of Calculation_, London: G. Bell and Sons, Ltd., 1914, 343 pp. LILLEY, S., Mathematical Machines, _Nature_, vol. 149, Apr. 25, 1942, pp. 462-465. MURRAY, FRANCIS J., _The Theory of Mathematical Machines_, New York: King’s Crown Press, 1947, 116 pp. The author states that a mathematical machine is a mechanism that provides information concerning the relationships among a specified set of mathematical concepts. TURCK, J. A. V., _The Origin of Modern Calculating Machines_, Chicago: Western Society of Engineers, 1921. Recently, however, some magazine and newspaper publishers have seen news value in machines that think, and some good general articles with appeal to a wide audience have appeared. For the references to these articles, see the section of this supplement entitled “Digital Machines—Miscellaneous.” PUNCH-CARD CALCULATING MACHINES There are a few general references on punch-card calculating machines: BAEHNE, G. WALTER, editor, and others, _Practical Applications of the Punched Card Method in Colleges and Universities_, New York: Columbia University Press, 1935, 442 pp. This is a collection of many contributions from a number of authors, describing various applications, chiefly educational. ECKERT, W. J., _Punched-Card Methods in Scientific Computation_, New York: Columbia University, The Thomas J. Watson Astronomical Computing Bureau, 1940, 136 pp. This is a scientific treatise, chiefly relating to the computation of orbits in astronomy. HARTKEMEIER, HARRY PELLE, _Principles of Punch-Card Machine Operation_ (Subtitle: _How to Operate Punch-Card Tabulating and Alphabetic Accounting Machines_), New York: Thomas Y. Crowell Co., 1942, 269 pp. This is based on the author’s experience in teaching statistical analysis using IBM tabulators. The book does not deal with the collator or multiplying punch. HEDLEY, K. J., _The Development of the Punched-Card Method_, Actuarial Society of Australasia, 1946, 20 pp. INTERNATIONAL BUSINESS MACHINES CORPORATION, _International Business Machines_ (form no. A-4036-6-45), New York: International Business Machines Corporation, 1945, 65 pp. Pages 6 to 31 show pictures and brief descriptions of about 20 punch-card machines, available in 1945. SCHNACKEL, H. G., and H. C. LANG, _Accounting by Machine Methods_, New York: Ronald Press Co., 1939, 53 pp. WOLF, ARTHUR W., and EDMUND C. BERKELEY, _Advanced Course in Punched Card Operations_, Newark, N. J.: Prudential Insurance Company of America, 1942, 98 pp. A useful and authoritative description of IBM punch-card calculating machinery is the following: INTERNATIONAL BUSINESS MACHINES CORPORATION, DEPARTMENT OF EDUCATION, _Machine Methods of Accounting_, Endicott, N. Y.: International Business Machines Corporation, 1936-41, 385 pp. This is a collection of 28 separate booklets telling the detailed operation of IBM punch-card machinery. They were written for employees of IBM and users of IBM equipment. The following list of the booklets is useful in locating them: NO. OF TITLE FORM NO. DATE PAGES Machine Methods of Accounting—Foreword AM 1936 6 Development of IBM Corporation AM-1-1 1936 14 Principles of the Electric Accounting Machine Method AM-2 1936 12 The Tabulating Card AM-3-1 1936 20 Design of Tabulating Cards AM-4-1 1936 16 Preparation and Use of Codes AM-5 1936 28 Organization and Supervision of the Tabulating Department AM-6 1936 16 Selection and Training of Key Punch Operators AM-7 1936 12 Accounting Control AM-8 1936 8 Punches AM-9 1936 12 Alphabetic Printing Punches AM-10 1936 7 Facts to Know about Key Punches AM-11 1936 4 Verifiers AM-12 1936 4 Gang Punches AM-13 1936 8 Card-Operated Sorting Machines AM-14 1936 12 Facts to Know about Sorters AM-14a 1936 4 Electric Tabulating Machines AM-15 1936 20 Electric Accounting Machines (Type 285 and Type 297) AM-16 1936 16 Alphabetic Direct Subtraction Accounting Machine AM-17 1936 28 Numerical Interpreters AM-18 1936 8 Electric Punched-Card Interpreter (Type 552) AM-18a 1941 8 Reproducing Punches (Type 512) AM-19 1936 16 Automatic Summary Punches for Use with the Numerical Accounting Machines (Type 285-297) AM-20 1936 16 Automatic Summary Punches for Use with the Alphabetic Accounting Machines (Type 405) AM-20a 1940 16 Multiplying Punches AM-21 1936 16 Application of Machines to Accounting Functions AM-22 1936 24 Other International Products AM-23-2 1936 19 The International Automatic Carriage (Type 921) AM-24 1938 15 The Department of Education of IBM has begun a second series of booklets on the principles of operation of punch-card calculating machinery: INTERNATIONAL BUSINESS MACHINES CORPORATION, DEPARTMENT OF EDUCATION, _Principles of Operation_, Endicott, N. Y.: International Business Machines Corporation, 1942 and later (except for one published in 1939). Many of the booklets in this series have good examples of machine operation and applications. Also, for the first time, letters and numbers have been used as coordinates to label the hubs on the plugboards. This series includes the following: NO. OF TITLE FORM NO. DATE PAGES CARD PUNCHES AND VERIFIERS Card-Punching and Verifying Machines 52-3176-0 1946 21 Alphabetical Verifier, Type 055 52-3295-1 1946 4 INTERPRETERS Card Interpreters, Type 550, 551, and 552 52-3178-0 1946 14 REPRODUCERS Automatic Reproducing Punch, Type 513 52-3180-0 1945 22 End Printing Reproducing Punch, Type 519 52-3292-1 1946 26 Electric Document-Originating Machine, June Type 519 52-3292-2 1948 26 COLLATORS Collator AM-25 1943 31 Collator Counting Device C.R. 9178 1942 12 CALCULATING PUNCHES Electric Multiplier, Type 601 52-3408-1 1947 47 Calculating Punch, Type 602 52-3409-0 1946 83 Calculating Punch, Type 602 52-3409-5 1947 93 Calculating Punch, Type 602-A (Preliminary Manual) 22-5489-0 1948 59 Electronic Multiplier, Type 603 52-3561-0 1946 5 Electronic Calculating Punch, Type 604 22-5279-0 1948 51 TABULATORS Accounting Machine, Type 402 and 403 (Preliminary Manual) 22-5654-0 1949 146 Alphabetical Accounting Machine, Type 404 52-3395-1 1946 96 Typical Applications, Alphabetical Accounting Machine, Type 404, with Multiple Line Printing 22-3771-1 1947 47 Alphabetical Accounting Machine, Type 405 AM 17 (1), 1943 90 Revised 1/1/43 Nov. Alphabetical Accounting Machine, Type 405 52-3179-2 1948 81 AUTOMATIC PRINTING CARRIAGES Bill Feed, Type 920 52-3184-0 1945 21 Form Feeding Device 52-3235-0 1946 11 Automatic Carriage, Type 921 52-3183-0 1945 36 Tape-Controlled Carriage (Preliminary Manual, Revised) 22-5415-1 1948 27 TEST SCORING MACHINE Test Scoring Machine 94-2333-0 1939 19 May Test Scoring Machine 32-9145-1 1946 20 Published Tests Adapted for Use with June the IBM Electric Test Scoring Machine 27-4286-9 1948 8 In addition to the new types of punch-card machines referred to in the above list, an elaborate punch-card calculating machine is described in the following reference: ECKERT, W. J., The IBM Pluggable Sequence Relay Calculator, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 23, July 1948, pp. 149-161. A description of punch-card machinery in rather a light vein is contained in: ANONYMOUS, Speaking of Pictures: New Mechanical Monsters Ease _Life’s_ Growing Pains, _Life_, Sept. 15, 1947, pp. 15-16. ANONYMOUS, _540_, Chicago: Time-Life-Fortune Magazine, Subscription Fulfillment Office, 1948, 15 pp. New types of punch-card machinery are continually coming into use. Among them are: machines that take in punch cards and make punched paper tape (such as teletype tape), and vice versa—useful for transmitting punch-card information over wires; an electric typewriter operated by punch cards—useful for preparing almanacs for sea and air navigation, etc.; a calculator programmed by punch cards, consisting of an assembly of a tabulator, an electronic calculating punch, and an auxiliary storage unit, all cabled together—useful for some types of long calculation; etc. For information about such machinery, the manufacturers may be consulted. PUNCH-CARD CALCULATING MACHINERY: APPLICATIONS There are many articles in scientific journals on applications of punch-card calculating machinery to technical problems. The fields of engineering, education, indexing, mathematics, surveying, statistics, and others are all represented in the following list of sample references: ALT, FRANZ L., Multiplication of Matrices, _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 13, Jan. 1946, pp. 12-13. BAILEY, C. F., and others, Punch Cards for Indexing Scientific Data, _Science_, vol. 104, Aug. 23, 1946, p. 181. BOWER, E. C., On Subdividing Tables, _Lick Observatory Bulletin_, vol. 16, no. 455, Nov. 1933, pp. 143-144. BOWER, E. C., Systematic Subdivision of Tables, _Lick Observatory Bulletin_, vol. 17, no. 467, Apr. 1935, pp. 65-74. CLEMENCE, G. M., and PAUL HERGET, Optimum-Interval Punched-Card Tables, _Mathematical Tables and Other Aids to Computation_, vol. 1, no. 6, Apr. 1944, pp. 173-176. CULLEY, FRANK L., Use of Accounting Machines for Mass-Transformation from Geographic to Military-Grid Coordinates, Washington, D. C.: National Research Council, _American Geophysical Union Transactions of 1942_, part 2, pp. 190-197. DEMING, W. EDWARDS, and MORRIS H. HANSEN, On Some Census Aids to Sampling, _Journal of the American Statistical Association_, vol. 38, no. 225, Sept. 1943, pp. 353-357. DUNLAP, JACK W., The Computation of Means, Standard Deviations, and Correlations by the Tabulator When the Numbers Are Both Positive and Negative, _Proceedings of the Educational Research Forum_, International Business Machines Corporation, Aug. 1940, pp. 16-19. DWYER, PAUL S., The Use of Tables in the Form of Prepunched Cards, _Proceedings of the Educational Research Forum_, International Business Machines Corporation, Aug. 1940, pp. 125-127. DWYER, PAUL S., Summary of Problems in the Computation of Statistical Constants with Tabulating and Sorting Machines, _Proceedings of the Educational Research Forum_, International Business Machines Corporation, Aug. 1940, pp. 20-28. DWYER, PAUL S., and ALAN D. MEACHAM, The Preparation of Correlation Tables on a Tabulator Equipped with Digit Selection, _Journal of the American Statistical Association_, vol. 32, 1937, pp. 654-662. DYER, H. S., Making Test Score Data Effective in the Admission and Course Placement of Harvard Freshmen, _Proceedings of the Research Forum_, International Business Machines Corporation, 1946, pp. 55-62. ECKERT, W. J., and RALPH F. HAUPT, The Printing of Mathematical Tables, _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 17, Jan. 1947, pp. 196-202. FEINSTEIN, LILLIAN, and MARTIN SCHWARZCHILD, Automatic Integration of Linear Second-Order Differential Equations by Means of Punched-Card Machines, _Review of Scientific Instruments_, vol. 12, no. 8, Aug. 1941, pp. 405-408. HOTELLING, HAROLD, Some New Methods in Matrix Calculation, _The Annals of Mathematical Statistics_, vol. 14, no. 1, Mar. 1943, pp. 1-34. INTERNATIONAL BUSINESS MACHINES CORPORATION, editor, and others, _Proceedings of the Educational Research Forum_, Endicott, N. Y.: International Business Machines Corporation, 1941. INTERNATIONAL BUSINESS MACHINES CORPORATION, editor, and others, _Proceedings of the Research Forum_, Endicott, N. Y.: International Business Machines Corporation, 1946, 94 pp. KING, GILBERT W., Punched-Card Tables of the Exponential Function, _Review of Scientific Instruments_, vol. 15, no. 12, Dec. 1944, pp. 349-350. KING, GILBERT W., and GEORGE B. THOMAS, Preparation of Punched-Card Tables of Logarithms, _Review of Scientific Instruments_, vol. 15, no. 12, Dec. 1944, p. 350. KORMES, MARK, A Note on the Integration of Linear Second-Order Differential Equations by Means of Punched Cards, _Review of Scientific Instruments_, vol. 14, no. 4, Apr. 1943, p. 118. KORMES, MARK, Numerical Solution of the Boundary Value Problem for the Potential Equation by Means of Punched Cards, _Review of Scientific Instruments_, vol. 14, no. 8, Aug. 1943, pp. 248-250. KORMES, MARK, and JENNIE P. KORMES, Numerical Solution of Initial Value Problems by Means of Punched-Card Machines, _Review of Scientific Instruments_, vol. 16, no. 1, Jan. 1945, pp. 7-9. KUDER, G. FREDERIC, Use of the IBM Scoring Machine for Rapid Computation of Tables of Intercorrelations, _Journal of Applied Psychology_, vol. 22, no. 6, Dec. 1938, pp. 587-596. MAXFIELD, D. K., Library Punched Card Procedures, _Library Journal_, vol. 71, no. 12, June 15, 1946, pp. 902-905 ... MCLAUGHLIN, KATHLEEN, Adding Machines Nip AEF Epidemics, New York: _New York Times_, Apr. 27, 1945. MCPHERSON, JOHN C., On Mechanical Tabulation of Polynomials, _Annals of Mathematical Statistics_, Sept. 1941, pp. 317-327. MCPHERSON, JOHN C., Mathematical Operations with Punched Cards, _Journal of the American Statistical Association_, vol. 37, June 1942, pp. 275-281. MILLIMAN, WENDELL A., Mechanical Multiplication by the Use of Tabulating Machines, _Transactions of the Actuarial Society of America_, vol. 35, part 2, Oct. 1934, pp. 253-264; for discussion see also vol. 36, part 1, May 1935, pp. 77-84. ROYER, ELMER B., A Machine Method for Computing the Biserial Correlation Coefficient in Item Validation, _Psychometrika_, vol. 6, no. 1, Feb. 1941, pp. 55-59. WHITTEN, C. A., Triangulation Adjustment by International Business Machines, Washington, D. C.: National Research Council, _American Geophysical Union Transactions of 1943_, part 1, p. 31. The following bibliography may be obtained on request to the Watson Scientific Computing Laboratory, Columbia University, 612 West 116 Street, New York 27, N. Y.: WATSON SCIENTIFIC COMPUTING LABORATORY, _Bibliography: The Use of IBM Machines in Scientific Research, Statistics, and Education_, New York: International Business Machines Corporation (form no. 50-3813-0), Sept. 1947, 25 pp. The organization and equipment of this laboratory are described in: ECKERT, W. J., Facilities of the Watson Scientific Computing Laboratory, _Proceedings of the Research Forum_, International Business Machines Corporation, 1946, pp. 75-80. THE DIFFERENTIAL ANALYZER The basic scientific articles on the two differential analyzers at Massachusetts Institute of Technology are: BUSH, VANNEVAR, The Differential Analyzer: A New Machine for Solving Differential Equations, _Journal of the Franklin Institute_, vol. 212, no. 4, Oct. 1931, pp. 447-488. BUSH, VANNEVAR, and SAMUEL H. CALDWELL, A New Type of Differential Analyzer, _Journal of the Franklin Institute_, vol. 240, no. 4, Oct. 1945, pp. 255-326. Some of the less technical articles about the second differential analyzer at M.I.T. are: CALDWELL, SAMUEL H., Educated Machinery, _Technology Review_, vol. 48, no. 1, Nov. 1945, pp. 31-34. GENET, N., 100-Ton Brain at M.I.T., _Scholastic_, vol. 48, Feb. 4, 1946, p. 36. ANONYMOUS, Mathematical Machine; New Electronic Differential Analyzer, _Science News Letter_, vol. 48, Nov. 10, 1945, p. 291. ANONYMOUS, Robot Einstein: Differential Analyzer at M.I.T., _Newsweek_, vol. 26, Nov. 12, 1945, p. 93. ANONYMOUS, M.I.T.’s 100-Ton Mathematical Brain is Now to Tackle Problems of Peace, _Popular Science_, vol. 148, Jan. 1946, p. 81. ANONYMOUS, The Great Electro-Mechanical Brain; M.I.T.’s Differential Analyzer, _Life_, vol. 20, Jan. 14, 1946, pp. 73-74 ... ANONYMOUS, All the Answers at Your Fingertips; in the Laboratory of M.I.T., _Popular Mechanics_, vol. 85, Mar. 1946, pp. 164-167 ... A differential analyzer was built at the Moore School of Electrical Engineering: TRAVIS, IRVEN, Differential Analyzer Eliminates Brain Fag, _Machine Design_, July 1935, pp. 15-18. A differential analyzer was built at the General Electric Company, Schenectady, N. Y. Instead of using a mechanical or electrical amplifier of the motion of the little turning wheel riding on the disc, this machine follows the motion using polarized light. This machine is described in: BERRY, T. M., Polarized Light Servo System, _Transactions of the American Institute of Electrical Engineers_, vol. 63, Apr. 1944, pp. 195-197. KUEHNI, H. P., and H. A. PETERSON, A New Differential Analyzer, _Transactions of the American Institute of Electrical Engineers_, vol. 63, May 1944, pp. 221-227. A differential analyzer has been put into use at the University of California: BOELTER, L. M. K., and others, _The Differential Analyzer of the University of California_, Los Angeles: University of California, 1947, 25 pp. A differential analyzer was built at Manchester University, England. It was built first from “Meccano” parts, at a total cost of about 20 pounds, and later refined for more exact work. Some articles dealing with this differential analyzer are: HARTREE, D. R., The Differential Analyzer, _Nature_, vol. 135, June 8, 1935, p. 940. HARTREE, D. R., The Mechanical Integration of Differential Equations, _The Mathematical Gazette_, vol. 22, 1938, pp. 342-364. HARTREE, D. R., and A. PORTER, The Construction of a Model Differential Analyser, _Memoirs and Proceedings of the Manchester Literary and Philosophical Society_, vol. 79, July 1935, pp. 51-72. Other small scale differential analyzers built in England are covered in: BEARD, R. E., The Construction of a Small Scale Differential Analyser and Its Application to the Calculation of Actuarial Functions, _Journal of the Institute of Actuaries_, vol. 71, 1942, pp. 193-227. MASSEY, H. S. W., J. WYLIE, and R. A. BUCKINGHAM, A Small Scale Differential Analyser: Its Construction and Operation, _Proceedings of the Royal Irish Academy_, vol. 45, 1938, pp. 1-21. A differential analyzer constructed in Germany is briefly described in the following: SAUER, R., and H. POESCH, Integrating Machine for Solving Ordinary Differential Equations, _Engineers Digest_ (American Edition), vol. 1, May 1944, pp. 326-328. From the historical point of view there are some interesting papers on a machine for solving differential equations by Sir William Thomson (Lord Kelvin), including one by his brother James Thomson. They are in the _Proceedings of the Royal Society_, vol. 24, Feb. 1876, pp. 262-275. The method of integration by a machine is described, but the state of machine tools at the time was such that no accurate mechanism was constructed. Another interesting paper foreshadowing the differential analyzer is: WAINWRIGHT, LAWRENCE L., _A Ballistic Engine_, Chicago: University of Chicago, thesis for Master’s Degree, 1923, 28 pp. Some of the applications and mathematical limitations of differential analyzers are covered in: BUSH, V., and S. H. CALDWELL, Thomas-Fermi Equation Solution by the Differential Analyzer, _Physical Review_, vol. 38, no. 10, 1931, pp. 1898-1902. HARTREE, D. R., A Great Calculating Machine: the Bush Differential Analyser and Its Applications in Science and Industry, _Proceedings of the Royal Institution of Great Britain_, vol. 31, 1940, pp. 151-170. HARTREE, D. R., and A. PORTER, The Application of the Differential Analyser to Transients on a Distortionless Transmission Line, _Journal of the Institute of Electrical Engineering_, vol. 83, no. 503, Nov. 1938, pp. 648-656. HARTREE, D. R., and J. R. WOMERSLEY, A Method for the Numerical or Mechanical Solution of Certain Types of Partial Differential Equations, _Proceedings of the Royal Society of London_, series A, vol. 161, 1937, pp. 353-366. MAGINNISS, F. J., Differential Analyzer Applications, _General Electric Review_, vol. 48, no. 5, May 1945, pp. 54-59. SHANNON, CLAUDE E., Mathematical Theory of the Differential Analyzer, _Journal of Mathematics and Physics_, Cambridge, Mass.: Massachusetts Institute of Technology, vol. 20, no. 4, 1941, pp. 337-354. HARMONIC ANALYZERS AND SYNTHESIZERS Another branch of the analogue calculating machine is the harmonic analyzer and synthesizer. These are machines that study wave motions and related physical and mathematical functions. A brief list of articles on this type of machine follows: ARCHER, R. M., Projecting Apparatus for Compounding Harmonic Vibrations, _Journal of Scientific Instruments_, vol. 14, 1937, pp. 408-410. BROWN, S. L., A Mechanical Harmonic Synthesizer-Analyzer, _Journal of the Franklin Institute_, vol. 228, 1939, pp. 675-694. BROWN, S. L., and L. L. WHEELER, A Mechanical Method for Graphical Solution of Polynomials, _Journal of the Franklin Institute_, vol. 231, 1941, pp. 223-243. BROWN, S. L., and L. L. WHEELER, Use of the Mechanical Multiharmonograph for Graphing Types of Functions and for Solution of Pairs of Non-Linear Simultaneous Equations, _Review of Scientific Instruments_, vol. 13, Nov. 1942, pp. 493-495. BROWN, S. L., and L. L. WHEELER, The Use of a Mechanical Synthesizer to Solve Trigonometric and Certain Types of Transcendental Equations, and for the Double Summations Involved in Patterson Contours, _Journal of Applied Physics_, vol. 14, Jan. 1943, pp. 30-36. FÜRTH, R., and R. W. PRINGLE, A New Photo-Electric Method for Fourier Synthesis and Analysis, _London, Edinburgh and Dublin Philosophical Magazine and Journal of Science_, vol. 35, series 7, 1944, pp. 643-656. INTERNATIONAL HYDROGRAPHIC BUREAU, _Tide Predicting Machines_, International Hydrographic Bureau, Special Publication 13, July 1926. KRANZ, FREDERICK W., A Mechanical Synthesizer and Analyzer, _Journal of the Franklin Institute_, vol. 204, 1927, pp. 245-262. MARBLE, F. G., An Automatic Vibration Analyzer, _Bell Laboratories Record_, vol. 22, Apr. 1944, pp. 376-380. MAXWELL, L. R., An Electrical Method for Compounding Sine Functions, _Review of Scientific Instruments_, vol. 11, Feb. 1940, pp. 47-54. MILLER, DAYTON C., A 32-Element Harmonic Synthesizer, _Journal of the Franklin Institute_, vol. 181, 1916, pp. 51-81. MILLER, DAYTON C., The Henrici Harmonic Analyzer and Devices for Extending and Facilitating Its Use, _Journal of the Franklin Institute_, vol. 182, 1916, pp. 285-322. MILNE, J. R., A “Duplex” Form of Harmonic Synthetiser and Its Mathematical Theory, _Proceedings of the Royal Society of Edinburgh_, vol. 39, 1918-19, pp. 234-242. MONTGOMERY, H. C., An Optical Harmonic Analyzer, _Bell System Technical Journal_, vol. 17, no. 3, July 1938, pp. 406-415. RAYMOND, W. J., An Harmonic Synthesizer Having Components of Incommensurable Period and Any Desired Decrement, _Physical Review_, vol. 11, series 2, 1918, pp. 479-481. ROBERTSON, J. M., A Simple Harmonic Continuous Calculating Machine, _London, Edinburgh and Dublin Philosophical Magazine and Journal of Science_, vol. 13, 1932, pp. 413-419. SOMERVILLE, J. M., Harmonic Synthesizer for Demonstrating and Studying Complex Wave Forms, _Journal of Scientific Instruments_, vol. 21, Oct. 1944, pp. 174-177. STRAITON, A. W., and G. K. TERHUNE, Harmonic Analysis by Photographic Method, _Journal of Applied Physics_, vol. 14, 1943, pp. 535-536. WEGEL, R. L., and C. R. MOORE, An Electrical Frequency Analyzer, _Bell System Technical Journal_, vol. 3, 1924, pp. 299-323. NETWORK ANALYZERS A third branch of the analogue calculating machine is the network analyzer. To solve problems, this machine uses the laws governing a network of electrical circuits. For example, an electric power company with a system of power lines over hundreds of miles may have a problem about electrical power: will an accident or a sudden demand cause a breakdown anywhere in the system? In the General Electric Company in Schenectady, N. Y., there is a machine called the A.C. Network Analyzer. All the properties of the power company’s network of lines can be fed on a small scale into the analyzer. Certain dials are turned and certain plugwires are connected. Then various kinds of “accidents” and “sudden demands” are fed into the machine, and the response of the system is noted. The answers given by the machine are multiplied by the proper scale factor, and in this way the problem of the power company is solved. There are two kinds of problems that network analyzers are built to solve: the steady state conditions and the transient conditions. For example, you may not overload a fuse with an electric iron when it is plugged in and being used, but as you pull out the cord, you may blow the fuse: the steady state does not overstrain the system, but the transient does. Some articles on network analyzers are: ENNS, W. E., A New Simple Calculator of Load Flow in A.C. Networks, _Transactions of the American Institute of Electrical Engineers_, vol. 62, 1943, pp. 786-790. HAZEN, H. L., and others, _The M.I.T. Network Analyzer_, Cambridge, Mass.: Massachusetts Institute of Technology, Department of Electrical Engineering, Serial No. 69, Apr. 1931. KUEHNI, H. P., and R. G. LORRAINE, A New A.C. Network Analyzer, _Transactions of the American Institute of Electrical Engineers_, vol. 57, 1938, pp. 67-73. PARKER, W. W., Dual A.C. Network Calculator, _Electrical Engineering_, May 1945, pp. 182-183. PARKER, W. W., The Modern A.C. Network Calculator, _Transactions of the American Institute of Electrical Engineers_, vol. 60, Nov. 1941, pp. 977-982. PETERSON, H. A., An Electric Circuit Transient Analyzer, _General Electric Review_, Sept. 1939, pp. 394-400. VARNEY, R. N., An All-Electric Integrator for Solving Differential Equations, _Review of Scientific Instruments_, vol. 13, Jan. 1942, pp. 10-16. Some of the articles on applications of network analyzers to various problems are: KRON, GABRIEL, Equivalent Circuits of the Elastic Field, _Journal of Applied Mechanics_, vol. A11, Sept. 1944, pp. 146-161. KRON, GABRIEL, Tensorial Analysis and Equivalent Circuits of Elastic Structures, _Journal of the Franklin Institute_, vol. 238, Dec. 1944, pp. 399-442. KRON, GABRIEL, Numerical Solution of Ordinary and Partial Differential Equations by Means of Equivalent Circuits, _Journal of Applied Physics_, vol. 16, 1945, pp. 172-186. KRON, GABRIEL, Electric Circuit Models for the Vibration Spectrum of Polyatomic Molecules, _Journal of Chemical Physics_, vol. 14, no. 1, Jan. 1946, pp. 19-31. KRON, G., and G. K. CARTER, A.C. Network Analyzer Study of the Schrödinger Equation, _Physical Review_, vol. 67, 1945, pp. 44-49. KRON, G., and G. K. CARTER, Network Analyzer Tests of Equivalent Circuits of Vibrating Polyatomic Molecules, _Journal of Chemical Physics_, vol. 14, no. 1, Jan. 1946, pp. 32-34. PETERSON, H. A., and C. CONCORDIA, Analyzers for Use in Engineering and Scientific Problems, _General Electric Review_, vol. 48, no. 9, Sept. 1945, pp. 29-37. MACHINES FOR SOLVING ALGEBRAIC EQUATIONS Another branch of the analogue calculating machine is a type of machine that will solve various kinds of algebraic equations (see Supplement 2). A list of some articles follows. The article by Mallock describes a machine for solving up to 10 linear simultaneous equations in 10 unknowns, and the article by Wilbur, a machine for solving up to 9. DIETZOLD, ROBERT L., The Isograph—A Mechanical Root-Finder, _Bell Laboratories Record_, vol. 16, no. 4, Dec. 1937, pp. 130-134. DUNCAN, W. J., Some Devices for the Solution of Large Sets of Simultaneous Linear Equations, _London, Edinburgh, and Dublin Philosophical Magazine and Journal of Science_, vol. 35, series 7, 1944, pp. 660-670. FRAME, J. SUTHERLAND, Machines for Solving Algebraic Equations, _Mathematical Tables and Other Aids to Computation_, vol. 1, no. 9, Jan. 1945, pp. 337-353. HART, H. C., and IRVEN TRAVIS, Mechanical Solution of Algebraic Equations, _Journal of the Franklin Institute_, vol. 225, Jan. 1938, pp. 63-72. HERR, D. L., and R. S. GRAHAM, An Electrical Algebraic Equation Solver, _Review of Scientific Instruments_, vol. 9, Oct. 1938, pp. 310-315. MALLOCK, R. R. M., An Electrical Calculating Machine, _Proceedings of the Royal Society_, series A, vol. 140, 1933, pp. 457-483. MERCNER, R. O., The Mechanism of the Isograph, _Bell Laboratories Record_, vol. 16, no. 4, Dec. 1937, pp. 135-140. STIBITZ, GEORGE R., Electric Root-finder, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 24, Oct. 1948, pp. 328-329. WILBUR, J. B., The Mechanical Solution of Simultaneous Equations, _Journal of the Franklin Institute_, vol. 222, Dec. 1936, pp. 715-724. ANALOGUE MACHINES—MISCELLANEOUS Some articles referring to various other kinds of analogue machines and their applications are here listed together: BUSH, V., F. D. GAGE, and R. R. STEWART, A Continuous Integraph, _Journal of the Franklin Institute_, vol. 203, 1927, pp. 63-84. GRAY, T. S., A Photo-Electric Integraph, _Journal of the Franklin Institute_, vol. 212, 1931, pp. 77-102. HAZEN, H. L., G. S. BROWN, and W. R. HEDEMAN, The Cinema Integraph: A Machine for Evaluating a Parametric Product Integral (two parts and appendix), _Journal of the Franklin Institute_, vol. 230, July 1940, pp. 19-44, and Aug. 1940, pp. 183-205. MCCANN, G. D., and H. E. CRINER, Mechanical Problems Solved Electrically, _Westinghouse Engineer_, vol. 6, no. 2, March 1946, pp. 49-56. MYERS, D. M., An Integraph for the Solution of Differential Equations of the Second-Order, _Journal of Scientific Instruments_, vol. 16, 1939, pp. 209-222. PEKERIS, C. L., and W. T. WHITE, Differentiation with the Cinema Integraph, _Journal of the Franklin Institute_, vol. 234, July 1942, pp. 17-29. SMITH, C. E., and E. L. GOVE, An Electromechanical Calculator for Directional-Antenna Patterns, _Transactions of the American Institute of Electrical Engineers_, vol. 62, 1943, pp. 78-82. YAVNE, R. O., High Accuracy Contour Cams, _Product Engineering_, vol. 19, part 2, Aug. 1948, 3 pp. ANONYMOUS, Electrical Gun Director Demonstrated, _Bell Laboratories Record_, vol. 22, no. 4, Dec. 1943, pp. 157-167. ANONYMOUS, Development of the Electric Director, _Bell Laboratories Record_, vol. 22, no. 5, Jan. 1944, pp. 225-230. ANONYMOUS, Old Field Fortune Teller: Electronic Oil Pool Analyzer, _Popular Mechanics_, vol. 86, Sept. 1946, p. 154. HARVARD IBM AUTOMATIC SEQUENCE-CONTROLLED CALCULATOR The basic scientific description of this machine as of September 1, 1945, is contained in: AIKEN, HOWARD H., and STAFF OF THE COMPUTATION LABORATORY, _A Manual of Operation for the Automatic Sequence-Controlled Calculator_, Cambridge, Mass.: Harvard University Press, 1946, 561 pp. The machine has changed rather a good deal since Sept. 1, 1945. Some circuits have been removed. Other circuits have been added. The capacity of the machine to do problems has been greatly increased. The Computation Laboratory at Harvard University is cordial towards scientific inquiries, and some unpublished, mimeographed information is available at the laboratory regarding the details of these changes. Some shorter scientific and technical descriptions of the machine are contained in: AIKEN, HOWARD H., and GRACE M. HOPPER, The Automatic Sequence Controlled Calculator (3 parts), _Electrical Engineering_, vol. 65, nos. 8, 9, and 10, Aug. to Nov. 1946, p. 384 ... (21 pp.). BLOCH, RICHARD M., Mark I Calculator, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Harvard University Press, 1948, pp. 23-30. HARRISON, JOSEPH O., JR., The Preparation of Problems for the Mark I Calculator, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Harvard University Press, 1948, pp. 208-210. INTERNATIONAL BUSINESS MACHINES CORPORATION, _IBM Automatic Sequence-Controlled Calculator_, Endicott, N. Y.: International Business Machines Corporation, 1945, 6 pp. Some of the less technical articles regarding the machine are: GENET, N., Got a Problem? Harvard’s Amazing New Mathematical Robot, _Scholastic_, vol. 45, Sept. 18, 1944, p. 35. TORREY, V., Robot Mathematician Knows All the Answers, _Popular Science_, vol. 145, Oct. 1944, pp. 86-89.... ANONYMOUS, Giant New Calculator, _Science News Letter_, vol. 46, Aug. 12, 1944, p. 111. ANONYMOUS, Mathematical Robot Presented to Harvard, _Time_, vol. 44, Aug. 14, 1944, p. 72. ANONYMOUS, World’s Greatest Machine for Automatic Calculation, _Science News Letter_, vol. 46, Aug. 19, 1944, p. 123. ANONYMOUS, Superbrain, _Nation’s Business_, vol. 32, Sept. 1944, p. 8. ANONYMOUS, Robot Works Problems Never Before Solved, _Popular Mechanics_, vol. 82, Oct. 1944, p. 13. ENIAC, THE ELECTRONIC NUMERIC INTEGRATOR AND CALCULATOR There is as yet no full-scale, published scientific account of the Eniac. At the Ballistic Research Laboratories, Aberdeen, Md., where the machine now is, there are a few copies of some long mimeographed reports on the machine and the way it works. These were prepared by H. H. Goldstine and others when at the Moore School of Electrical Engineering, as a part of the contract under which the machine was constructed for the U. S. Government. It is possible that these reports might be consulted on request by serious students. Some scientific descriptions of the machine and its properties are: BURKS, ARTHUR W., Electronic Computing Circuits of the ENIAC, _Proceedings of the Institute of Radio Engineers_, vol. 35, no. 8, Aug. 1947, pp. 756-767. CLIPPINGER, R. F., _A Logical Coding System Applied to the Eniac_, B. R. L. Report No. 673, Aberdeen, Md.: Ballistic Research Laboratories, Sept. 29, 1948, 41 pp. ECKERT, J. PRESPER, JR., JOHN W. MAUCHLY, HERMAN H. GOLDSTINE, and J. G. BRAINERD, Description of the ENIAC and Comments on Electronic Digital Computing Machines, Applied Mathematics Panel Report 171.2R, Washington, D. C.: National Defense Research Committee, Nov. 1945, 78 pp. GOLDSTINE, HERMAN H., and ADELE GOLDSTINE, The Electronic Numerical Integrator and Computer (ENIAC), _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 15, July 1946, pp. 97-110. HARTREE, D. R., The ENIAC, an Electronic Computing Machine, _Nature_, vol. 158, Oct. 12, 1946, pp. 500-506. HARTREE, D. R., _Calculating Machines: Recent and Prospective Developments and Their Impact on Mathematical Physics_, Cambridge, England: The University Press, 1947, 40 pp. (Pages 14 to 27 are devoted to the Eniac.) TABOR, LEWIS P., Brief Description and Operating Characteristics of the ENIAC, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Harvard University Press, 1948, pp. 31-39. Some of the less technical articles on Eniac are: ROSE, A., Lightning Strikes Mathematics: ENIAC, _Popular Science_, vol. 148, Apr. 1946, pp. 83-86. ANONYMOUS, Robot Calculator: ENIAC, All Electronic Device, _Business Week_, Feb. 16, 1946, p. 50 ... ANONYMOUS, Answers by ENY: Electronic Numerical Integrator and Computer, ENIAC, _Newsweek_, vol. 27, Feb. 18, 1946, p. 76. ANONYMOUS, Adds in ¹/₅₀₀₀ Second: Electronic Computing Machine at the University of Pennsylvania, _Science News Letter_, vol. 49, Feb. 23, 1946, p. 113 ... ANONYMOUS, ENIAC: at the University of Pennsylvania, _Time_, vol. 47, Feb. 25, 1946, p. 90. ANONYMOUS, It Thinks with Electrons; the ENIAC, _Popular Mechanics_, vol. 85, June 1946, p. 139. ANONYMOUS, Electronic Calculator: ENIAC, _Scientific American_, vol. 174, June 1946, p. 248. BELL LABORATORIES RELAY COMPUTERS As yet no full-scale scientific report is available on the Bell Laboratories general-purpose relay computers that went to Aberdeen and Langley Field. However, there is some information about these and other Bell Laboratories relay computing machines in the following articles: ALT, FRANZ L., A Bell Telephone Laboratories’ Computing Machine (two parts), _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 21, Jan. 1948, pp. 1-13, and vol. 3, no. 22, Apr. 1948, pp. 69-84. CESAREO, O., The Relay Interpolator, _Bell Laboratories Record_, vol. 24, no. 12, Dec. 1946, pp. 457-460. JULEY, JOSEPH, The Ballistic Computer, _Bell Laboratories Record_, vol. 25, no. 1, Jan. 1947, pp. 5-9. WILLIAMS, SAMUEL B., A Relay Computer for General Application, _Bell Laboratories Record_, vol. 25, no. 2, Feb. 1947, pp. 49-54. WILLIAMS, SAMUEL B., Bell Telephone Laboratories’ Relay Computing System, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Harvard University Press, 1948, pp. 40-68. ANONYMOUS, Complex Computer Demonstrated, _Bell Laboratories Record_, vol. 19, no. 2, Oct. 1940, pp. v-vi. ANONYMOUS, _Computer Mark 22 Mod. 0: Development and Description_, Navord Report No. 178-45, Washington, D. C.: Navy Department, Dec. 6, 1945, 225 pp. ANONYMOUS, Relay Computer for the Army, _Bell Laboratories Record_, vol. 26, no. 5, May 1948, pp. 208-209. THE KALIN-BURKHART LOGICAL-TRUTH CALCULATOR As yet there are no published references on the Kalin-Burkhart Logical-Truth Calculator. Some books covering a good deal of mathematical logic are: QUINE, W. V., _Mathematical Logic_, New York: W. W. Norton & Co., 1940, 348 pp. REICHENBACH, HANS, _Elements of Symbolic Logic_, New York: The Macmillan Co., 1947, 444 pp. TARSKI, ALFRED, _Introduction to Logic_, New York: Oxford University Press, 1941, 239 pp. WOODGER, J. H., _The Axiomatic Method in Biology_, Cambridge, England: The University Press, 1937, 174 pp. Chapter 2, pp. 18-52, is an excellent and understandable summary of the concepts of mathematical logic. Several papers on the application of mathematical logic to the analysis of practical situations are: BERKELEY, EDMUND C., Boolean Algebra (The Technique for Manipulating “And,” “Or,” “Not,” and Conditions) and Applications to Insurance, _Record of the American Institute of Actuaries_, vol. 26, Oct. 1937, pp. 373-414. BERKELEY, EDMUND C., Conditions Affecting the Application of Symbolic Logic, _Journal of Symbolic Logic_, vol. 7, no. 4, Dec. 1942, pp. 160-168. SHANNON, CLAUDE E., A Symbolic Analysis of Relay and Switching Circuits, _Transactions of the American Institute of Electrical Engineers_, vol. 57, 1938, pp. 713-723. This paper has had a good deal of influence here and there on the development of electric circuits using relays. The following report discusses the solution of some problems of mathematical logic by means of a large-scale digital calculator: TARSKI, ALFRED, _A Decision Method for Elementary Algebra and Geometry_, Report R-109, California: Rand Corporation, Aug. 1, 1948, 60 pp. OTHER DIGITAL MACHINES FINISHED OR UNDER DEVELOPMENT The Aiken Mark II Relay Calculator The Computation Laboratory of Harvard University finished during 1947 a second large relay calculator, called the Aiken Mark II Relay Calculator. This machine is alluded to briefly at the end of Chapter 10 and is described more fully in the following: CAMPBELL, ROBERT V. D., Mark II Calculator, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 69-79. FREELAND, STEPHEN L., Inside the Biggest Man-Made Brain, _Popular Science_, May 1947, pp. 95-100. MILLER, FREDERICK G., Application of Printing Telegraph Equipment to Large-Scale Calculating Machinery, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 213-222. The Edsac The Edsac is a machine under construction in England. WILKES, M. V., The Design of a Practical High-Speed Computing Machine: the EDSAC, _Proceedings of the Royal Society_, series A, vol. 195, 1948, pp. 274-279. WILKES, M. V., and W. RENWICK, An Ultrasonic Memory Unit for the EDSAC, _Electronic Engineering_, vol. 20, no. 245, July 1948, pp. 208-213. The Edvac The Edvac is a machine under construction at the Moore School of Electrical Engineering, Philadelphia. KOONS, FLORENCE, and SAMUEL LUBKIN, Conversion of Numbers from Decimal to Binary Form in the EDVAC, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 26, Apr. 1949, pp. 427-431. ANONYMOUS, EDVAC Replaces ENIAC, _The Pennsylvania Gazette_, Philadelphia: University of Pennsylvania, vol. 45, no. 8, Apr. 1947, pp. 9-10. The IBM Selective-Sequence Electronic Calculator The IBM Selective-Sequence Electronic Calculator was finished and announced in January 1948, and is alluded to briefly at the end of Chapter 10. More information about this machine is in the following references: ECKERT, W. J., Electrons and Computation, _The Scientific Monthly_, vol. 67, no. 5, Nov. 1948, pp. 315-323. INTERNATIONAL BUSINESS MACHINES CORPORATION, _IBM Selective-Sequence Electronic Calculator_, New York: International Business Machines Corporation (form no. 52-3927-0), 1948, 16 pp. The Raytheon Computer The Raytheon Computer is a machine under construction at the Raytheon Manufacturing Co., Waltham, Mass. BLOCH, R. M., R. V. D. CAMPBELL, and M. ELLIS, The Logical Design of the Raytheon Computer, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 24, Oct. 1948, pp. 286-295. BLOCH, R. M., R. V. D. CAMPBELL, and M. ELLIS, General Design Considerations for the Raytheon Computer, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 24, Oct. 1948, pp. 317-323. A “System of Electric Remote-Control Accounting” During the 1930’s a system using connected punch-card machinery was experimented with in a department store in Pittsburgh. The purpose of the system was automatic accounting and analysis of sales. This system is described in: WOODRUFF, L. F., A System of Electric Remote-Control Accounting, _Transactions of the American Institute of Electrical Engineers_, vol. 57, Feb. 1938, pp. 78-87. The Univac The Univac is a machine under construction at the Eckert-Mauchly Computer Corporation, Philadelphia. A similar but smaller digital computer called the Binac is also being developed. ECKERT-MAUCHLY COMPUTER CORPORATION, _The Univac System_, Philadelphia: Eckert-Mauchly Computer Corp., 1948, 8 pp. ELECTRONIC CONTROL CO. (now ECKERT-MAUCHLY COMPUTER CORP.), _A Tentative Instruction Code for a Statistical Edvac_, Philadelphia: Electronic Control Co. (now Eckert-Mauchly Computer Corp.), May 7, 1947, 19 pp. SNYDER, FRANCES E., and HUBERT M. LIVINGSTON, Coding of a Laplace Boundary Value Problem for the UNIVAC, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 25, Jan. 1949, pp. 341-350. The Zuse Computer The Zuse Computer is a small digital computer constructed in Germany. LYNDON, ROGER C., The Zuse Computer, _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 20, Oct. 1947, pp. 355-359. THE DESIGN OF DIGITAL MACHINES Following are a number of references on various aspects of the design of digital computing machines: Organization BURKS, ARTHUR W., Super-Electronic Computing Machine, _Electronic Industries_, vol. 5, no. 7, July 1946, p. 62. BURKS, ARTHUR W., HERMAN H. GOLDSTINE and JOHN VON NEUMANN, _Preliminary Discussion of the Logical Design of an Electronic Computing Instrument_, Princeton, N. J.: Institute for Advanced Study, 2nd edition, Sept. 1947, 42 pp. ECKERT, J. PRESPER, JR., JOHN W. MAUCHLY, and J. R. WEINER, An Octal System Automatic Computer, _Electrical Engineering_, vol. 68, no. 4, Apr. 1949, p. 335. FORRESTER, JAY W., WARREN S. LOUD, ROBERT R. EVERETT, and DAVID R. BROWN, _Lectures by Project Whirlwind Staff on Electronic Digital Computation_, Cambridge, Mass.: Massachusetts Institute of Technology, Servo-mechanisms Laboratory, Mar. and Apr. 1947, 149 pp. LUBKIN, SAMUEL, Decimal Point Location in Computing Machines, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 21, Jan. 1948, pp. 44-50. PATTERSON, GEORGE W., editor, and others, _Theory and Techniques for Design of Electronic Digital Computers_ (subtitle: _Lectures Given at the Moore School 8 July 1946-31 August 1946_), Philadelphia: The University of Pennsylvania, Moore School of Electrical Engineering, vol. 1, lectures 1-10, Sept. 10, 1947, 161 pp.; vol. 2, lectures 11-21, Nov. 1, 1947, 173 pp.; vol. 3 and 4 in preparation. STIBITZ, GEORGE R., _Relay Computers_, Applied Mathematics Panel Report 171.1R, Washington, D. C.: National Defense Research Council, Feb. 1945, 83 pp. STIBITZ, GEORGE R., Should Automatic Computers be Large or Small? _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 20, Oct. 1947, pp. 362-364. STIBITZ, GEORGE R., The Organization of Large-Scale Calculating Machinery, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 91-100. STIBITZ, GEORGE R., A New Class of Computing Aids, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 23, July 1948, pp. 217-221. Input and Output Devices ALEXANDER, SAMUEL N., Input and Output Devices for Electronic Digital Calculating Machinery, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 248-253. FULLER, HARRISON W., The Numeroscope, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 238-247. O’NEAL, R. D., Photographic Methods for Handling Input and Output Data, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 260-266. TYLER, ARTHUR W., Optical and Photographic Storage Techniques, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 146-150. ZWORYKIN, V. K., L. E. FLORY, and W. S. PIKE, Letter-Reading Machine, _Electronics_, vol. 22, no. 6, June 1949, pp. 80-86. ANONYMOUS, Letter-Printing Cathode-Ray Tube, _Electronics_, vol. 22, no. 6, June 1949, pp. 160-162. Storage Devices BRILLOUIN, LEON N., Electromagnetic Delay Lines, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 110-124. FORRESTER, JAY W., High-Speed Electrostatic Storage, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 125-129. HAEFF, ANDREW V., The Memory Tube and its Application to Electronic Computation, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 24, Oct. 1948, pp. 281-286. KORNEI, OTTO, Survey of Magnetic Recording, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 223-237. MOORE, BENJAMIN L., Magnetic and Phosphor Coated Discs, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 130-132. RAJCHMAN, JAN A., The Selectron—A Tube for Selective Electrostatic Storage, _Mathematical Tables and Other Aids to Computation_, vol. 2, no. 20, Oct. 1947, pp. 359-361 and frontispiece. SHARPLESS, T. KITE, Mercury Delay Lines as a Memory Unit, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 103-109. SHEPPARD, C. BRADFORD, Transfer Between External and Internal Memory, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 267-273. Programming or Coding EVERETT, ROBERT R., _Digital Computing Machine Logic_ (memorandum M-63), Cambridge, Mass.: Massachusetts Institute of Technology, Servo-mechanisms Laboratory, Mar. 19, 1947, 48 pp. GOLDSTINE, HERMAN H., and JOHN VON NEUMANN, _Planning and Coding of Problems for an Electronic Computing Instrument_, Princeton, N. J.: Institute for Advanced Study, 1947, 69 pp. GOLDSTINE, HERMAN H., and JOHN VON NEUMANN, _Planning and Coding of Problems for an Electronic Computing Instrument_, Princeton, N. J.: Institute for Advanced Study, part 2, vol. 3, 1948, 23 pp. MAUCHLY, JOHN W., Preparation of Problems for Edvac-Type Machines, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 203-207. DIGITAL MACHINES—MISCELLANEOUS Many of the following articles are nontechnical and contain much interesting information about machines that think: ALT, FRANZ L., New High-Speed Computing Devices, _The American Statistician_, vol. 1, no. 1, Aug. 1947, pp. 14-15. BUSH, VANNEVAR, As We May Think, _Atlantic Monthly_, July 1945, pp. 101-108. CONDON, EDWARD U., _The Electronic Brain Means a Better Future for You_ (broadcast), Columbia Broadcasting System, Jan. 4, 1948. DAVIS, HARRY M., Mathematical Machines, _Scientific American_, vol. 180, no. 4, Apr. 1949, pp. 29-39. LAGEMANN, JOHN K., It All Adds Up, _Collier’s Magazine_, May 31, 1947, pp. 22-23 ... LOCKE, E. L., Modern Calculators, _Astounding Science Fiction_, vol. 52, no. 5, Jan. 1949, pp. 87-106. MACLAUGHLAN, LORNE, Electrical Mathematicians, _Astounding Science Fiction_, vol. 53, no. 3, May 1949, pp. 93-108. MANN, MARTIN, Want to Buy a Brain? _Popular Science_, vol. 154, no. 5, May 1949, pp. 148-152. NEWMAN, JAMES R., Custom-Built Genius, _New Republic_, June 23, 1947, pp. 14-18. PFEIFFER, JOHN E., The Machine That Plays Gin Rummy, _Science Illustrated_, vol. 4, no. 3, Mar. 1949, pp. 46-48 ... RIDENOUR, LOUIS N., Mechanical Brains, _Fortune_, vol. 39, no. 5, May 1949, pp. 108-118. TUMBLESON, ROBERT C., Calculating Machines, _Federal Science Progress_, June 1947, pp. 3-7. ANONYMOUS, Almost Human, _Home Office News_, Newark, N. J.: Prudential Insurance Company of America, Feb. 1947, p. 8. APPLICATIONS OF DIGITAL MACHINES Some of the problems that mechanical brains can solve, some of the methods for controlling them to solve problems, and some of the implications of mechanical brains for future problems are covered in the following references: Solving Problems BERKELEY, EDMUND C., Electronic Machinery for Handling Information, and its Uses in Insurance, _Transactions of the Actuarial Society of America_, vol. 48, May 1947, pp. 36-52. BERKELEY, EDMUND C., Electronic Sequence Controlled Calculating Machinery and Applications in Insurance, _Proceedings of 1947 Annual Conference, Life Office Management Association_, New York: Life Office Management Association, 1947, pp. 116-129. CURRY, HASKELL B., and WILLA A. WYATT, _A Study of Inverse Interpolation of the Eniac_, B. R. L. Report No. 615, Aberdeen, Md.: Ballistic Research Laboratories, Aug. 19, 1946, 100 pp. HARRISON, JOSEPH O., JR., and HELEN MALONE, Piecewise Polynomial Approximation for Large-Scale Digital Calculators, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 26, Apr. 1949, pp. 400-407. HOFFLEIT, DORRIT, A Comparison of Various Computing Machines Used in Reduction of Doppler Observations, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 25, Jan. 1949, pp. 373-377. LEONTIEF, WASSILY W., Computational Problems Arising in Connection with Economic Analysis of Interindustrial Relationships, _Proceedings of a Symposium on Large-Scale Digital Calculating Machinery_, Cambridge, Mass.: Harvard University Press, 1948, pp. 169-175. LOTKIN, MAX, _Inversion on the Eniac Using Osculatory Interpolation_, B. R. L. Report No. 632, Aberdeen, Md.: Ballistic Research Laboratories, July 15, 1947, 42 pp. LOWAN, ARNOLD N., The Computation Laboratory of the National Bureau of Standards, _Scripta Mathematica_, vol. 15, no. 1, Mar. 1949, pp. 33-63. MATZ, ADOLPH, Electronics in Accounting, _Accounting Review_, vol. 21, no. 4, Oct. 1946, pp. 371-379. MCPHERSON, JAMES L., Applications of High-Speed Computing Machines to Statistical Work, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 22, Apr. 1948, pp. 121-126. MITCHELL, HERBERT F., JR., Inversion of a Matrix of Order 38, _Mathematical Tables and Other Aids to Computation_, vol. 3, no. 23, July 1948, pp. 161-166. ANONYMOUS, Revolutionizing the Office, _Business Week_, May 28, 1949, no. 1030, pp. 65-72. Speech Some of the possibilities of machines dealing with voice and speech are indicated in: DUDLEY, HOMER, R. R. RIESZ, and S. S. A. WATKINS, A Synthetic Speaker, _Journal of the Franklin Institute_, vol. 227, June 1939, pp. 739-764. This is an article on the _Voder_, which is an abbreviation of _V_oice _O_peration _De_monstrator. The machine was exhibited at the New York World’s Fair, 1939. DUDLEY, HOMER, The Vocoder, _Bell Laboratories Record_, vol. 18, no. 4, Dec. 1939, pp. 122-126. This is a more general type of machine than the Voder. The Vocoder is both an analyzer and synthesizer of human speech. POTTER, RALPH K., GEORGE A. KOPP, and HARRIET C. GREEN, _Visible Speech_, New York: D. Van Nostrand Co., 1947, 441 pp. ANONYMOUS, Pedro the Voder: A Machine that Talks, _Bell Laboratories Record_, vol. 17, no. 6, Feb. 1939, pp. 170-171. Weather Some of the possibilities of machines dealing with weather information are covered in: LAGEMANN, JOHN K., Making Weather to Order, _New York Herald Tribune: This Week_, Feb. 23, 1947. SHALETT, SIDNEY, Electronics to Aid Weather Figuring, _The New York Times_, Jan. 11, 1946. ZWORYKIN, V. K., _Outline of Weather Proposal_, Princeton, N. J.: Radio Corporation of America Research Laboratories, Oct. 1945, 11 pp. ANONYMOUS, Weather Under Control, _Fortune_, Feb. 1948, pp. 106-111 ... The Robot Machine ČAPEK, KAREL, _R. U. R._ (translated from the Czech by Paul Selver), New York: Doubleday, Page & Co., 1923. LAGEMANN, JOHN K., From Piggly Wiggly to Keedoozle, _Collier’s Magazine_, vol. 122, no. 18, Oct. 30, 1948, pp. 20-21 ... LEAVER, E. W., and J. J. BROWN, Machines Without Men, _Fortune_, vol. 34, no. 5, Nov. 1946, pp. 165 ... PEASE, M. C., Devious Weapon, _Astounding Science Fiction_, vol. 53, no. 2, Apr. 1949, pp. 34-43. SHANNON, CLAUDE E., _Programming a Computer for Playing Chess_, Bell Telephone Laboratories, Oct. 8, 1948, 34 pp. SHELLEY, MARY W., _Frankenstein_ (in Everyman’s Library, No. 616), New York: E. P. Dutton & Co., last reprinted 1945, 242 pp. SPILHAUS, ATHELSTAN, Let Robot Work for You, _The American Magazine_, Dec. 1948, p. 47 ... ANONYMOUS, Another New Product for Robot Salesmen, _Modern Industry_, vol. 13, no. 2, Feb. 15, 1947. ANONYMOUS, The Automatic Factory, _Fortune_, vol. 34, no. 5, Nov. 1946, p. 160 ... ANONYMOUS, Machines Predict What Happens in Your Plant, _Business Week_, Sept. 25, 1948, pp. 68-69 ... NAME INDEX _Note: This list of persons mentioned in the text includes names of fictional characters. The subject index, which follows, includes all other names._ Aiken, Howard H., 90-112, 177-8, 232, 245-6 Alexander, Samuel N., 251 Alquist, 200 Alt, Franz L., 142, 237, 247, 253 Archer, R. M., 241 Aristotle, 152 Babbage, Charles, 89 Baehne, G. Walter, 232 Bailey, C. F., 237 Barcroft, Joseph, 229 Beach, Frank A., 229 Beard, R. E., 88, 240 Berkeley, Edmund C., 233, 248, 254 Berry, R. J. A., 229 Berry, T. M., 240 Bloch, Richard M., 246, 250 Bloomfield, Leonard, 231 Bodmer, Frederick, 231 Boelter, L. M. K., 240 Boole, George, 152 Boring, Edwin G., 229 Bower, E. C., 237 Brainerd, J. G., 247 Brillouin, Leon N., 252 Brown, David R., 251 Brown, G. S., 245 Brown, J. J., 255 Brown, S. L., 241-2 Buckingham, R. A., 240 Burkhart, William, 144, 155-6 Burks, Arthur W., 246, 251 Bush, Vannevar, 72, 74, 239, 241, 245, 253 Caldwell, Samuel H., 74, 239, 241 Campbell, Robert V. D., 249-50 Čapek, Karel, 199, 255 Carroll, Lewis, 12 Carter, G. K., 244 Cesareo, O., 248 Clemence, G. M., 237 Clippinger, R. F., 246 Comrie, John Leslie, 232 Concordia, C., 244 Condon, Edward U., 253 Crew, E. W., 232 Criner, H. E., 245 Culley, Frank L., 237 Curry, Haskell B., 254 Davis, Harry M., 253 Deming, W. Edwards, 237 Dietzold, Robert L., 244 Domin, Harry, 199 Dudley, Homer, 254-5 Duncan, W. J., 244 Dunlap, Jack W., 237 Dwyer, Paul S., 237 Dyer, H. S., 237 Eckert, J. Presper, Jr., 114, 178, 247, 251 Eckert, W. J., 233, 236-7, 239, 250 Edison, Thomas A., 15 Ellis, M., 250 Enns, W. E., 243 Everett, Robert R., 251-2 Feinstein, Lillian, 237 Flesch, Rudolf, 231 Flory, L. E., 252 Forrester, Jay W., 251-2 Frame, J. Sutherland, 244 Frankenstein, Victor, 198, 200 Franz, Shepherd I., 229 Freeland, Stephen L., 249 Fry, Macon, 232 Fuller, Harrison W., 252 Fürth, R., 242 Gage, F. D., 245 Genet, N., 239, 246 Godwin, Mary W. (Mary W. Shelley), 198, 255 Goldstine, Adele, 247 Goldstine, Herman H., 247, 251, 253 Gove, E. L., 245 Graff, Willem L., 231 Graham, R. S., 244 Gray, T. S., 245 Green, Harriet C., 255 Haeff, Andrew V., 252 Hansen, Morris H., 237 Harrison, Joseph O., Jr., 246, 254 Hart, H. C., 244 Hartkemeier, Harry Pelle, 233 Hartree, D. R., 232, 240-1, 247 Haupt, Ralph F., 237 Hayakawa, S. I., 231 Hazen, H. L., 243, 245 Hedeman, W. R., 245 Hedley, K. J., 233 Herget, Paul, 237 Herr, D. L., 244 Herrick, C. Judson, 229 Hoffleit, Dorrit, 254 Hogben, Launcelot, 231 Hollerith, Herman, 43 Hopper, Grace M., 246 Horsburgh, E. H., 232 Hotelling, Harold, 237 Householder, Alston S., 230 Jespersen, Otto, 231 Juley, Joseph, 248 Kalin, Theodore A., 144, 155-6 Kelvin, Lord, 72, 240 King, Gilbert W., 238 Koons, Florence, 249 Kopp, George A., 255 Kormes, Jennie P., 238 Kormes, Mark, 238 Kornei, Otto, 252 Kranz, Frederick W., 242 Kron, Gabriel, 243-4 Kuder, G. Frederic, 238 Kuehni, H. P., 240, 243 Lagemann, John K., 253, 255 Landahl, Herbert D., 230 Lang, H. C., 233 Lashley, Karl S., 229 Leaver, E. W., 255 Leontief, Wassily W., 254 Lettvin, Jerome Y., 230 Lilley, S., 232 Livingston, Hubert M., 250 Locke, E. L., 253 Lorraine, R. G., 243 Lotkin, Max, 254 Loud, Warren S., 251 Lowan, Arnold N., 254 Lubkin, Samuel, 249, 251 Lyndon, Roger C., 250 MacLaughlan, Lorne, 253 Maginniss, F. J., 241 Mallock, R. R. M., 244 Malone, Helen, 254 Mann, Martin, 253 Marble, F. G., 242 Massey, H. S. W., 240 Mastukazi, Kiyoshi, 19 Matz, Adolph, 254 Mauchly, John W., 114, 178, 247, 251, 253 Maxfield, D. K., 238 Maxwell, L. R., 242 McCann, G. D., 245 McCulloch, Warren S., 230 McLaughlin, Kathleen, 238 McPherson, James L., 254 McPherson, John C., 238 Meacham, Alan D., 237 Mercner, R. O., 244 Miller, Dayton C., 242 Miller, Frederick G., 249 Milliman, Wendell A., 238 Milne, J. R., 242 Mitchell, Herbert F., Jr., 254 Montgomery, H. C., 242 Moore, Benjamin L., 252 Moore, C. R., 242 Murray, Francis J., 232 Myers, D. M., 245 Newman, James R., 253 Ogden, C. K., 231 O’Neal, R. D., 252 Parker, W. W., 243 Patterson, George W., 251 Pease, M. C., 255 Pekeris, C. L., 245 Peterson, H. A., 240, 243-4 Pfeiffer, John E., 253 Pieron, Henri, 229 Pike, W. S., 252 Pitts, Walter, 230 Poesch, H., 240 Porter, A., 240-1 Potter, Ralph K., 255 Pringle, R. W., 242 Quine, W. V., 248 Rajchman, Jan A., 252 Rashevsky, N., 230 Raymond, W. J., 242 Reichenbach, Hans, 248 Renwick, W., 249 Ridenour, Louis N., 253 Riesz, R. R., 254 Robertson, J. M., 242 Rose, A., 247 Rossum, 199 Royer, Elmer B., 238 Sauer, R., 240 Schlauch, Margaret, 231 Schnackel, H. G., 233 Schrödinger, Erwin, 229 Schwarzchild, Martin, 237 Shalett, Sidney, 255 Shannon, Claude E., 153-5, 241, 248, 255 Sharpless, T. Kite, 252 Shelley, Mary W., 198, 255 Shelley, Percy Bysshe, 198 Sheppard, C. Bradford, 252 Sherrington, Charles S., 229 Smith, C. E., 245 Snyder, Frances E., 250 Somerville, J. M., 242 Spilhaus, Athelstan, 255 Stewart, R. R., 245 Stibitz, George R., 129-30, 244, 251 Straiton, A. W., 242 Tabor, Lewis P., 247 Tarski, Alfred, 248-9 Terhune, G. K., 242 Thomas, George B., 238 Thomson, James, 240 Thomson, William, 72, 240 Tilney, Frederick, 229 Torrey, V., 246 Travis, Irven, 239, 244 Tumbleson, Robert C., 253 Turck, J. A. V., 232 Tyler, Arthur W., 252 Varney, R. N., 243 von Neumann, John, 124, 251 Wainwright, Lawrence L., 72, 241 Walpole, Hugh R., 231 Watkins, S. S. A., 254 Wegel, R. L., 242 Weiner, J. R., 251 Wheeler, L. L., 241-2 Whitten, C. A., 238 Wiener, Norbert, 229 Wilbur, J. B., 244 Wilkes, M. V., 249 Williams, Samuel B., 248 Wolf, Arthur W., 233 Womersley, J. R., 241 Wood, Thomas, 19 Woodger, J. H., 248 Woodruff, L. F., 250 Wyatt, Willa A., 254 Wylie, J., 240 Yavne, R. O., 245 Zworykin, V. K., 190, 252, 255 SUBJECT INDEX _Notes: Phrases consisting of an adjective and a noun, or of a noun and a noun, are entered in their alphabetical place according to the first word. For example, “electrostatic storage tube” is under_ e, _and “punch card” is under_ p. _A_ field, 99 _A_ tape, 82-3 abacus, 17-9, 133, 220 _abax_ (Greek), 18 absolute value, 101, 222 accumulator, 115-6 accumulator decade, 118 accuracy, 67, 89 acetylcholine, 3 add output, 120 addend, 223 adder, 77 adder mechanism, 77-8 adding, 24-5, 27, 37, 55, 100, 119, 139 addition circuit, 37 Aiken Mark I Calculator, 10, 89-112, 245-6; _see also_ Harvard IBM Automatic Sequence-Controlled Calculator Aiken Mark II Relay Calculator, 176-8, 249 Aiken Mark III Electronic Calculator, 177 air resistance coefficient, 80-2 algebra of logic, 26, 36, 56-62, 105, 140, 151-2, 164, 221-3, 248 algebraic equations, machines for solving, 244 all-or-none response, 3 alphabet, 14 alphabetic coding, 13, 54 alphabetic punching, 46 alphabetic writing, 13 amplify, 73 analogous, 65 analogue, 65 analogue machines (machines that handle information expressed as measurements), 65; MIT Differential Analyzer No. 2, 65-88; references, 239-45 analytical engine, 90 analyzer, 68, 241-4; _see also_ differential analyzer and, 146-8 and/or, 149 angle-indicator, 74-5 animal thinking, 4, 8, 188 annuities, 88 antecedent, 158 antilogarithm, 139, 226 antitangent, 139, 226 approximation, 220; _see also_ rapid approximation aptitude testing, 190 argument (in a mathematical table or function), 96, 103-4, 122, 136, 224 arithmetical operations, 55-6, 173 armor with a motor, 180, 195 array, 173, 227 Atomic Energy Commission, 203, 208 attitudes, 205 augend, 223 _aut_ (Latin), 149 automatic address-book, 181 automatic carriage, 53 “Automatic Computing Machinery” (section in _Mathematical Tables and Other Aids to Computation_), 177 automatic control: house-furnace, 189; lawn-mower, 188; tractor-plow, 188; weather, 189 automatic cook, 181 automatic factory, 189 automatic library, 9, 181 automatic machinery, 182 automatic pilot, 189 automatic recognizer, 186-7 automatic sequence-controlled calculator, 90; _see also_ Harvard IBM Automatic Sequence-Controlled Calculator automatic stenographer, 185 automatic switching circuits, 248 automatic translator, 182 automatic typist, 182, 184 axon, 3 _B_ field, 99 _B_ tape, 82-3 Ballistic Research Laboratories, 1, 113-5, 127-8, 132, 142 base _e_, 226 base 10, 226 beam of electrons, 172 behavior, 4, 7-8, 29 Bell Telephone Laboratories, 4-5, 128-43, 247-8 Bell Telephone Laboratories’ general-purpose relay computer, 128-43, 247-8; cost, 142; reliability, 141; speed, 142 Bessel functions, 111, 226 Binac, 179 binary coding, 11, 13 binary digit, 14 binary numbers, 14, 216-9 biophysics, 230 biquinary numbers, 133, 219-20 blocks of arguments, 137 Boolean algebra, 152, 248; _see also_ mathematical logic both, 149 bowwow theory, 12 brain evolution, 229 brain with a motor, 180, 195 BTL frames, 138-9 bus, 32, 119 button, 91, 94 _C_ field, 99 _C_ tape, 82-3 _calcis_ (Latin), 18 calculating punch, 47, 51-2, 235 calculator frames, 138 calculator programmed by punch cards, 236 cam, 94-5 cam contact, 91, 94-5 capacitance, 117 capacitor, 117 capacity: counter, 59; selecting, 59 carbon dioxide, 190 card channel, 47, 52 card column, 48 card feed, 48, 91 card punch, 91, 97 card reader, 116, 118 card sorter, 96 card stacker, 48 card station, 47 Carnegie Institution of Washington, 113 carry impulse, 118 cell nucleus, 2-3 census, 43, 53 channel, 47, 52, 170 characteristic of a logarithm, 107 check counter, 105 check-marks, 151 checking, 105, 110, 179, 227 chess game, 117 chestnut blight, 201 chortle, 12 class selector, 59 clearing, 100 codes, 29, 54, 96, 99 coding, 30, 130, 252-3 coding line, 99 column (in a punch card), 45 connective, 148, 158-9 connective grouping, 159 collating, 51, 173 collator, 47, 51, 235 collator counting device, 51, 235 combining information, 15 combining operations, 173 Common, 59-60 comparer, 57-8 comparing, 50, 57-8 complement, 55; _see also_ nines complement, ones complement, tens complement Complex Computer, 129-30 complex numbers, 128-9 computer, 6, 27 Computer 1 and Computer 2, 132, 138 conflicts between statements, 149-50 consequent, 158 constant, 224 constant ratio, 77 constant register, 96, 99 constant switch, 99 Constant Transmitter, 116, 118 consulting a table, 103, 122 convergent, 221 Converter, 115 context, 144 continuous annuities, 88 continuous contingent insurances, 88 continuously running gear, 93 control, 6, 28, 90-1 control brushes, 51-2 control frames, 138-9 Control Instrument Company, 43 control over robot machines, 196-208 control tape, 28 controversy, 197 cosine, 75, 85, 139, 226 cost of mechanical brains, 87, 109, 126, 142, 165, 168 counter, 52, 74, 93-4 counter position, 93 counter wheel, 93, 118 counting, 55 coupling (numbers), 106 cube, 105, 224 Current (input of comparer), 57 cycle, 29, 45 Cycling Unit, 115-6 Cypriote, 13 Dartmouth College, 131 decade, 118 decimal digit, 11, 14 decimal position, 118 deciphering, 184, 188 decoding, 184, 188 definite integral, 111, 225 delay lines, 17, 20, 171-2 dendrite, 3 denial, 147 dependent variable, 81, 224 derivative, 68-71, 225 design of mechanical brains, 167-79, 251 desk calculating machines, 4, 11, 17, 19 detail cards, 50 dial switch, 92, 95-6 dial telephone, 17, 19, 128 differences, 110, 227 differential, 68, 70, 78 differential analyzer, 68, 72-88, 239-41 Differential Analyzer No. 2, 65-88; accuracy, 86; cost, 87; reliability, 87; speed, 87 differential equation, 68-9, 71, 111, 141, 225-6 differential function, 70 differential gear assembly, 78 digit, 11, 14 Digit Pickup, 60 digit selector, 60 digit tray, 119 digit trunk lines, 119 digit trunks, 119 digital machines (machines that handle information expressed as digits or letters): Bell Laboratories’ general-purpose relay calculator, 128-43; Eniac, 113-27; Harvard IBM Automatic Sequence-Controlled Calculator, 89-112; punch-card calculating machinery, 42-64; references, 232-9, 245-55 directions, 24 disc, 78-80 discrimination, 140 discriminator, 140-1 distance, 68-9 distinguishing _A_ and _H_, 184 dividend, 103, 223 Divider-Square-Rooter, 115-7 dividing, 55-6, 98, 102, 121, 140 divisor counter, 102 doorpost, 65-6 doubling, 76-7, 100 doubling mechanism, 76-7 drafting rules, 149 drag coefficient, 80 drive, 86 Dry Ice, 190 echo, 171 Eckert-Mauchly Computer Corporation, 179, 250 economic relations, 194 Edsac, 249 “educated” machine, 101 Edvac, 177, 249 Egyptian, 12 either, 149 electric charge, 172 electric remote-control accounting, 250 electric typewriter, 91, 97, 236 electromagnet, 168 Electronic Binary Automatic Computer, 179 electronic calculating punch, 236 Electronic Control Company, 250 Electronic Numerical Integrator and Calculator (Eniac), 113-27, 246-7; _see also_ Eniac electronic tubes, 17, 20-1, 178-9; Cathode, 21; Grid, 21; Plate, 21 electrostatic storage tube, 17, 20, 172 11 position, 45 11 punch, 58 else, 146-7 end-around-carry, 95, 217, 223 engine, 90 Eniac, 113-27, 246-7; cost, 126; panels, 115; reliability, 126; speed, 125; unbalance, 124 “enough alike,” 184 Equal (output of sequencer), 61-2 equation, 68, 225 equivalent, 14 erase key, 134 Etruscan, 188 explanation, 209-13 explicit equation, 86 exponential, 85, 106, 225-6 extraction, 222 falsity, 147 farad, 117 fingers, 16, 18 fire-control instrument, 17, 19, 67, 131 5 impulse, 56 flights, 70 flip-flop, 119 following logically, 145 form feeding device, 236 formal logic, 152 formula, 68, 70, 224 Frankenstein’s monster, 198 function, 68, 70, 81, 103, 116, 118, 224 function table, 80-1, 116, 118 gang punching, 50 gearbox, 77-8 General Electric A.C. Network Analyzer, 243 General Electric Company, 243 geographic code, 54 giant brain, 1, 5-8 globe, 65-6 graph, 81 great circle, 69 greater-than, 25-7, 37, 222 greater-than circuit, 37 Greek letters, 120 guided missile, 197, 206 gun, 69 hail storm, 190 hand perforator, 132, 134 handling information, 10-18 harmonic analyzers, 241-2 harmonic synthesizers, 241-2 Harvard Computation Laboratory, 89, 176-7, 245, 249 Harvard IBM Automatic Sequence-Controlled Calculator (Mark I), 10, 89-112, 245-6; cost, 109; efficiency, 111; reliability, 110; speed, 109 Harvard Sequence-Controlled Electronic Calculator (Mark III), 177 Harvard Sequence-Controlled Relay Calculator (Mark II), 176-8, 249 Harvard University, 1, 4, 8, 89, 176-7, 245, 249 hatred, 206 hoppers, 51 hub, 46, 98 human brain, 2-4, 16, 229 humidity, 63 IBM (International Business Machines), 43-64, 89-90, 177, 233-9, 249-50 IBM Automatic Sequence-Controlled Calculator, 10, 89-112, 245-6; _see also_ Harvard IBM Automatic Sequence-Controlled Calculator IBM card-programmed calculator, 236 IBM pluggable sequence relay calculator, 236 IBM punch-card machinery, 43-64, 233-9 IBM Selective-Sequence Electronic Calculator, 177-9, 249 ideographic writing, 12 if, 146-7 if ... then, 149 ignorance, 205 illness, 191-2 imitative scheme, 12 in-code, 99 in-field, 99 independent variable, 81, 224 infinity, 86, 133, 212, 225 information, 10 initial conditions, 83, 225 Initiating Unit, 115-6 input, 6, 90-1 input devices, 175, 251-2 input register, 27 instantaneous rate of change, 70-1 Institute of Advanced Study, 124 instructions, 28, 83, 97, 178-9 insurance company, 42 insurance policies, 42 insurance values, 88 integral, 68, 71-2, 225 integral sign, 85, 225 integrating, 71-2, 78 integrator, 78-80 integrator mechanism, 78-9 International Business Machines Corporation (IBM), 43; _see_ IBM International Hydrographic Bureau, 242 International Phonetic Alphabet, 13 interpolating, 131, 221 interposing, 102 interpreter, 47, 49, 235 interpreting, 49 interval, 68, 70 intuitive thinking, 8 inverse, 71 judgments, 191 Kalin-Burkhart Logical-Truth Calculator, 144-66, 248; cost, 165; reliability, 166; speed, 166 key punch, 47-8, 96, 235 keyboard, 48 knots, 17 language of logic, 56-62, 105, 140; _see also_ mathematical logic languages, 10-21, 231 latch relay, 40-1 left-hand components, 56, 121, 215 library, 9, 181 Library of Congress, 15 lie detector, 192 line of coding, 99 linear, 224-5 linear interpolation, 221 linear simultaneous equations, 141, 225 lobe, 94-5 logarithm, 67, 85, 106-8, 139, 225 Logarithm-In-Out counter, 107 logic, 144; _see also_ mathematical logic logical choice, 4; _see also_ mathematical logic logical connective, 148, 222 logical operations, 56-62, 173 logical pattern, 145-6 logical truth, 144-56, 166 Logical-Truth Calculator, 144-66; _see_ Kalin-Burkhart Logical-Truth Calculator loopholes, 149 Low Primary (output of sequencer), 61-2 Low Secondary (output of sequencer), 61-2 Lower Brushes, 52 loxodrome, 69-70 machine call number, 99 machine cycle, 56 machine language, 29, 99, 175, 191 machines as a language for thinking, 19-20; references, 231-2 machines involving voice and speech, 185-6, 254 magnetic surfaces, 17, 20, 168-70, 179 magnetic tape, 169-70, 179 magnetic wire, 168 magnetized spot, 168-70 main connective, 160 many-wire cable, 50 Mark I (Harvard IBM Automatic Sequence-Controlled Calculator), 10, 89-112, 245-6; _see also_ Harvard IBM Automatic Sequence-Controlled Calculator Mark II (Harvard Sequence-Controlled Relay Calculator), 176-8, 249 Mark III (Harvard Sequence-Controlled Electronic Calculator), 177 Massachusetts Institute of Technology, 1, 20, 65, 72-88, 153 Massachusetts Institute of Technology’s Differential Analyzer No. 2, 65-88; accuracy, 86; cost, 87; reliability, 87; speed, 87 master card, 50 Master Programmer, 115-6 matching, 173 mathematical biophysics, 230 mathematical logic, 26, 36, 56-62, 105, 140, 151-2, 164, 221-3, 248 matrices, 173, 227 matrix, 173, 227 meanings, 209, 231 measurements, 65-6, 68 mechanical brain, 1, 5-8, 20; crucial devices for, 20 mechanical brains under construction, 176-9 memory, 27, 90-1 mentality, 24, 27 mercury tank, 171, 179 merging, 173 metal fingers, 135 mica, 172 microphone, 185 mimeograph stencil, 16 Minoan, 188 miscellaneous field, 99 mistake, 134 Moore School of Electrical Engineering, 7, 113-27, 177, 249 multiplicand, 223 multiplicand counter, 101 multiplication schemes, 214-6 multiplier, 115-6 multiplier counter, 101 multiply-divide unit, 103 multiplying, 55-6, 101, 121, 140 multiplying punch, 47, 52, 235 National Advisory Committee for Aeronautics, 128, 132 Naval Proving Ground, 177 negation, 24-5, 27, 34-6 negation circuit, 36 negative, 147 negative digit, 215 neon bulb, 119 nerve, 2-4 nerve cell, 2, 3, 16 nerve fiber, 2, 3 nerve networks, 230 nervous system, 188 network analyzers, 242-4 neurosis, 191 nine-pulses, 120-1 nines complement, 95, 121, 223 No X, 59 Northrop Aircraft, Inc., 179 not, 146-8 numeric coding, 13, 54 numerical X position, 45 numerical Y position, 45 occupation code, 54 octal notation, 179, 219 ohm, 117 Ojibwa, 12 ones complement, 217 only, 146-7 operation code, 103 operations with numbers, 24-7 or, 146-9 organization of digital machines, 251 out-code, 99 out-field, 99 output, 6, 90-1, 251-2 output devices, 176, 251-2 output register, 27 paper channel, 52 partial differential equations, 87 partial products, 115, 214 Pearl Assurance Company, 88 pebbles, 17-8 pen with a motor, 180, 195 permanent table frames, 138-9 personal income tax, 141 phonetic writing, 13 phonograph, 15-6 phonographic writing, 13 phototube, 81-2, 183-4 physical equipment for handling information, 11, 15-21, 91 physical problems, 69-72 physical quantities, 67-9 pictographic writing, 12 plugboard, 46, 98 plug-in units, 117-8 point of view, 207 pooh-pooh theory, 12 position (in a punch card), 45 position frames, 138-9 power, 43, 65, 133, 216, 224 prejudice, 205 Previous (input of comparer), 57 Primary (input of sequencer), 61-2 Primary Brushes, 51, 62 Primary Feed, 51, 61 Primary Sequence Brushes, 51 printer, 137 printer frames, 138 problem frames, 138 problem position, 132, 135 problem tape, 134 processor, 132, 134, 175 product, 70, 102, 223 product counter, 102 production scheduling, 193 program, 122, 173, 252-3 program-control switch, 123 program pulse, 122 program-pulse input terminal, 123 program register, 38 program tape, 28-9 program trays, 119 program trunk lines, 119 programming method of von Neumann, 124 pronoun, 223 psychological testing, 190 psychological trainer, 191-2 pulses, 120, 171 punch card, 17, 44-5, 95, 97 punch-card column, 45 punch-card machinery, 17, 20, 42-64, 232-9; cost, 63; reliability, 63-4; speed, 62-3 punch feed, 51-2 punched paper tape, 17, 23, 82, 95 punching channel, 50 punching dies, 48, 51-2 pyramid circuit, 39 quantity of information, 11, 14-15 quartz, 171 quotient, 98, 103 _R.U.R._, 199 radar, 183 railroad line, 6, 119 rapid approximation, 106-8, 220-1 rate of change, 68, 70-1 ratio, 77, 83 Raytheon Computer, 250 reading, 57 reading brushes, 51-2 reading channel, 50 reading of punch cards, 44 reasoning, 144 rebus-writing, 13 reciprocal, 85, 224 recognizing, 8, 182-5 recorder, 132, 137 rectifier, 32 referent, 12 register, 27 reject, 49 relay, 17, 20-1, 23, 92, 129, 133, 178; Common, 21; Ground, 21; Normally Closed, 21; Normally Open, 21; Pickup, 21 release key, 48 reliability, 63-4, 110, 126, 128, 141-2, 166, 168, 174 Remington-Rand, 43 reperforator, 137 rephrasing, 163-4 reproducer, 47, 49-50, 235 reproducing, 49 reset code, 100 resetting, 100 resistance, 80, 117 resistance coefficient, 80 resistor, 117 right-hand components, 56, 121, 215 robot machine, 197, 198-208, 255 robot salesman, 201 _robota_ (Czech), 199 Roman numerals, 212; ancient style, 219 room, 70 Rossum’s Universal Robots, 199 rounding off, 55-6 routine, 8, 167, 173 routine frames, 138-9 routine tape, 28, 134 rules, 191, 224 satisfy, 225 scale factor, 74, 86 schemes for expressing meanings, 11-15 screen, 172 screw, 78 Secondary (input of sequencer), 61-2 Secondary Brushes, 51, 62 Secondary Feed, 61 Select-Receiving-Register circuit, 39 selecting, 26, 58, 104 selection, 26-7, 38, 222 selection circuit, 38 selection counter, 104 selector, 58-60 sensing digits, 108 separation sign, 129 sequence-control tape, 98 sequence-control-tape code, 98 sequence-controlled, 89 sequence-tape feed, 98 sequencer, 61 sequencing, 61 shifting, 217 short-cut multiplication, 215-6 Simon, 22-40 simultaneous, 225 simultaneous equations, 85, 225 sine, 75, 85, 106, 139, 226 sink (of a circuit), 154 slab, 18 slide rule, 65, 67 smoothness, 110, 227 social control, types, 203 sorter, 47-9 sorting, 57, 173 soundtracks, 16, 18 source (of a circuit), 154 space key, 48 speedometer, 68 spelling rules, 185 spoken English, 11 square, 224 square matrix, 227 square root, 116-7, 173, 220, 224 Start Key, 98 statements, 26, 144-51 static electricity, 63 storage, 6 storage counter, 93 storage devices, 252 storage register, 28, 93 storing information, 15 storing register frames, 138 storing registers, 139 string, 65-6 stylus, 16 subroutine, 106 Subsidiary Sequence Mechanism, 90, 106 subtract output, 120 subtracting, 55, 100, 119, 139, 223 subtracting by adding, 223 summary punch, 50, 116, 119 summary-punching, 50 switch open and current flowing, 154 switchboard, 76 switches in parallel, 154 switches in series, 154 switching circuits, 155 syllable-writing, 13 syllables, 211 syllogism, 146, 152 symbolic logic, 221-3, 248; _see also_ mathematical logic symbolic writing, 12 synapse, 3 System of Electric Remote-Control Accounting, 250 systems for handling information, 10 table tape, 134 tables (of values), 103, 136, 224 tabular value, 136, 224 tabulator, 47, 52, 119, 235 tallies, 17 tangent, 105, 226 tank (armored), 180, 195 tank (mercury tank), 171, 179 tape-controlled carriage, 236 tape feed, 91, 178-9 tape punch, 91, 97-8, 137 tape reels, 170 tape transmitter, 135, 137 telegraph line, 6, 119 telephone central station, 138 teletype, 17 teletype transmitter, 133, 135 teletypewriter, 130, 137 ten-position relay, 91-3 ten-position switch, 91-2 ten-pulses, 120-1 tens complement, 224 test scoring machine, 236 then, 146-7 thermostat, 187 thinking, 1-5, 10, 97 timed electrical currents, 44 timing contact, 94 tolerances, 67, 105 torque, 73, 86 torque amplifier, 73 trajectories, 69, 114, 141 transfer circuit, 33 transferring, 31, 34, 100, 119, 167 translating, 57 transmitter, 74 triggering control, 183, 186-7 trigonometric tables, 226 trigonometric tangent, 105, 226 truth, 144 truth table, 147, 155, 222 truth value, 26, 58, 105, 147, 222 tuning, 183 turning force, 72 12 position, 45 two-position relay, 21, 91-2; _see also_ relay two-position switch, 91-2 typewriter, 16, 18 typewriter carriage, 53 unattended operation, 174 understanding, 212-3, 231 unemployment, 201-2 Unequal (output of comparer), 57 unit of information, 11, 14-5, 169 United Nations, 203, 208 United States Army Ordnance Department, 113-4 Univac, 250 University of Pennsylvania, 7, 113 unknowns, 141 Upper Brushes, 52 value tape code, 96 value tape feed, 95-6 variables, 84, 223 _vel_ (Latin), 149 verifier, 47-8, 235 vibration, 69 Vocoder, 255 Voder, 254 voltage, 74 Watson Scientific Computing Laboratory, 239 weather control, 189, 255 weather forecasting, 189, 255 wheel (of a counter), 78 white elephant, 73, 114 winch, 73 words for explaining, 209-12 X, 59 X distributor, 59 X Pickup, 59 X punch, 45, 58 X selector, 59 zero, 133, 212 _zh_ (sound), 13, 185 Zuse Computer, 250 *** END OF THE PROJECT GUTENBERG EBOOK GIANT BRAINS; OR, MACHINES THAT THINK *** Updated editions will replace the previous one—the old editions will be renamed. Creating the works from print editions not protected by U.S. copyright law means that no one owns a United States copyright in these works, so the Foundation (and you!) can copy and distribute it in the United States without permission and without paying copyright royalties. Special rules, set forth in the General Terms of Use part of this license, apply to copying and distributing Project Gutenberg™ electronic works to protect the PROJECT GUTENBERG™ concept and trademark. Project Gutenberg is a registered trademark, and may not be used if you charge for an eBook, except by following the terms of the trademark license, including paying royalties for use of the Project Gutenberg trademark. If you do not charge anything for copies of this eBook, complying with the trademark license is very easy. You may use this eBook for nearly any purpose such as creation of derivative works, reports, performances and research. Project Gutenberg eBooks may be modified and printed and given away—you may do practically ANYTHING in the United States with eBooks not protected by U.S. copyright law. Redistribution is subject to the trademark license, especially commercial redistribution. START: FULL LICENSE THE FULL PROJECT GUTENBERG LICENSE PLEASE READ THIS BEFORE YOU DISTRIBUTE OR USE THIS WORK To protect the Project Gutenberg™ mission of promoting the free distribution of electronic works, by using or distributing this work (or any other work associated in any way with the phrase “Project Gutenberg”), you agree to comply with all the terms of the Full Project Gutenberg™ License available with this file or online at www.gutenberg.org/license. Section 1. General Terms of Use and Redistributing Project Gutenberg™ electronic works 1.A. By reading or using any part of this Project Gutenberg™ electronic work, you indicate that you have read, understand, agree to and accept all the terms of this license and intellectual property (trademark/copyright) agreement. If you do not agree to abide by all the terms of this agreement, you must cease using and return or destroy all copies of Project Gutenberg™ electronic works in your possession. If you paid a fee for obtaining a copy of or access to a Project Gutenberg™ electronic work and you do not agree to be bound by the terms of this agreement, you may obtain a refund from the person or entity to whom you paid the fee as set forth in paragraph 1.E.8. 1.B. “Project Gutenberg” is a registered trademark. It may only be used on or associated in any way with an electronic work by people who agree to be bound by the terms of this agreement. There are a few things that you can do with most Project Gutenberg™ electronic works even without complying with the full terms of this agreement. See paragraph 1.C below. There are a lot of things you can do with Project Gutenberg™ electronic works if you follow the terms of this agreement and help preserve free future access to Project Gutenberg™ electronic works. See paragraph 1.E below. 1.C. The Project Gutenberg Literary Archive Foundation (“the Foundation” or PGLAF), owns a compilation copyright in the collection of Project Gutenberg™ electronic works. Nearly all the individual works in the collection are in the public domain in the United States. If an individual work is unprotected by copyright law in the United States and you are located in the United States, we do not claim a right to prevent you from copying, distributing, performing, displaying or creating derivative works based on the work as long as all references to Project Gutenberg are removed. Of course, we hope that you will support the Project Gutenberg™ mission of promoting free access to electronic works by freely sharing Project Gutenberg™ works in compliance with the terms of this agreement for keeping the Project Gutenberg™ name associated with the work. You can easily comply with the terms of this agreement by keeping this work in the same format with its attached full Project Gutenberg™ License when you share it without charge with others. 1.D. The copyright laws of the place where you are located also govern what you can do with this work. Copyright laws in most countries are in a constant state of change. If you are outside the United States, check the laws of your country in addition to the terms of this agreement before downloading, copying, displaying, performing, distributing or creating derivative works based on this work or any other Project Gutenberg™ work. The Foundation makes no representations concerning the copyright status of any work in any country other than the United States. 1.E. Unless you have removed all references to Project Gutenberg: 1.E.1. The following sentence, with active links to, or other immediate access to, the full Project Gutenberg™ License must appear prominently whenever any copy of a Project Gutenberg™ work (any work on which the phrase “Project Gutenberg” appears, or with which the phrase “Project Gutenberg” is associated) is accessed, displayed, performed, viewed, copied or distributed: This eBook is for the use of anyone anywhere in the United States and most other parts of the world at no cost and with almost no restrictions whatsoever. You may copy it, give it away or re-use it under the terms of the Project Gutenberg License included with this eBook or online at www.gutenberg.org. If you are not located in the United States, you will have to check the laws of the country where you are located before using this eBook. 1.E.2. If an individual Project Gutenberg™ electronic work is derived from texts not protected by U.S. copyright law (does not contain a notice indicating that it is posted with permission of the copyright holder), the work can be copied and distributed to anyone in the United States without paying any fees or charges. If you are redistributing or providing access to a work with the phrase “Project Gutenberg” associated with or appearing on the work, you must comply either with the requirements of paragraphs 1.E.1 through 1.E.7 or obtain permission for the use of the work and the Project Gutenberg™ trademark as set forth in paragraphs 1.E.8 or 1.E.9. 1.E.3. If an individual Project Gutenberg™ electronic work is posted with the permission of the copyright holder, your use and distribution must comply with both paragraphs 1.E.1 through 1.E.7 and any additional terms imposed by the copyright holder. Additional terms will be linked to the Project Gutenberg™ License for all works posted with the permission of the copyright holder found at the beginning of this work. 1.E.4. Do not unlink or detach or remove the full Project Gutenberg™ License terms from this work, or any files containing a part of this work or any other work associated with Project Gutenberg™. 1.E.5. Do not copy, display, perform, distribute or redistribute this electronic work, or any part of this electronic work, without prominently displaying the sentence set forth in paragraph 1.E.1 with active links or immediate access to the full terms of the Project Gutenberg™ License. 1.E.6. You may convert to and distribute this work in any binary, compressed, marked up, nonproprietary or proprietary form, including any word processing or hypertext form. However, if you provide access to or distribute copies of a Project Gutenberg™ work in a format other than “Plain Vanilla ASCII” or other format used in the official version posted on the official Project Gutenberg™ website (www.gutenberg.org), you must, at no additional cost, fee or expense to the user, provide a copy, a means of exporting a copy, or a means of obtaining a copy upon request, of the work in its original “Plain Vanilla ASCII” or other form. Any alternate format must include the full Project Gutenberg™ License as specified in paragraph 1.E.1. 1.E.7. Do not charge a fee for access to, viewing, displaying, performing, copying or distributing any Project Gutenberg™ works unless you comply with paragraph 1.E.8 or 1.E.9. 1.E.8. You may charge a reasonable fee for copies of or providing access to or distributing Project Gutenberg™ electronic works provided that: • You pay a royalty fee of 20% of the gross profits you derive from the use of Project Gutenberg™ works calculated using the method you already use to calculate your applicable taxes. The fee is owed to the owner of the Project Gutenberg™ trademark, but he has agreed to donate royalties under this paragraph to the Project Gutenberg Literary Archive Foundation. Royalty payments must be paid within 60 days following each date on which you prepare (or are legally required to prepare) your periodic tax returns. Royalty payments should be clearly marked as such and sent to the Project Gutenberg Literary Archive Foundation at the address specified in Section 4, “Information about donations to the Project Gutenberg Literary Archive Foundation.” • You provide a full refund of any money paid by a user who notifies you in writing (or by e-mail) within 30 days of receipt that s/he does not agree to the terms of the full Project Gutenberg™ License. You must require such a user to return or destroy all copies of the works possessed in a physical medium and discontinue all use of and all access to other copies of Project Gutenberg™ works. • You provide, in accordance with paragraph 1.F.3, a full refund of any money paid for a work or a replacement copy, if a defect in the electronic work is discovered and reported to you within 90 days of receipt of the work. • You comply with all other terms of this agreement for free distribution of Project Gutenberg™ works. 1.E.9. If you wish to charge a fee or distribute a Project Gutenberg™ electronic work or group of works on different terms than are set forth in this agreement, you must obtain permission in writing from the Project Gutenberg Literary Archive Foundation, the manager of the Project Gutenberg™ trademark. Contact the Foundation as set forth in Section 3 below. 1.F. 1.F.1. Project Gutenberg volunteers and employees expend considerable effort to identify, do copyright research on, transcribe and proofread works not protected by U.S. copyright law in creating the Project Gutenberg™ collection. Despite these efforts, Project Gutenberg™ electronic works, and the medium on which they may be stored, may contain “Defects,” such as, but not limited to, incomplete, inaccurate or corrupt data, transcription errors, a copyright or other intellectual property infringement, a defective or damaged disk or other medium, a computer virus, or computer codes that damage or cannot be read by your equipment. 1.F.2. LIMITED WARRANTY, DISCLAIMER OF DAMAGES - Except for the “Right of Replacement or Refund” described in paragraph 1.F.3, the Project Gutenberg Literary Archive Foundation, the owner of the Project Gutenberg™ trademark, and any other party distributing a Project Gutenberg™ electronic work under this agreement, disclaim all liability to you for damages, costs and expenses, including legal fees. YOU AGREE THAT YOU HAVE NO REMEDIES FOR NEGLIGENCE, STRICT LIABILITY, BREACH OF WARRANTY OR BREACH OF CONTRACT EXCEPT THOSE PROVIDED IN PARAGRAPH 1.F.3. YOU AGREE THAT THE FOUNDATION, THE TRADEMARK OWNER, AND ANY DISTRIBUTOR UNDER THIS AGREEMENT WILL NOT BE LIABLE TO YOU FOR ACTUAL, DIRECT, INDIRECT, CONSEQUENTIAL, PUNITIVE OR INCIDENTAL DAMAGES EVEN IF YOU GIVE NOTICE OF THE POSSIBILITY OF SUCH DAMAGE. 1.F.3. LIMITED RIGHT OF REPLACEMENT OR REFUND - If you discover a defect in this electronic work within 90 days of receiving it, you can receive a refund of the money (if any) you paid for it by sending a written explanation to the person you received the work from. If you received the work on a physical medium, you must return the medium with your written explanation. The person or entity that provided you with the defective work may elect to provide a replacement copy in lieu of a refund. If you received the work electronically, the person or entity providing it to you may choose to give you a second opportunity to receive the work electronically in lieu of a refund. If the second copy is also defective, you may demand a refund in writing without further opportunities to fix the problem. 1.F.4. Except for the limited right of replacement or refund set forth in paragraph 1.F.3, this work is provided to you ‘AS-IS’, WITH NO OTHER WARRANTIES OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PURPOSE. 1.F.5. Some states do not allow disclaimers of certain implied warranties or the exclusion or limitation of certain types of damages. If any disclaimer or limitation set forth in this agreement violates the law of the state applicable to this agreement, the agreement shall be interpreted to make the maximum disclaimer or limitation permitted by the applicable state law. The invalidity or unenforceability of any provision of this agreement shall not void the remaining provisions. 1.F.6. INDEMNITY - You agree to indemnify and hold the Foundation, the trademark owner, any agent or employee of the Foundation, anyone providing copies of Project Gutenberg™ electronic works in accordance with this agreement, and any volunteers associated with the production, promotion and distribution of Project Gutenberg™ electronic works, harmless from all liability, costs and expenses, including legal fees, that arise directly or indirectly from any of the following which you do or cause to occur: (a) distribution of this or any Project Gutenberg™ work, (b) alteration, modification, or additions or deletions to any Project Gutenberg™ work, and (c) any Defect you cause. Section 2. Information about the Mission of Project Gutenberg™ Project Gutenberg™ is synonymous with the free distribution of electronic works in formats readable by the widest variety of computers including obsolete, old, middle-aged and new computers. It exists because of the efforts of hundreds of volunteers and donations from people in all walks of life. Volunteers and financial support to provide volunteers with the assistance they need are critical to reaching Project Gutenberg™’s goals and ensuring that the Project Gutenberg™ collection will remain freely available for generations to come. In 2001, the Project Gutenberg Literary Archive Foundation was created to provide a secure and permanent future for Project Gutenberg™ and future generations. To learn more about the Project Gutenberg Literary Archive Foundation and how your efforts and donations can help, see Sections 3 and 4 and the Foundation information page at www.gutenberg.org. Section 3. Information about the Project Gutenberg Literary Archive Foundation The Project Gutenberg Literary Archive Foundation is a non-profit 501(c)(3) educational corporation organized under the laws of the state of Mississippi and granted tax exempt status by the Internal Revenue Service. The Foundation’s EIN or federal tax identification number is 64-6221541. Contributions to the Project Gutenberg Literary Archive Foundation are tax deductible to the full extent permitted by U.S. federal laws and your state’s laws. The Foundation’s business office is located at 809 North 1500 West, Salt Lake City, UT 84116, (801) 596-1887. Email contact links and up to date contact information can be found at the Foundation’s website and official page at www.gutenberg.org/contact Section 4. Information about Donations to the Project Gutenberg Literary Archive Foundation Project Gutenberg™ depends upon and cannot survive without widespread public support and donations to carry out its mission of increasing the number of public domain and licensed works that can be freely distributed in machine-readable form accessible by the widest array of equipment including outdated equipment. Many small donations ($1 to $5,000) are particularly important to maintaining tax exempt status with the IRS. The Foundation is committed to complying with the laws regulating charities and charitable donations in all 50 states of the United States. Compliance requirements are not uniform and it takes a considerable effort, much paperwork and many fees to meet and keep up with these requirements. We do not solicit donations in locations where we have not received written confirmation of compliance. To SEND DONATIONS or determine the status of compliance for any particular state visit www.gutenberg.org/donate. While we cannot and do not solicit contributions from states where we have not met the solicitation requirements, we know of no prohibition against accepting unsolicited donations from donors in such states who approach us with offers to donate. International donations are gratefully accepted, but we cannot make any statements concerning tax treatment of donations received from outside the United States. U.S. laws alone swamp our small staff. Please check the Project Gutenberg web pages for current donation methods and addresses. Donations are accepted in a number of other ways including checks, online payments and credit card donations. To donate, please visit: www.gutenberg.org/donate. Section 5. General Information About Project Gutenberg™ electronic works Professor Michael S. Hart was the originator of the Project Gutenberg™ concept of a library of electronic works that could be freely shared with anyone. For forty years, he produced and distributed Project Gutenberg™ eBooks with only a loose network of volunteer support. Project Gutenberg™ eBooks are often created from several printed editions, all of which are confirmed as not protected by copyright in the U.S. unless a copyright notice is included. Thus, we do not necessarily keep eBooks in compliance with any particular paper edition. Most people start at our website which has the main PG search facility: www.gutenberg.org. This website includes information about Project Gutenberg™, including how to make donations to the Project Gutenberg Literary Archive Foundation, how to help produce our new eBooks, and how to subscribe to our email newsletter to hear about new eBooks.