

DIGITAL COMPUTER AND CONTROL ENGINEERING

McGRAW-HILL ELECTRICAL AND ELECTRONIC ENGINEERING SERIES

Frederick Emmons Terman, Consulting Editor W. W. Harman and J. G. Truxal, Associate Consulting Editors

Ahrendt and Savant. Servomechanism Practice
Angelo - Electronic Circuits
Aseltine. Transform Method in Linear System Analysis
Atwater - Introduction to Microwave Theory
Bailey and Gault • Alternating-current Machinery
Beranek. Acoustics
Bracewell. The Fourier Transform and Its Application
Brenner and Javid • Analysis of Electric Circuits
Brown • Analysis of Linear Time-invariant Systems
Bruns and Saunders - Analysis of Feedback Control Systems
Cage • Theory and Application of Industrial Electronics
Cauer - Synthesis of Linear Communication Networks
Chen - The Analysis of Linear Systems
Chen • Linear Network Design and Synthesis
Chirlian - Analysis and Design of Electronic Circuits
Chirlian and Zemanian • Electronics
Clement and Johnson • Electrical Engineering Science
Cote and Oakes • Linear Vacuum-tube and Transistor Circuits
Cuccia • Harmonics, Sidebands, and Transients in Communication Engineering
Cunningham - Introduction to Nonlinear Analysis
D'Azzo and Houpis • Feedback Control System Analysis and Synthesis
Eastman - Fundamentals of Vacuum Tubes
Feinstein - Foundations of Information Theory
Fitzgerald and Higginbotham - Basic Electrical Engineering
Fitzaerald and Kingsley • Electric Machinery
Frank - Electrical Measurement Analysis
Friedland, Wing, and Ash • Principles of Linear Networks
Ghausi - Principles and Design of Linear Active Circuits
Ghose - Microwave Circuit Theory and Analysis
Greiner - Semiconductor Devices and Applications
Hammond - Electrical Engineering
Hancock • An Introduction to the Principles of Communication Theory
Happell and Hesselberth • Engineering Electronics
Harman - Fundamentals of Electronic Motion
Harman - Principles of the Statistical Theory of Communication
Harman and Lytle • Electrical and Mechanical Networks
Harrington - Introduction to Electromagnetic Engineering
Harrington • Time-harmonic Electromagnetic Fields
Hayashi • Nonlinear Oscillations in Physical Systems
Hayt • Engineering Electromagnetics
Hayt and Kemmerly • Engineering Circuit Analysis
Hill • Electronics in Engineering
Javid and Brenner • Analysis, Transmission, and Filtering of Signals
Javid and Brown • Field Analysis and Electromagnetics
Johnson - Transmission Lines and Networks
Koenig and Blackwell • Electromechanical System Theory
Kraus • Antennas
Kraus - Electromagnetics
Kuh and Pederson • Principles of Circuit Synthesis

Ledley - Digital Computer and Control Engineering
LePage. Complex Variables and the Laplace Transform for Engineering
LePage and Seely - General Network Analysis
Ley, Lutz, and Rehberg • Linear Circuit Analysis
Linvill and Gibbons • Transistors and Active Circuits
Littader • Pulse Electronics
Lynch and Truxal - Introductory System Analysis
Lynch and Truxal • Principles of Electronic Instrumentation
Lynch and Truxal• Signals and Systems in Electrical Engineering
Millman • Vacuum-tube and Semiconductor Electronics
Millman and Seely • Electronics
Millman and Taub • Pulse and Digital Circuits
Millman and Taub • Pulse, Digital, and Switching Waveforms
Mishein and Braun - Adaptive Control Systems
Moore - Traveling-wave Engineering
Nanavati - An Introduction to Semiconductor Electronics
Pettit • Electronic Switching, Timing, and Pulse Circuits
Pettit and McWhorter. Electronic Amplifier Circuits
Pettit and McWhorter. Concepts of Probability Theory
Pfeiffer - Linear Systems Analysis
Reza - An Introduction to Information Theory
Reza and Seely - Modern Network Analysis
Rogers • Introduction to Electric Fields
Ryder - Engineering Electronics
Schwartz - Information Transmission, Modulation, and Noise
Schwarz and Friedland - Linear Systems
Seely - Electromechanical Energy Conversion
Seely - Electron-tube Circuits
Seely. Electronic Engineering
Seely • Introduction to Electromagnetic Fields
Seely • Radio Electronics
Seifert and Steeg - Control Systems Engineering
Siskind - Direct-current Machinery
Skilling • Electric Transmission Lines
Skilling-Transient Electric Currents
Spangenberg • Fundamentals of Electron Devices
Spangenberg•Vacuum Tubes
Stevenson - Elements of Power System Analysis
Stewart • Fundamentals of Signal Theory
Storer - Passive Network Synthesis
Strauss - Wave Generation and Shaping
Su•Active Network Synthesis
Terman - Electronic and Radio Engineering
Terman and Pettit - Electronic Measurements
Thaler - Elements of Servomechanism Theory
Thaler and Brown • Analysis and Design of Feedback Control Systems
Thaler and Pastel. Analysis and Design of Nonlinear Feedback Control Systems
Thompson - Alternating-current and Transient Circuit Analysis
Tou • Digital and Sampled-data Control Systems
Tou • Modern Control Theory
Truxal. Automatic Feedback Control System Synthesis
Valdes • The Physical Theory of Transistors
Van Bladel. Electromagnetic Fields
Weinberg - Network Analysis and Synthesis
Williams and Young. Electrical Engineering Problems

# DIGITAL GOMPUTER AND CONTROL ENGINEERING 

ROBERT STEVEN LEDLEY<br>ASSOCIATE PROFESSOR OF ELECTRICAL ENGINEERING<br>THE GEORGE WASHINGTON UNIVERSITY<br>CONSULTANT MATHEMATICIAN<br>TO THE NATIONAL BUREAU OF STANDARDS

WRITTEN WITH THE ASSISTANCE OF

LOUIS S. ROTOLO JAMES BRUCE WILSON Research Scientist Research Associate<br>The George Washington University

McGRAW-HILL BOOK COMPANY, INC.
New York Toronto London
1960

DIGITAL COMPUTER AND CONTROL ENGINEERING
Copyright © 1960 by the McGraw-Hill Book Company, Inc. Printed in the United States of America. All rights reserved. This book, or parts thereof, may not be reproduced in any form without permission of the publishers. Library of Congress Catalog Card Number 59-15055
vII
36981
the maple press company, york, pa.

TO MY SONS
FREDDY AND GARY

## FOREWORD

Until less than a century ago, men toiled manually to produce the very clothes they wore, shelters they lived in, and food they ate. The industrial revolution-derived from the invention of machines that automatically make commodities-was a revolution that vastly enlarged man's productive capabilities. The effect is observed upon comparing the daily life of a man of a century ago with that of a modern man, in his highly mechanized economic and interdependent social civilization. Now we are on the threshold of a new kind of revolution, a revolution that may in the future have even more far-reaching effects, vastly increasing man's "thinking" capabilities of planning, analyzing, computing, controlling. This new revolution derives from the availability of machines that automatically compute and control. We know its effects will be great, but we now can only speculate on the forms they will take. Not only will its influence be directly marked in the physical sciences and in technology, but, perhaps even more significantly, it will have a tremendous effect on the biological sciences and on the economic, political, and social aspects of our civilization. Its effects during the productive life span of the infant of 1960 will certainly be greater than those the industrial revolution has had during the life span of the infant of 1900 . Pivotal in the growth and development of this newest of mankind's capabilities will be the digitalcomputer and -control engineer, whose primary occupation is the creation -the research, development, and production-of these new machines.

There is another quite remarkable aspect of digital-computer and control engineering. Never before in the history of human endeavor has a new development of such scope and complexity emerged so rapidly. Within a single decade this entirely new field, constructing and utilizing thousands of new computers, has already penetrated almost all phases of our modern society, from nuclear-energy production and missile design to the processing of bank checks, business invoices, and medical diagnoses. And in the research stages there are already components that might make it feasible to build computers manyfold more complex than present-day computers.

Beyond the unique potential to mankind and the phenomenal growth of the field is yet a third relatively unique aspect of digital-computer and control engineering. It is fast becoming one of the broadest in scope and most demanding of all engineering fields, encompassing fundamental aspects of logic, mathematics, systems engineering, as well as solid-state
physics and electrical engineering. Since an error of only a single bit in a program or the breakdown of a single gate or component of a digital computer or control can result in the failure of the entire system, high meticulousness is demanded of the engineer. Thus his training must not only cover a wide range of topics but must as well emphasize precise attention to detail.

This book is the first comprehensive elementary engineering text in the digital-computer- and digital-control-engineering field (although there are several excellent advanced books in more specialized aspects of the field). The book seeks to present a new synthesis of educational material possessing a unity and breadth arising from the organization of the various aspects of digital-computer and -control engineering as a whole. It provides the material of a basic field of study for all students of electrical engineering, regardless of their ultimate specialty. However, it is hoped that this book may help stimulate a number of young engineers to enter this dynamic and vitally young field.

Samuel $N$. Alexander<br>Chief, Data Processing System Division<br>The National Bureau of Standards

## PREFACE

General Information. The purpose of this book is to fill the need for a comprehensive elementary-engineering textbook in the large and still rapidly growing field of digital computers and controls. (The term control is used to emphasize that digital control and digital computers are based on the same principles.) The need for such a text is not confined to engineering schools; in industry as well, the graduate engineer with a few sporadic encounters with digital circuitry needs a sound introduction to the burgeoning literature on all phases of digital computers and controls.

Within the first five years after he earns his degree almost every electrical engineer will deal with some phase of digital circuitry. Therefore a course on digital computers is required for all candidates for the bachelor of electrical engineering degree at The George Washington University. This is indicative of a trend in engineering schools throughout the country.

This text is based on experience I gained in teaching courses on digital computers at The George Washington University School of Engineering. It is directed to senior undergraduate engineering students and first-year graduate students and is intended primarily for a year's course. Prerequisites are college physics, calculus, and at least a first course in electronic circuits, although no great proficiency in these subjects is required. Since it is an elementary exposition of the principles of digitalcomputer and control engineering, the book covers topics in all three phases of the subject: the over-all design of digital systems (Parts 1 and 2) ; the logical design of digital circuitry (Parts 3 and 4) ; and the electronic design of digital circuits (Part 5).

An introductory exposition of a field as large and complex as this can never hope to treat all subjects exhaustively. Full treatment must be left to specialized source books, handbooks, and journal articles. Almost without exception, each chapter of this book could be used as the basis for an entire book in itself-this is in fact true of some sections as well. Each chapter is designed to introduce the student to certain fundamental concepts and techniques of development. The method of teaching is by example rather than by generalized exposition. It is felt that the student is more capable of grasping abstractions from specifics than of extracting concepts from discussions based on generalizations alone. Hence I have tried wherever it was possible to guide the student by means of specific, concrete examples. From experience I have found that this
pedagogical method is particularly well suited to engineering students.
Since there has been no previous comprehensive text in the field, there is no precedent for the choice of topics. The subjects covered were chosen to present a continuous, natural development of the major aspects of the field in the limited time available to the engineering student. Of course in any field of this size there will exist differences of opinion as to which topics should and should not be included. I feel that I have chosen those topics of greatest importance and that this comprehensive treatment will satisfy the needs of the largest number of readers.

Much attention was paid to the exercises, of which more than 750 appear in the book. The exercises at the end of each section serve to illustrate the material of the section, to enable the student to gain computational facility, and to extend the material to closely related topics not covered in the section. Almost every chapter ends with Additional Topics, a section designed to introduce the reader to new material not covered in the chapter and to stimulate his further reading in the field. The text includes many new results of original research never previously compiled into book form, some of which here appear in publication for the first time (see Special Technical Features below).

Outline of the Text. Perhaps the most outstanding capability afforded by digital techniques is that of decision making, as exemplified by the programmed system. Thus Part 1, the first of two parts on digital systems, is concerned with the digital programmed system. Its first two chapters are introductory in nature: the first is intended to motivate the student by delineating the wide range of applications of digital systems and controls; the second is designed to orient the student with respect to the digital-computer-engineering field. The next three chapters are directly concerned with programming; their purpose is to expose the engineering student to a large variety of instruction and operation formats, as well as to the practice of coding. Sequencing of instructions in four-, three-, two-, and one-address-system instruction formats is considered. The fundamental concepts of the loop, or iteration, and the subroutine are introduced, followed by a discussion of the various kinds of operations that instructions can involve. At the end of Part 1 we consider the formulation of program-checking and computer-maintenance programs. Further automatic-programming techniques lay the groundwork for a simplified presentation of the international algebraic automatic program called ALGOL.

Part 2 is concerned with the functional approach to digital-systems design; here again the purpose is to expose the student to a variety of possible systems-design concepts. Numerical analysis is considered, as the basis of the systems design of the general-purpose digital computer. Here the concept of the polynomial-approximation approach is stressed as a fundamental method for reducing most mathematical computation to additions, subtractions, multiplications, and divisions. Next are described computational methods other than those of classical numerical
analysis, methods which are, however, of fundamental importance in business and in other activities requiring data reduction. Besides techniques for searching and sorting, examples of methods for redundant and irredundant coding are considered. In order to demonstrate clearly the possibility of other than general-purpose computers, the digital differential analyzer is considered, along with real-time control and other techniques. Also a general discussion is included of the concepts underlying the "super" computers now in the research and developmental stages. Finally I introduce the Pedagac, a small general-purpose computer intended to provide the necessary thread of continuity to the study of digital-computer engineering (see below for further discussion of the Pedagac).

Probably the "newest" of the concepts confronting the uninitiated reader in digital-computer and -control engineering is that concerned with Boolean algebra as the basis for the logical design of digital circuits. Thus Part 3, the first of two parts on the logical design of digital circuitry, is concerned with the mathematical foundations of Boolean algebra. First Boolean algebra is introduced in terms of propositions, for it is advisable that the engineer understand the relation of Boolean algebra to other concepts as well as digital circuitry. Hence we take up the propositional-calculus representation and the class, or set, representation before the digital-circuit representation. The method of using bases and associated designation numbers in the succeeding chapters (which was first fully developed by the author, although it appeared implicitly in some earlier writings) has been found admirably suited to the teaching of the logical design of digital circuits. On the basis of this method, several modern procedures for the simplification of Boolean functions are explained, leading into the design of digital circuits to compute elementary synchronous recursive functions. In the final three chapters of this part, digital computational methods of importance in logical circuit design are considered. With few exceptions the methods presented are based on the author's original research. Elementary algorithms, including methods for solving Boolean equations and their application to circuit design, are given. Chapters 13 and 14 consider computations with Boolean matrices, the former being concerned with the theoretical development of the methods, the latter with applications of these results. (Should it be desired to study the applications of the computational methods before delving into the details of the proofs, Chap. 13 has been written so that the applications of Chap. 14 may be considered directly after Sec. 13-3 with no loss of continuity.)

Part 4 is concerned with the logical design of specific computer components. First the serial arithmetic unit is considered, then parallel and rapid arithmetic operations. Since the philosophy of teaching general principles by specific example is used, a survey of methods of performing arithmetic operations is not given. Instead the discussions are centered round a few illustrations, carefully chosen for their suitability in demon-
strating clearly the concepts involved in circuits that perform arithmetic operations. Next the various problems are considered that arise in the computation of control functions, beginning with a general discussion of minimum decoding procedures. Finally the concept of packaging is introduced, and with the logical design of the Pedagac as an illustrative example, many of the important aspects of the final logical design of a complete digital system are elucidated.

The last part, Part 5, is concerned with what is probably the most active field in digital-computer and -control engineering, the electronic design of digital circuits. The goals of the electronic design of circuits for use in digital computers and controls are derived from considerations of the digital-systems design and the logical design already covered. Here again the attempt is made to teach concepts through selected examples of circuits. Clearly, in these rapidly developing and dynamic fields, detailed discussions of many different specific circuits are not justified-many of them would certainly be obsolescent before publication of the book. Hence specific circuits are used only as concrete illustrations of the more general underlying principles. The experienced reader will observe that the topics covered in many of the individual sections can well afford entire books to themselves. The first chapter of this part is concerned with the two most important problems involved in the transition from abstract systems and logical design to the electronic realization of digital circuits, namely, timing, or clock phasing, and reliability. Then aspects of the use of semiconductor devices, diodes and transistors, in electronic-digital-circuit design are considered. Here the most important concept to be learned is a thorough understanding of the use of the devices; hence much space is devoted to discussion of the physical operation and the equivalent circuit of transistors. Consideration of magnetic elements in digital-circuit design follows, encompassing magnetic-core and multiaperture gating devices as well as magnetic amplifiers. The discussion ends with a section on two most promising modern circuit developments, Cryotron and microwave circuits. The next chapter is concerned with the closely related memory methods and input-output techniques. Only core and film high-speed memories are considered, since the use of other high-speed memory forms is rare; for the same reason only tape and drum low-speed memories are described. Many of the most important input-output methods depend on analog-to-digital and digital-to-analog conversion, and these are accordingly included in this chapter. In this context a full explanation of the important sampling theorem is given. The final chapter illustrates some exceedingly important topics in the final design of a computer, through the electronics and wiring diagram of the Pedagac.

Special T'echnical Features. In Part 1 of the text Sec. 5-9 is concerned with the International Algebraic Language (ALGOL). This general automatic algebraic programming language contains the primary features of other automatic programs, such as FORTRAN, IT, etc., and has the advantage of becoming widely accepted. Sponsored by the Association
for Computing Machinery and several foreign societies, the universal acceptance of ALGOL would undoubtedly have a great beneficial effect on the national and international exchange of ideas and methods of programming.

Special features of Part 2 include J. H. Wegstein's general method for accelerating the convergence of iterative solutions to equations, in Sec. $6-3$. The Tabledex method and the techniques of searching with relaxed conditions given in Secs. 7-3 and 7-4, as well as the new, more accurate formulas for evaluating superimposed coding given in Sec. 7-7, are the original work of the author. The specific method of Sec. 8-3 for coding the control computer was developed by the author, while the method for coding the logistics and business computer, appearing in Sec. 8-5, is based on the work of W. H. Marlow.

In Part 3 the computational methods for constraints, logical dependence and independence, solution to Boolean algebraic equations, and transformation to the absolute simplest form, given in Secs. 12-2 through $12-10$, are the author's original developments. The method of antecedence and consequence solutions, the fundamental Boolean matrix formulas and their proofs, given in Secs. 14-1 through 14-6, are the result of the author's original research, as are also the extension of the use of designation numbers to three (or more) -valued logic and their application to the design of three-valued digital circuits (Sec. 12-11). The extension of the fundamental Boolean matrix formulas to multivalued logic, as given in Sec. 14-7, was developed by W. R. Smith and N. F. J. Matthews; the general solution to the logical matrix equation given in that section was developed by W. R. Smith. R. D. Elbourn deserves credit for the direct method of finding prime implicants given in Sec. 11-7.

The discussions of the parallel adder and of rapid multiplication, in Secs. 16-2 and 16-4 of Part 4, are based on the work of A. Weinberger and J. L. Smith. The rapid-division method of Sec. 16-5 was developed by the author and J. B. Wilson. The treatment of minimum decoding methods is based on a development of C. H. Page. In Part 5 the proba-bilistic-logic approach to increasing circuit reliability (Sec. 19-4) is the author's adaptation of a development of W. S. McCulloch. The transistor equivalent circuit, described in Sec. 20-4 for the most commonly used grounded-emitter voltage-drive configuration, is based on an original development of S. B. Geller. The magnetic amplifier of E. W. Hogue in Sec. 21-3 presents a new technique for magnetic amplification. Section 23-4 on minimum-wiring theory is based on the works of $H$. Loberman and A. Weinberger.

Special Pedagogical Feature: The Pedagac. It has been my experience that, although students might understand most of the various isolated aspects of computer engineering, they still might not visualize the complete process of designing and building a computer. In order to provide the necessary thread of continuity to the study of computer engineering, a simple computer, the Pedagac ("Pedagogic Automatic Computer") is designed from start to finish in the book (see Chaps. 9, 18, and 23). At
first glance the Pedagac may seem unduly specific. However, this is far from true, for the Pedagac serves as a concrete example by means of which many exceedingly important points are illustrated. Many of these points would be completely meaningless to the student if they were not developed in the context of an entire system. The Pedagac was specially designed to illustrate pertinent subject matter most clearly from a pedagogical (rather than cost or production, etc.) point of view. The arithmetic unit is serial, since a parallel arithmetic unit would have overwhelmed the student with primarily repetitive circuitry. The registers are static flip-flops, for these are the most easily understood in relation to arithmetic operations. The control is of a parallel nature, which is in general easier to comprehend. Eight clock phases are used to simplify the transition from logical to electronic design. The specially designed packages were made as simple in concept as possible.

Possible Course Structures. This text may be used for college courses in several different ways. For a two-term course the first term may cover Parts 1 and 2, and Part 3 through Chap. 12; the second term, the remainder of the book. Or the book may be used for a two-term composite elementary-advanced course: the elementary course may include much of the fundamentals of digital-computer engineering, and then those students who wish to pursue the subject in more detail may continue in the more advanced course. One suggested elementary course would consider Chaps. 1 to 4 of Part 1, Chaps. 6 and 7 of Part 2, Chaps. 10 and 11 of Part 3, Chaps. 15 and 16 of Part 4, and Chaps. 19 and 20 of Part 5; the more advanced course that follows would complete the text. A more leisurely treatment of the subject may be given in a three-term course, with more attention being paid to the selected readings and other projects and subjects mentioned in the Additional Topics sections. Here Parts 1 and 2 may be covered the first term, Part 3 the second term, and Parts 4 and 5 the third term. Other, perhaps quite eclectic, arrangements will certainly occur to the experienced instructor.

Acknowledgments. It gives me the greatest pleasure to acknowledge the help and cooperation I have received from many persons during the preparation of this book. My sincerest thanks go to James B. Wilson, who carefully and tirelessly edited the entire manuscript, contributing many important and valuable improvements to the style and technical presentation; to Louis S. Rotolo, who assisted in the designing of the Pedagac and with the Pedagac chapters, was extremely helpful in the preparation of the manuscript, and contributed many valuable suggestions; and to William R. Smith, who critically read the entire manuscript, prepared most of the technical illustrations, and helped in numerous other ways. I would like also to express my gratitude to R. D. Elbourn for reviewing the manuscript, making many constructive criticisms. The encouragement and support given by E. Frank and N. T. Grisamore have been greatly appreciated. Many colleagues helped by supplying advice and information on various technical points. Of these the author particularly wishes to mention A. Weinberger, J. A. Cunning-
ham, S. B. Geller, E. W. Hogue, J. H. Wegstein, the late M. Abramowitz, H. Loberman, S. Greenwald, E. R. Toense, W. W. Youden, J. L. Smith, D. R. Boyle, C. H. Page, W. H. Marlow, N. F. J. Matthews, and J. Rabinow. The author is indebted to G. U. Uyehara, N. T. Grisamore, and R. A. Toense for assisting in the design of the Pedagac package. The quality of the illustrations is in large part due to the skill and talent of J. E. Ozefovich, D. K. Anand, and A. Bucek, as well as W. R. Smith. The author wishes to thank Eva March Cuddy, Edna Crum, and Judith Holsberg for typing most of the manuscript. He gratefully acknowledges the partial support of the Mathematics Division of the Air Force Office of Scientific Research, Air Research and Development Command, and the Information Systems Branch of the Office of Naval Research, without which the preparation of the manuscript would have been impossible.

Robert Steven Ledley

1

## CONTENTS

Foreword. ..... ix
Preface ..... xi
PART 1. INTRODUCTION TO DIGITAL PROGRAMMED SYSTEMS
Chapter 1. Applications of Digital Computers and Control ..... 1
1-1. Introduction ..... 1
1-2. Numerical Solution to Equations ..... 2
1-3. Process Control ..... 9
1-4. Simulations ..... 13
1-5. Data Processing ..... 18
1-6. Additional Topics ..... 23
Chapter 2. Principles and Block Diagram of a Digital Computer ..... 25
2-1. Introduction ..... 25
2-2. Block Diagram of a Computer ..... 26
2-3. Functional Description of a Computer ..... 30
2-4. Words and Pulses ..... 34
2-5. Logical Building Blocks ..... 38
2-6. Input, Output, and Memory Systems ..... 44
2-7. Digital-computer and -control Engineering ..... 54
$2-8$. Additional Topics ..... 55
Chapter 3. Coding and Programming a Digital Computer ..... 60
3-1. Introduction ..... 60
3-2. Number Systems: Conversion ..... 62
3-3. Number Systems: Arithmetic ..... 69
$3-4$. Coding: Sequences of Instructions ..... 71
$3-5$. Coding Decisions ..... 76
3-6. Coding: Flow Charting and Symbolic Code Aids ..... 78
3-7. Three-address Instruction Systems ..... 81
3-8. Two-address Instruction Systems ..... 84
3-9. One-address Instruction Systems ..... 86
3-10. Decimal Systems ..... 90
3-11. Additional Topics ..... 92
Chapter 4. Programming Fundamentals ..... 94
4-1. Introduction ..... 94
4-2. Recursion Codes and Instruction Modification ..... 95
$4-3$. The Subroutine ..... 104
4-4. Instruction Types ..... 108
4-5. Instruction Types (Continued) ..... 114
4-6. Special Coding Techniques ..... 118
4-7. The Control Panel ..... 124
4-8. Additional Topics ..... 128
Chapter 5. Advanced Programming . ..... 130
$5-1$. Introduction ..... 130
5-2. Program Debugging Methods and Routines ..... 131
$5-3$. Computer Maintenance Routines ..... 135
5-4. Interpretive Routines: Mathematical ..... 139
5-5. Interpretive Routines: Simulational ..... 142
5-6. Memory Space, Speed of Computation, and Automatic Programming ..... 148
5-7. Compiling Routines: Translator; Address Assigner ..... 150
5-8. Compiling Routines: Algebraic ..... 155
5-9. The International Algebraic Language (ALGOL) ..... 159
5-10. Additional Topics ..... 171
PART 2. FUNCTIONAL APPROACH TO SYSTEMS DESIGN
Chapter 6. Fundamentals of Numerical Analysis ..... 173
6-1. Introduction ..... 173
6-2. Simultaneous Linear Equations ..... 174
6-3. Algebraic and Transcendental Equations ..... 178
6-4. Function Evaluation: Series and Continued Fractions ..... 183
6-5. Function Evaluation: Interpolation ..... 186
6-6. Function Evaluation: Best-fit Polynomial Approximation ..... 190
6-7. Integration ..... 193
6-8. Differentiation ..... 196
6-9. Undetermined Coefficients ..... 198
6-10. Differential Equations ..... 200
6-11. Accuracy and Error ..... 203
6-12. Additional Topics ..... 211
Chapter 7. Searching, Sorting, Ordering, and Codifying ..... 215
7-1. Introduction ..... 215
7-2. Methods of Searching ..... 218
7-3. Manual Searching Methods ..... 223
7-4. Searching with Relaxed Conditions ..... 226
7-5. Sorting and Ordering ..... 230
7-6. Ordering by Merging ..... 236
7-7. Codifying: Error Correction and Superimposition ..... 242
7-8. Additional Topics ..... 253
Chapter 8. Special-purpose Digital-computer Systems Design ..... 256
8-1. Introduction ..... 256
8-2. The Digital Differential Analyzer ..... 257
8-3. Real-time Logical Systems Control: A Real-time Control Computer 262
8-4. Systems Design for Special-purpose Information-retrieval Computer268
8-5. Manipulations with Rectangular Arrays: A Business and Logistics Com- puter 271
8-6. The Large-scale Data Processor ..... 281
8-7. Additional Topics ..... 286
Chapter 9. Systems Design of the Pedagac ..... 288
PART 3. FOUNDATIONS FOR THE LOGICAL DESIGN OF DIGITAL CIRCUITRY
Chapter 10. Introduction to Boolean Algebra and Digital-computer Circuits ..... 295
10-1. Introduction ..... 295
10-2. Definition of Logic and Propositions ..... 296
10-3. Definition of Propositional Operations ..... 297
10-4. Implication, Equivalence, and Tautology ..... 299
10-5. Truth Tables ..... 300
10-6. Boolean Algebra ..... 302
10-7. Boolean Algebra as the Algebra of Sets ..... 304
10-8. Digital-computer Circuits ..... 306
10-9. Boolean Algebra as the Algebra of Digital-computer Circuits ..... 308
10-10. From Circuit Diagram to Boolean Function ..... 309
10-11. From Boolean Function to Circuit Diagram ..... 314
10-12. Additional Topics ..... 315
Chapter 11. The Designation Numbers and the Design of Function Circuits ..... 320
11-1. Introduction ..... 320
11-2. The Designation Numbers ..... 321
11-3. The First and Second Canonical Forms ..... 324
11-4. Included and Nonincluded Elementary Elements ..... 326
11-5. Mongrel Forms ..... 329
11-6. Simplest Sum-of-products Representation ..... 331
11-7. Obtaining Essential Prime Implicants Directly ..... 336
11-8. Simplification of Computer-circuit Design ..... 344
11-9. The Design of Circuits That Compute Functions ..... 346
11-10. Synchronous Recursive-function Circuits ..... 351
11-11. The States of Circuits ..... 356
11-12. Additional Topics ..... 361
Chapter 12. Elementary Computational Methods in Circuit Design ..... 368
12-1. Introduction ..... 368
12-2. Constraints ..... 368
12-3. Logical Dependence and Independence ..... 374
12-4. Constraints in Circuit Design ..... 376
12-5. Linear Boolean Equations ..... 379
12-6. The General Method for Solution to Any Number of Simultaneous Equations in Any Number of Unknowns ..... 384
12-7. Solution to Equations in Circuit Design ..... 389
12-8. The Absolute Simplest Form and Change of Variables ..... 393
12-9. Transformation to the Absolute Simplest Form ..... 396
12-10. The Absolute Simplest Form in Circuit Design ..... 400
12-11. Additional Topics ..... 402
xxiiCONTENTS
Chapter 13. Boolean Matrix Equations and the Fundamental Formulas ..... 414
13-1. Introduction and Statement of the Problem ..... 414
13-2. Designation Numbers and Boolean Matrices ..... 419
13-3. Antecedences and Consequences, and the Fundamental Formulas ..... 424
13-4. Solution to the General Boolean Matrix Equation ..... 428
13-5. Solution to the Unitary Matrix Equation ..... 434
13-6. Derivation of the Fundamental Matrix Equation and the Fundamental Formulas ..... 439
13-7. Additional Topics ..... 441
Chapter 14. Applications of Matrix Equations in Circuit Design ..... 448
14-1. Type 1 Problems in Circuitry ..... 448
14-2. Type 2 Problems in Circuitry ..... 450
14-3. Type 3 Problems in Circuitry ..... 453
14-4. Constraints in the Problems ..... 462
14-5. Ordinary Equations ..... 465
14-6. More General Circuit-design Problems ..... 470
14-7. Additional Topics ..... 476
PART 4. LOGICAL DESIGN OF DIGITAL-COMPUTER CIRCUITRY
Chapter 15. Serial Arithmetic Operations ..... 485
15-1. Introduction ..... 485
15-2. Common Computer Components ..... 487
15-3. Common Computer Components (Continued) ..... 491
15-4. Preliminaries to Synchronous Operation ..... 498
15-5. Serial Arithmetic Unit: Addition and Subtraction ..... 502
15-6. Serial Arithmetic Unit: Multiplication and Division ..... 511
15-7. Additional Topics ..... 517
Chapter 16. Parallel and Rapid Arithmetic Operations ..... 519
16-1. Introduction ..... 519
16-2. The Parallel Adder: Logical Design ..... 519
16-3. Parallel Arithmetic Units ..... 525
16-4. Rapid Multiplication ..... 528
16-5. Rapid Division ..... 533
16-6. Floating Operations ..... 538
16-7. Additional Topics ..... 540
Chapter 17. Control ..... 543
17-1. Introduction ..... 543
17-2. The Decoding Circuit ..... 547
17-3. Arithmetic Control: Instruction Decoder and Operations Signal Gener- ator ..... 553
17-4. Arithmetic Control: Internally Generated Signals and Register Con- trol ..... 557
17-5. Control of Memory Address Selection and Instruction Sequencing ..... 559
17-6. Memory Selection ..... 562
17-7. Control of Instruction Execution ..... 568
17-8. Timing and Counters ..... 571
Chapter 18. Packaging and the Logical Design of the Pedagac ..... 575
18-1. Introduction ..... 575
18-2. Packaging ..... 576
18-3. Phases and Block Diagram of the Pedagac ..... 580
18-4. Operations Signal Generator ..... 586
18-5. Arithmetic Unit: Vertical Description ..... 590
18-6. Arithmetic Unit: Horizontal Description ..... 595
18-7. Instruction Register, Current-address Register, Instruction Decoder, Memory-selection Unit, and Counters 606
18-8. Phase Generator, Buffer, and Push Buttons ..... 615
18-9. Additional Topics ..... 621
PART 5. ELECTRONIC DESIGN OF DIGITAL CIRCUITS
Chapter 19. Problems and Limitations in Electronic Realization ..... 623
19-1. Introduction ..... 623
19-2. Types of Digital Gating Systems ..... 624
19-3. Clock Phases and Synchronization ..... 631
19-4. Methods for Increasing Circuit Reliability ..... 634
19-5. Additional Topics ..... 643
Chapter 20. Semiconductor Elements in Digital-circuit Design. ..... 645
20-1. Introduction ..... 645
20-2. Solid-state Semiconductor Devices ..... 645
20-3. Transistors ..... 650
20-4. Transistor Equivalent Circuit ..... 658
20-5. Diode-gated Circuits ..... 667
20-6. Transistor Gating and Flip-Flops ..... 672
20-7. The Tunnel Diode ..... 679
20-8. Additional Topics ..... 684
Chapter 21. Magnetic Elements in Digital-circuit Design ..... 689
21-1. Introduction ..... 689
21-2. Magnetic Properties and Materials for Digital Circuits ..... 693
21-3. Diode-gated Magnetic-amplifier Circuits ..... 698
21-4. Magnetic Gating ..... 704
21-5. Modern Computer Techniques ..... 711
21-6. Additional Topics ..... 719
Chapter 22. Memory and Input-Output Methods ..... 724
22-1. Introduction ..... 724
22-2. Magnetic-core Memories ..... 724
22-3. Magnetic-film Memories ..... 728
22-4. Magnetic Tapes and Drums ..... 732
22-5. Conversion from Analog to Digital and from Digital to Analog ..... 739
22-6. Input-Output Methods ..... 747
22-7. Additional Topics ..... 757
Chapter 23. The Electronic Design of the Pedagac ..... 764
23-1. Introduction ..... 764
23-2. Problems in the Electronic Design of the Pedagac ..... 765
23-3. Problems in Assigning Clock Phases ..... 769
23-4. Minimum-wiring Theory ..... 773
23-5. Wiring Table for the Pedagac ..... 782
23-6. Additional Topics ..... 786
Appendix ..... 787
Name Index ..... 807
Subject Index ..... 815

## INTRODUCTION TO DIGITAL PROGRAMMED SYSTEMS

## CHAPTER 1

## APPLICATIONS OF DIGITAL COMPUTERS AND CONTROL

## 1-1. Introduction

The purpose of this chapter is to stimulate the reader to want to know what is in the rest of the book. By illustrating how computers can be applied, we hope to interest the reader in how he might help design and use these remarkable machines. The wide range of potential applications of digital computers and control in all phases of science, industry, and government is truly amazing. In the sciences applications range from mathematics and physics to biology and medicine. The early applications were in engineering and physics, but perhaps the greatest scientific use of computers yet to come is in the biological, medical, and social sciences. In business and industry applications range from automatic banking, inventory control, and process control to the precise control of milling machines to produce parts requiring complicated hightolerance machining and to missile-testing processes. In government applications range from automatic patent searching and post-office sorting to large-scale control of defense weapon systems. Present applications are already too numerous to list in a single volume, but they are infinitesimal compared with the potential future applications. We hope, however, that by presenting brief descriptions of just a few applications we may impart to the reader a better insight into how digital computers and controls are used.

In general a computer can be conceived as a numerical-transformation machine. Numbers are the inputs to it, and the computer transforms these numbers into new numbers, which appear as the outputs:

$$
\text { Input numbers } \rightarrow \text { computer } \rightarrow \text { output numbers }
$$

For instance, the input numbers may be the initial conditions of a differential equation; the output numbers will be a table of the functional solutions. Or the input numbers may be readings from an engineering drawing, and the output numbers will be coded instructions to direct a special milling machine. Or the input numbers may be codes that
represent a patient's symptoms; the output numbers may be codes that represent possible alternative disease diagnoses.

There are two main kinds of electronic computers: digital and analog. In digital computers the numbers (digits) themselves are handled explicitly by the computer; an analog computer instead deals with a representation of the numbers, for instance, by voltages, lengths, etc. In this book we are concerned with digital computers only. These can be classified as general-purpose or special-purpose computers. In the first part of this book we shall describe the general-purpose computer; in Part 2 we shall consider some of the special-purpose computers. Specialpurpose digital computers are sometimes referred to as digital controls. The same engineering principles are involved in the design of either general-purpose computers or special-purpose digital-control computers. Therefore we have used the two terms in the title of the book.

For the purposes of this chapter we have arbitrarily classified computer applications into four categories; many applications can fall into more than one of our categories. First we shall consider numerical solutions to equations. This represents an important class of applications, and undoubtedly it is these applications which makers of the first computers had in mind. The first of these applications described is based on principles familiar to every electrical engineer, the motion of charged particles in a vacuum. However, the context of the application discussed here has far greater significance. Problems involving the solution to equations are not limited to the physical sciences; equations can be written to describe many biological phenomena as well. The second category is process control: Here the need for digital computers with specialized capabilities becomes apparent. It is probably not an exaggeration to say that the third category came into being because of the great capabilities of the computers: this is simulation. Before the advent of computers, simulations (except perhaps laboriously calculated military war games) were rarely even discussed because they were clearly not feasible to perform. However, with the advent of high-speed computers simulations have become practical, and great new fields of scientific research have been opened. Most of the present-day computer applications can probably be classed in the fourth category, data processing: Business accounting, statistical reductions, information retrieval, and many other important but routine procedures can be handled by computers.

## 1-2. Numerical Solution to Equations

Motion of Charged Particles in the Earth's Magnetic Field. Project Argus was a major scientific and military experiment conducted by the United States (Fig. 1-1). Rockets carried a small atomic bomb more than 300 miles above the earth, at this altitude the bomb was exploded, and a resulting thin layer of radiation spread quickly round the globe. Nuclear and atomic particles were propelled by the exploding bomb and streaked through the vacuum of the universe under forces almost entirely due to the earth's magnetic field. Some particles moved toward the
earth's poles and caused artificial auroras (northern and southern lights). In order to measure the characteristics of this radiation layer, an earth satellite and other rockets were launched with paths passing through the layer (see Fig. 1-2). Instruments in the satellite and rockets transmitted measurements back to earth. Scientifically the shots rank among mankind's foremost experiments. They showed that radiation introduced


Fig. 1-1. Announcement of Argus shots.
into space by man can have significant effects over those of natural radiation. Militarily the Argus shots indicated that the additional radiation added to the natural radiation interfered with man's electronic communications. The grave consequence is that such interference can be caused at will.

The Argus project tested theoretical calculations of what would take place when the small atomic bomb was exploded above the earth's atmosphere. Where would the electrons and other particles go? This was a problem in the study of the motion of charged particles in a magnetic field (the earth's) and is in principle, except for the shape of the field, the same as the problems encountered in magnetically directing an electron beam in a television tube, or accelerating particles in a betatron, or circulating particles in a cyclotron, etc. If the earth's
magnetic field is represented as that of a magnetic dipole, and if $x, y$, and $z$ are cartesian coordinates with the $z$ axis directed along the earth's magnetic axis from south to north, then from electromagnetic field theory


Fig. 1-2. Earth satellite measuring characteristics of radiation layer.
it can be shown that the trajectories of the charged particles are given by the solutions to the following differential equations (where the superscript dots denote differentiation with respect to time):

$$
\begin{aligned}
\ddot{x} & =\frac{M q}{m c}\left\{-\left(x^{2}+y^{2}+z^{2}\right)^{-5 / 5}\left[\left(2 z^{2}-x^{2}-y^{2}\right) \dot{y}-3 y z \dot{z}\right]\right\} \\
\ddot{y} & =\frac{M q}{m c}\left\{-\left(x^{2}+y^{2}+z^{2}\right)^{-5 /[ }\left[\left(x^{2}+y^{2}-2 z^{2}\right) \dot{x}+3 x z \dot{z}\right]\right\} \\
\ddot{z} & =\frac{M q}{m c}\left\{+3 z\left[k\left(x^{2}+y^{2}+z^{2}\right)^{-5 / 2}+\left(x^{2}+y^{2}\right)\left(x^{2}+y^{2}+z^{2}\right)^{-4}\right]\right\}
\end{aligned}
$$

where $k=(x \dot{y}-y \dot{x})-\left(x^{2}+y^{2}\right)\left(x^{2}+y^{2}+z^{2}\right)^{-3 / 2}$
$M=$ earth's magnetic dipole strength
$m=$ relativistic mass of particle
$q=$ charge of particle
$c=$ speed of light
The initial conditions are the initial coordinates ( $x_{0}, y_{0}, z_{0}$ ) of the particle and the components ( $\dot{x}_{0}, \dot{y}_{0}, \dot{z}_{0}$ ) of its velocity just after the explosion.

These equations can be used to plot the paths of the charged particles given their initial velocities and directions. The distribution of the initial velocities and directions can be calculated from nuclear physics; the trajectories of different kinds of particles can then be computed for many different initial conditions in the distribution. The complexity of these computations requires the use of a digital computer. The basic importance of such a calculation preliminary to the actual experiment is evident: by predicting the motion of the particles, proper and adequate plans can be made concerning the instrumentations of the satellite and the measurements to be made, the best geographical location of the experiment, the optimum altitude for exploding the bomb, and so forth.

Hydrodynamics of Blood Flow. The partial differential equations that describe biological phenomena more often than not defy analytical solution. Attempts are usually made either to introduce simplifying assumptions or to isolate special aspects of the problem for investigation. Both these alternatives involve certain compromises on the part of a researcher. Such compromises can often be avoided, however, by using an electronic computer to solve the original partial differential equations numerically.

Consider the problem of blood flow through a large artery-aninstance of pulsed viscous fluid flow in an elastic tube. The first step in an investigation of this problem is the formulation of hypotheses about the hydrodynamic principles involved and the derivation of the corresponding partial differential equations. The second step is to devise an experiment from which boundary conditions for the equations may be determined. The third step is to solve the equations on a computer, comparing the solutions with the data obtained experimentally. Probably adjustments will be required in the hypotheses and the equations, and further experiments and computations will have to be devised. In this way the phenomenon can be studied in its entirety.

For example, the following equations can be derived, assuming laminar viscous flow and an exponential functional form for the elasticity of the blood vessel:

$$
\begin{array}{rlrl}
V & =-\frac{1}{8 \mu} \frac{d P}{d x} A^{2} & F & =-\frac{\pi A^{4}}{8 \mu} \frac{d P}{d x} \\
\frac{\partial}{\partial t} A^{2}+\frac{\partial}{\partial x} A^{2} V & =0 & \frac{d P}{d A} & =C A^{m}
\end{array}
$$

where $P=$ pressure
$F=$ average flow through a cross section
$V=$ average blood velocity over a cross section
$\mu=$ coefficient of blood viscosity
$A=$ radius of aorta
$x=$ distance along aorta
$t=$ time
$C, m=$ constants
The experiment was to measure the pressure, as a function of time, at
equally spaced intervals along the aorta of an anesthetized dog (see Fig. 1-3). The intercostal arteries (between the ribs) were tied, so that there was no significant outflow from the aorta, and a flowmeter was placed at one end of the aorta. The boundary conditions chosen were the flow and the pressure at one end of the aorta; the equations were used to predict the pressure at the other points along the aorta. The accuracy of the predictions with respect to the experimental results would indicate the degree of validity of the original hypotheses upon which the equations were based. Such experiments can have important applications to the prevention and cure of heart diseases in man.


Fig. 1-3. Hydrodynamics of blood flow.
The Design of a Lens System. The need for accurate high-altitude photography has gained importance with the suggestion that aerial inspections be used as a means of averting atomic wars. For this work lenses of very high resolving power must be designed for aerial cameras. Figure 1-4 shows the detail that can be obtained from high-altitude photographs using modern lens systems. The scientific design of lens systems has become feasible only through the use of electronic computers.

The problem of designing a lens system consists in tracing the paths of many rays, emanating from a single object point, through the lens system to the final image plane (see Fig. 1-5). The extent of deviations in the image plane of these rays is a measure of the resolving power of the system. The computer computes the path of each ray as it would be refracted on passing through each spherical lens surface of the system. The initial direction of each ray is taken from the object point under consideration, and the position of impingement of this ray on the first lens surface is computed. Then the new direction of the ray as it leaves this first surface is calculated, and from this its position on the second lens surface is computed. In this way the ray is traced through the entire lens system, and its position on the final image plane is determined


Fig. 1-4. Aerial photography ( $25,000 \mathrm{ft}$ ), with enlargement of circled portion of photograph. [Photographs courtesy U.S. Air Force Air Photographic and Charting Service (MATS).]

Table 1-1. Flow Diagram of Computations for Tracing a Ray through a Lens System $\dagger$

Read into the computer three constants for the lens surface presently under consideration:
$C_{1}=$ curvature of spherical lens surface
$t=$ distance between this and previous lens surface
$\mu_{1}=\frac{N}{N_{1}}=$ ratio of indices of refractions of lens surface to left and right, respectively

## $\downarrow$

Read into the computer six constants for the ray being traced, namely:
$T=(x, y, z)=$ three coordinates of ray on previous lens surface
$Q=(X, Y, Z)=$ three components of unit direction vector of ray leaving previous surface

Compute $T_{1}=\left(x_{1}, y_{1}, z_{1}\right)$, the coordinates of the point where the ray strikes this lens surface, by means of the following incidence equations:

$$
\begin{aligned}
& x_{1}=x+L X-t \\
& y_{1}=y+L Y \\
& z_{1}=z+L Z \\
& \\
& \text { where } \quad \\
& \text { and } \quad=e+\frac{C_{1} M^{2}-2 M_{x}}{X+\xi} \\
& \xi=\left[X^{2}-C_{1}\left(C_{1} M^{2}-2 M_{x}\right)\right]^{3 / 2} \\
& M^{2}=x^{2}+y^{2}+z^{2}-e^{2}+t^{2}-2 t x \\
& M_{x}=x+e x-t \\
& e=t x-(x X+y Y+z Z)
\end{aligned}
$$

## $\downarrow$

Compute $Q_{1}=\left(X_{1}, Y_{1}, Z_{1}\right)$, the components of the unit direction vector of the refracted ray leaving this surface, by means of the following refraction equations:

$$
\begin{aligned}
& X_{1}=\mu_{1} X-g C_{1} x_{1}+g \\
& Y_{1}=\mu_{1} Y-g C_{1} y_{1} \\
& Z_{1}=\mu_{1} Z-g C_{1} z_{1} \\
& g=\xi^{\prime}-\mu_{1} \xi \\
& \xi^{\prime}=\left[1-\mu_{1}{ }^{2}\left(1-\xi^{2}\right)\right]^{3 / 2}
\end{aligned}
$$

where
and $\xi$ was found in the previous box.
Print out $T_{1}=\left(x_{1}, y_{1}, z_{1}\right)$ and $Q_{1}=\left(X_{1}, Y_{1}, Z_{1}\right)$.

Repeat the computation for each lens surface of the system in sequence from left to right until the ray position on the final image plane has been determined.
$\dagger$ The subscripted variables refer to the lens surface under consideration; the nonsubscripted variables refer to the previous surface.
(see Table 1-1 and Fig. 1-6). The results of a set of such computations from one object point are shown to the right of Fig. 1-5, where each dot represents the final position of a ray on the image plane. In an ideal lens system all the rays would fall on the same point in the final image plane. The dispersion of the dots indicates the resolving power of the real lens system.


Fig. 1-5. Ray tracing.


Fig. 1-6. Geometry of ray tracing.

## 1-3. Process Control

Machine-tool Control. $\dagger$ Significant improvements in many manufacturing processes can be obtained with the application of digital dataprocessing and control techniques. An example is digital machine-tool control, used to improve the over-all process of producing many different and complicated parts needed in our modern technology. Greater accuracy, reproducibility, and versatility are obtained as tooling costs and skilled-manpower requirements are reduced. It increases our capabilities to produce greater quantities and varieties of precision-machined parts, thus revolutionizing their potential use.

Consider a milling machine cutting a two-dimensional contour. The cutting tool is moved in the $x$ and $y$ directions by means of high-performance hydraulic servo drives. These servo drives are controlled by rapidly sequenced pulses that tell the servos precisely where to move the
$\dagger$ See Y. C. Ho and E. C. Johnson, Design of a Numerical Milling Machine System, Proc. Eastern Joint Computer Conf., 1957, Washington, D.C.
tool in order to obtain the contour finally desired. For instance, each time the $x$-direction control receives a pulse, it might advance the tool 0.0002 in . in the $x$ direction; if we assume that there can be up to 20,000 such pulses per second, the tool can be made to advance in the $x$ direction a maximum of $0.0002 \times 20,000=4 \quad \mathrm{ips}=20 \mathrm{fpm}$. By varying the number of pulses per second, up to the maximum, the speed with which the tool moves in the $x$ direction can be precisely controlled. The control of the $y$-direction motion of the tool is similar. Thus the tool can be directed to move round any desired contour. The precision of machining the desired part is of course limited by the smallest increment of distance of the control.


Fig. 1-7. Cutter offset path.
The problem of digital machine-tool control reduces to that of transforming information on a blueprint design into an appropriately timed sequence of $x$ and $y$ input control pulses. The control pulses direct the center of the cutting tool, but the desired contour is formed by the edge of the cutter; hence the proper cutter offset must be calculated from the blueprint. See, for example, Fig. 1-7, where the circles indicate some of the successive positions of the cutter. If we assume in Fig. 1-7 that the graph lines are 0.0002 in . apart, then the dots represent the successive positions of the offset path of the cutter's center that should be directed by the control pulses. (For example, the diagonal cut would be made by two pulses in the $y$ direction for each one pulse in the $x$ direction.) Of course, in a realistic case the part would be many times the size illustrated, and hence the number of input pulses required would be very large. Thus it would be a difficult job to start from the blueprint and
manually determine the detailed sequences of control pulses. The method of interpreting the blueprint design for the automatically controlled milling machine is divided into two steps. First the cutter's offset path is determined grossly in terms of the end points of straight-line path segments, and radii of circular contours, and so forth, as shown in Fig. 1-8. This in itself can present difficult problems of curve fitting. (Can you determine the equations of the offset path for the contour illustrated in Fig. 1-8?) The second step is to inter-


Fig. 1-8. Gross determination of cutter's offset path. polate between these points and from the radii, etc., to determine finally the precise 0.0002 -in. input-pulse fine structure.

Two computers are used for this process. The first is a general-purpose digital computer into which are put the specifications for the part contour taken from the blueprint. These might take the forms "diagonal at arctan 2," "straight 4 inches," "horizontal 3 inches," "radius 2 inches," etc. Or the input to the digital computer might be the blueprint itself,


Fig. 1-9. Machine-tool control process.
put into the computer by means of a "picture-reading" machine. The computer is programmed to compute from such input data the gross data of the offset cutter path. This is perhaps put out in the form of punched paper tape, like the rolls of a player piano, or in the form of a deck of punched cards. The second computer is used to control the milling machine directly. The punched paper tape or card deck is put into this control computer, which interpolates, etc., to produce the finestructure input pulses to the servo drives. The entire process is illustrated in Fig. 1-9.


> Fig. 1-10. Control of chemical plant.

Control of Chemical Plant. In many factories the processing of raw materials frequently involves sequences of decisions for which all alternative possibilities are known. By means of digital computers the entire processing can be made completely automatic. Control of this kind has the advantages that the decision processes themselves become more reliable when performed electronically and that the design of more complicated processes becomes feasible. As a specific example, consider a simplified version of a chemical factory that produces $\mathrm{Al}_{2} \mathrm{O}_{3}$ (see Fig. $1-10) . \dagger$ Table 8-2 summarizes the conditions which initiate various actions in the plant. The column entitled "Sensed-signal conditions" represents the list of conditions requiring some operation to be performed. The column entitled "Corresponding signals to be generated" indicates the actions to be taken.

Input signals to the control computer are transmitted by wires from critical places in the factory (see Fig. 1-10). These signals, defined in Table 8-1, consist essentially of two-valued (on or off) test results which in combination tell the computer the present state of the factory. For example, signal $L(1)$ will be a pulse when the mixture in mixing tank 1 is at or above a predetermined level and no pulse if the mixture is below this level. Each signal is initiated by a transducer, a device that converts mechanical information into electrical information, or vice versa. The transducers for our example convert fluid levels in tanks, temperatures, chemical concentrations, volumes of precipitate in a centrifuge, pressures, and so forth, into the electrical pulses that are the inputs to the computer. The outputs from the control computer are electrical signals supplied to transducers (servomechanisms) that open and close valves or hatches and otherwise operate to change the state of the factory. Table 8-2 shows under what conditions such changes of state will be initiated.

## 1-4. Simulations

Industrial Dynamics. The term industrial dynamics refers to the processes and factors influencing the economic development of an industrial corporation considered as an interacting part of a free competitive economy. The study of industrial dynamics involves so many factors that no complete analytical mathematical analysis is yet possible. Many universities in the United States, in cooperation with many industrial corporations, are attempting to simulate aspects of the indus-trial-dynamics problem. Representatives of management take part in such simulations, making decisions; the digital computer then computes the effects of these decisions and produces a report to the management representatives, who make new decisions, etc. (see Fig. 1-11). One advantage of such simulations is that they aid in training management personnel by presenting them with many and different industrial circum-
$\dagger$ The control of this particular process will be considered in greater detail in Sec. $8-3$; it suffices here to outline briefly the kind of input information supplied to the computer and the way the computer then controls the factory. (See pp. 262 to 267.)

stances analogous to real situations. A second advantage is that the simulations aid the study of industrial dynamics by bringing before the scientists involved situations not encountered through purely academic study. And, third, important generalizations can be deduced from the progress and results of the simulations.

As an illustration, consider a multifirm one-product competitive industry. The simulation is designed in such a way that the results of 5 years of operations can be simulated in 1 day. Each firm in the simulation is represented by a team of executives, who must make the following set of "management" decisions:

1. Price of product
2. Producing volume
3. Advertising expenditures
4. Research and development expenditures
5. Amount of new investment in plant and equipment
6. Dividends to be paid, etc.

One set of such decisions is made by each team firm for each quarter of a year. The computer then computes the interactions and effects of these decisions on the market; i.e., it simulates what may happen in reality and produces for each team a report giving:

1. Sales volume
2. Per cent of total products sales handled by this firm
3. Production capacity of this firm for the next quarter
4. Statement of profit and loss
5. Current inventory quantities
6. Statement of receipts and disbursements
7. Statement of financial conditions, etc.

Based on the study of its report, each team makes decisions as to how the firm will operate in the next quarter. These decisions are fed into the computer, and the simulations progress in this way from quarter to quarter.

The computer processes the decisions made by the teams (firms) and produces reports by means of mathematical models. The model is essentially a set of hypothetical equations relating the input information to the desired output information. For example, increased advertising bears a functional relation to increased sales, but this in turn depends on the advertising decisions of competitive firms. Increased research and development can produce an improved product which may give one firm some advantage. Price rises of course offset sales, but advertising can to a certain extent offset an increase in price. Obviously the gross profit is the product of sales volume and price per unit product, minus administrative costs, overhead, manufacturing costs, advertising, research and development, etc. The mathematical model embodying such considerations can become very complicated, depending on the level at which the simulation is intended. Evidently a great deal of study and research must be carried out in connection with the derivation of the specific equations that enter into the computer simulation. For a
simulation to be at all realistic, the complications will be so numerous as to be impossible to perform without digital computers.

Man-Machine Simulation System. Man-machine simulation is now recognized as an essential tool for the development of complex automatic systems that involve both electronic and manual controls. Such is the case, for example, in air-traffic control, ground control of interceptors, ground-controlled approach and landing, weapon assignment, or missile guidance systems. The interactions between the electronic control system being designed and the team of human operators can be studied before the system is actually constructed. This eliminates the only other alternative, the frequently prohibitively expensive process of actually building the proposed system and carrying out an extensive program of tests and modifications.

Figure 1-12 represents a simulation system that includes both a digital and an analog computer, linked with display and control equipment which permit human beings to be coupled into the system. The analogcomputer equipment is used for such tasks as accepting continuous control information and solving complex dynamic equations in real time, for which they are suited. The digital computer is used for controlling the experiment, for sequencing the stages depending on the outcome of each stage, for generating simulated data, for calculating with high precision where necessary, for handling variables with large dynamic ranges, for making logical decisions, and for statistically analyzing experimental results.

An example of a simulation is a simplified ground-controlled interceptor system (Fig. 1-12). The digital computer simulates a situation in which a large number of aircraft are observed by the search radar. A console displays the locations of these aircraft on a cathode-ray tube for the ground crew; with each aircraft is also displayed an associated identification (i.e., friendly, enemy, unknown, interceptor, bomber, commercial, etc.). The ground crew manually assigns targets to the interceptors; the targets are automatically tracked by the digital computer. A model of an interceptor cockpit fully equipped with instruments and pilot flying controls enables a human operator to imitate the actions of the interceptor pilot in flight. The pilot of the interceptor receives his flight-control information either directly from the digital computer or from the ground-crew commands. The pilot's control movements are interpreted by the analog computer, which then simulates the dynamics of the interceptor, operating the instruments in the cockpit. The velocity components of the interceptor are sent to the digital computer, which computes the path of the interceptor. The digital computer also displays the computed positions of both interceptor and target on a monitor scope for the ground crew. It is this display which gives the ground crew its information for the simulated data link with the pilot. The research control console enables a research team to set up the initial conditions, vary the target aircraft maneuvers, and determine the interceptor closure tactics. Records are kept of information generated by the


Fig. 1-12. Man-machine simulation.
interceptor pilot, analog computer, and digital computer during the experiment. These can then be analyzed on the digital computer after an experimental simulation has been completed.

## 1-5. Data Processing

Inventory Control. The annual industrial inventory of the United States has been estimated at 30 billion dollars; the cost of supporting this inventory is probably about 3 billion dollars annually in interest lost, tied-up money, depreciation, obsolescence, spoilage, storage, handling charges, and so forth. It has been estimated that the use of computer control and information-processing methods could reduce this inventory and its associated cost of support by more than 25 per cent. .(A specialpurpose inventory-control computer will be discussed in a later chapter.) Figure 1-13 indicates how a general-purpose computer could be used in an inventory-control system. Here the inventory files are electronically recorded in the computer. Inputs to the computer are items initiated outside the inventory records, such as receipts, issues, orders, shipping reports, etc. These inputs indicate the alterations in the inventory records that must be made by the computer. The outputs of the computer are items that arise from an examination of the inventory records, such as the need for more parts, orders to restock, bills or invoices for items shipped, accounting records, and other data about the current inventory records that may aid management in planning, etc. The analysis of an inventory-control problem for the use of a digital computer includes the preparation of a complete report on all the processing requirements, process charts of the data flow, and definitions of the controls. These reports and charts correspond to the equations describing a scientific problem.

Consider, for example, a concern that manufactures and sells certain products, and suppose that the company keeps the following files (see Fig. 1-13) : (a) a customer master file that contains all customers' names, addresses, purchases, balances due, credits, etc.; (b) a products inventory master file that contains the kind and number of each product in stock as well as its location, price, and other identifying descriptions and numbers; (c) a factory parts and raw-materials inventory file that contains a list of all parts and materials stocked that enter into the manufacturing process, together with descriptive identifications and numbers; and (d) a suppliers master file that contains all suppliers' names, addresses, supply records, balances due, credits, orders not yet received, and so forth. The procedure by which the computer keeps such files up to date and generates information from them will now be described; the reader should keep in mind that our intention is to give a gross idea of the problems involved, and we have hence oversimplified the circumstances. More realistically, these problems are characterized by huge masses of detailed considerations.

The customer file would be updated each time an order, payment, or return was received from the customer. At the same time the computer


Fig. 1-13. Inventory-control system.
would produce the necessary pricing and shipping information (i.e., customer discount, location, etc.) if an order was made, or the customer's refund order if a return was made. The products inventory file would be updated each time a report was received of shipping or completing a product. If a product was to be shipped, the computer would produce the product description number and warehouse location, and it would also produce an order for more products to be manufactured if the shipment reduced the inventory below a predetermined level. The computer can also produce the invoice for a sale from the proper information received from the files. The file of parts and raw materials used in the manufacturing processes would be updated each time a report was made of parts and materials used, returned, or received. The computer would determine what replacement orders and returns should be made as well as update the inventory. The supplier file would be updated each time a bill was received, or report of return or receipt was made. The computer would produce the payment orders to the supplier. Finally the computer would produce reports requested by management, on the basis of the various file records.

Airline Reservation System. In the reservation system of a nationwide airline, every minute hundreds of inquiries about seats available, actual sales, cancellations, and unsatisfied demands must be processed. Each ticket office in the United States of a particular airline must be able to interrogate the same centrally located computer concerning seats available on particular flights and to make reservations on particular flights; the processing of each query must be completed within a few seconds. The main advantages of such a system are that the customer is provided with an immediate reservation service and the airline is provided with an accurate inventory system almost devoid of errors.

A simplified reservation system is shown in Fig. 1-14. Each ticket office contains a reservation interrogation and sales machine, which is connected by transmission lines to a central service area. At the central service area, records are electronically stored on the availability and disposition of all seats on all airplanes to be flown by the airline, for about a month in the future. The processing of a reservation starts at the ticketoffice machine. Let us say that a customer desires two seats from Washington, D.C., to Chicago on Apr. 30 on the 3 p.m. flight. The sales clerk observes that Flight 83 leaves Washington, D.C., at 3 P.m. and goes to Seattle via Chicago, and chooses the card for Flight 83 from a file box. Each flight card contains information about two flights, one on each of the long edges. Along the edge are printed the scheduled stops, leaving a margin which is punched with a code representing the flight number. The clerk puts the punched margin of the card into a slot in the ticket-office machine, then presses buttons indicating the number of seats (two) and the date (Apr. 30) desired. The names of the cities on the card appear opposite a row of buttons on the machine, and the clerk pushes the buttons next to the names of the desired cities, Washington and Chicago. Then he presses the $I$ (interrogation) button.

Meanwhile the remote scanner (see Fig. 1-14) is searching for a ticketoffice machine with a card in it. When one is located, the remote scanner connects the ticket-office machine with the computer. The marginal punches on the card are sensed by the computer and tell it which flight is being interrogated; the date, number of seats, etc., are also transmitted to the computer. If two seats are available on Flight 83 for Apr. 30, the computer transmits the information to the ticket-office machine by illuminating the proper lights on it. If the customer desires to make the reservations, the $R$ (reservation) button is pushed and the computer subtracts two from the number of seats available on Flight 83.


Fig. 1-14. Airline reservation system.
If no seats were available, the no-seats-available light would have been illuminated. Similarly a cancellation can be made, and so forth. Of course our illustration has been greatly simplified, but the essential operations performed by the computer and the problems involved have been demonstrated.

Aids to Medical Diagnosis. It has been recognized that electronic computers can aid certain aspects of medical diagnosis. For example, the computer can (1) produce a list of possible diagnoses, consistent with medical knowledge, for a given set of symptoms presented by a patient; (2) indicate further diagnostic tests which best differentiate between remaining diagnostic possibilities; (3) calculate the probabilities for the alternate diagnostic possibilities; and (4) enable a more precise statement and analysis of the value decisions which may be associated with treatment planning. Such computer applications must be based on extensive medical data; hence a further use of computers is (5) to compile statistics that (a) relate symptom-disease combinations and that (b) evaluate
disease-treatment-prognosis results. These statistics are then used in future diagnosis, treatment, and prognosis determination. In addition, the computer can serve as an indispensable aid, under certain special circumstances: The computer can (6) enable criteria of a more quantitative nature to be utilized in evaluating the results of certain diagnostic procedures (such as electrocardiograms, electroencephalograms, etc.) and can perform the complicated calculations necessary for the proper interpretation of certain clinical measurements. Finally, the computer can significantly aid the important aspect of information retrieval in, for example, (7) the rapid retrieval of current information about new preventive measures, diagnostic techniques, and specific treatments, and (8) the accumulation and retrieval of desired aspects of a particular patient's total medical history (such as total radiation dosage received, previous allergic reactions, individual biochemical and physiologic norms and deviations, etc.).


Fig. 1-15. Hypothetical health-computing system.
Consider a modern high-speed electronic digital computer, and suppose that it has been programmed to aid medical diagnosis. Let us assume further that the physician can directly communicate with the computer by telephone, teletype, radio, etc. The value of such a computer interrogation arises from three factors: (1) the ability of the computer to formulate a treatment plan that will maximize the chance of curing the patient; (2) the ability to determine the minimum number of necessary medical laboratory tests or other diagnostic procedures for the particular patient; and (3) the ability to evaluate more accurately diagnostic-test results for a particular patient based upon his previously recorded health records.

A network of such computers could form a hypothetical healthcomputing system (see Fig. 1-15). Here each computer can communicate with individual physicians and hospitals within its area, receiving, transmitting, and computing medical information as required. However, the area computers must be capable of communicating with each other as well, since approximately 20 per cent of Americans change addresses each year, and probably most of us go on at least one trip per year. Also, all the area computers could communicate with a special research computer that could sample data as required for various research and public health-control investigations.

The great significance and importance of such a health-computer network cannot be overestimated as an aid to increasing individual good health and longevity and as a vast new source of medical information concerning mankind.

## 1-6. Additional Topics

$a$. The following references are not intended to be a complete bibliography on the use of digital computers; rather they are intended as sources of past and future applications.

## Books

Alt, Franz L.: "Electronic Digital Computers-Their Use in Science and Engineering," Academic Press, Inc., New York, 1958.
Bowden, B. V.: "Faster than Thought," Pitman Publishing Corporation, New York, 1953.

Canning, R. G.: "Electronic Data Processing for Business and Industry," John Wiley \& Sons, Inc., New York, 1956.
Chapin, Ned: "Automatic Computers-A System Approach for Business," D. Van Nostrand Company, Inc., Princeton, N.J., 1959.
Eckert, W. J., and Rebecca Jones: "Faster, Faster," McGraw-Hill Book Company, Inc., New York, 1956.
Edmundson, H. P., et al.: Studies in Machine Translation, Repts. 1-9, Rand Corp., 1958.

Gass, Saul I.: "Linear Programming Methods and Applications," McGraw-Hill Book Company, Inc., New York, 1958.
Gotlieb, C. C., and J. N. P. Hume: "High-speed Data Processing," McGraw-Hill Book Company, Inc., New York, 1958.
Jeenel, Joachim: "Programming for Digital Computers," McGraw-Hill Book Company, Inc., New York, 1959.
Ledley, R. S., and J. B. Wilson: "Programming and Utilizing Digital Computers," McGraw-Hill Book Company, Inc., New York, in press.
Livesley, R. K.: "Digital Computers," Cambridge University Press, New York, 1957.
Locke, W. N., and A. D. Booth (eds.): "Machine Translation of Languages," John Wiley \& Sons, Inc., New York, 1955.
McCracken, D. D.: "Digital Computer Programming," John Wiley \& Sons, Inc., New York, 1957.

## Periodicals

The Computer Journal, British Computer Society, Ltd., London.
Computers and Automation, Edmund C. Berkeley and Associates, New York.
Computing News, J. W. Granholm, Seattle.
Control Engineering, monthly, McGraw-Hill Publishing Company, New York.
Data Processing Digest, Canning, Sisson, \& Associates, Los Angeles.
Datamation (Research and Engineering, the Magazine of Datamation), bimonthly, Relyea Publishing Co., New York.
IBM Journal of Research and Development, International Business Machines Corporation.
IRE Transactions on Electronic Computers, Professional Group on Electronic Computers, Institute of Radio Engineers, Inc., New York.
Journal of the Association for Computing Machinery, New York.
Journal of Operations Research Society of America, Baltimore.

Journal of the Society for Industrial and Applied Mathematics, Philadelphia. Machine Translation, Massachusetts Institute of Technology, Cambridge, Mass.
Mathematical Tables and Other Aids to Computation, National Academy of SciencesNational Research Council, Washington, D.C.
Proceedings of the . . Joint Computer Conferences of the Professional Group on Electronic Computers (IRE), the Association for Computing Machinery, and the American Institute of Electrical Engineers (AIEE) Committee on Computing Devices.
b. References to Analog-computer Applications. The following are but a few of the many available texts describing analog-computer applications:

Johnson, C. L.: "Analog Computer Techniques," McGraw-Hill Book Company, Inc., New York, 1956.
Korn, G. A., and T. M. Korn: "Electronic Analog Computers," 2d ed., McGraw-Hill Book Company, Inc., New York, 1956.
Murray, F. J.: "The Theory of Mathematical Machines," 2d ed., King's Crown Press, New York, 1948.

## CHAPTER 2

## PRINCIPLES AND BLOCK DIAGRAM OF A DIGITAL COMPUTER

## 2-1. Introduction

Recapitulation. In the previous chapter we gave some idea of what computers can do. We observed that, in general, initial conditions, constants, and other numbers are first read into the computer and that the computer then proceeds with the calculations, finally printing out or otherwise displaying the results. In addition, the examples presented illustrated the kinds of calculations that can be carried out by a computer. These concepts are important foundations for an appreciation and understanding of the present chapter.

Orientation. The purpose of this chapter is to orient the student in the field of digital-computer engineering; it endeavors to present a bird's-eye view of the field. Thus, as the student continues into the detailed material of this book, he should always appreciate the relationship and significance of each topic in the over-all pattern. Specific, concrete examples are used as vehicles for transmitting the over-all ideas of the design and construction of digital computers. The student should pay strict attention to the general concepts and should use the specific examples only as a basis for understanding these generalizations.

This chapter begins with a description of the block diagram of a digital computer. There follows a more detailed discussion of the functioning of the parts of the computer. From this "macroscopic" point of view we go to the "microscopic" picture of a computer, glancing at various kinds of circuitry techniques. Thus we consider briefly the methods by which a number is recorded, by which digital circuitry can perform specific functions, and by which internal controls are obtained, and describe how numbers are memorized by and read into and out of a computer. The examples have been chosen solely to be appropriate for this orientation phase of study and therefore constitute simpler and in many cases less advanced techniques. Finally, we summarize our discussion of the main features of digital-computer and -control engineering.

A large part of the orientation in any subject must necessarily be concerned with the specialized vocabulary used to describe basic concepts. Therefore there are in this chapter many such basic discussions.

## 2-2. Block Diagram of a Computer

The purpose of this section is to acquaint the student briefly with the parts of a digital computer. To this end the block diagram of a computer will be developed in steps, from the simple to the more detailed.

The Computer. As was seen in Chap. 1, a computer handles numbers; it takes numbers that are fed into it and operates on them to form new numbers-the output numbers. Hence the simplest block diagram of a computer is as shown in Fig. 2-1.


Fig. 2-1. Simplest block diagram.
The computer can perform many different kinds of operations on numbers. Most of these operations combine two numbers to produce a third number. The two numbers so combined are called the arguments of the operation, and the number produced is called the result. Many operations that a computer can perform are similar to the familiar operations used in hand computation, such as adding two numbers to form the sum, multiplying two numbers to form the product, etc. Also analogous to hand computing is the fact that the computer can perform only one such operation at a time. $\dagger$ Hence, when many operations are to be performed, they must be performed in some appropriate sequence.

The computer is told what operations to perform by means of instructions. An instruction not only contains information about an operation to be performed but also designates the two arguments (usually) for the desired operation. When the operation specified by an instruction has been completed by the computer, i.e., when the result has been obtained, the instruction is said to have been executed.

For example, suppose that we wanted to compute the value of

$$
y=a(b+c)
$$

where $a, b$, and $c$ represent some specific real numbers. A sequence of instructions that would tell a computer to form $a(b+c)$ is as follows:

|  | Operation | 1st argument | 2d argument | Result |
| :--- | :--- | :---: | :---: | :---: |
| Instruction $1 \ldots \ldots \ldots \ldots$. | Add | $b$ | $c$ | $x=b+c$ <br> $y=a x$ |
| Instruction $2 \ldots \ldots \ldots \ldots$ | Multiply | $a$ | $x$ | $c$ |

The computer would first execute instruction 1 and then instruction 2.
The Memory. The computer itself is composed of two main parts, a memory, which stores numbers and instructions, and a computing unit, in which the actual computations take place (see Fig. 2-2). The com-
$\dagger$ Modern computers are being developed to perform several operations simultaneously.
puter's memory stores the numbers to be operated on; it stores intermediate results that are generated during the course of a computation; and it stores the final results. For instance, the numbers represented by $a, b$, and $c$ of our example are initially stored in the memory. After the first instruction is executed, the intermediate result $x$ is stored in the memory. After the second instruction is executed, the final result $y$ is stored in the memory.

The instructions themselves are also stored in the computer's memory. Each instruction is transmitted to the computing unit when it is to be


Fig. 2-2. Memory and computing unit.
executed. In our example, instruction 1 is first transmitted to the computing unit and executed, and then instruction 2 is transmitted to the computing unit and executed.

The reason for having an internal memory in the computer is that numbers and instructions can be transmitted between such a memory and the computing unit more rapidly than by other means. This enables the computations to proceed more quickly. High-speed computers exist such that a number or instruction in the memory can be transmitted to the computing unit in as short a time as $1 \mu \mathrm{sec}$. On the other hand, arithmetic operations such as addition can be performed in less than $1 \mu \mathrm{sec}$. Hence, it is generally the speed of the memory that limits the speed of a computer.


Fig. 2-3. Arithmetic unit and control.
The Computing Unit. It is seen from the above discussion that the computing unit has two functions: it must (1) obtain instructions from the memory and interpret them, as well as (2) perform the actual operations. Hence it is composed of two parts: the control, concerned with the former, and the arithmetic unit, concerned with the latter function (see Fig. 2-3).

An analogy can be made between the functioning of an electronic computer and the performance of hand computation. The computer's memory is analogous to the tabulation of numbers often kept during hand computations. The function of the computing unit is analogous
to the actual performance of the hand-computational operations. Carrying our analogy with hand computation a little further, the arithmetic unit is analogous to the pencil and paper, abacus, slide rule, etc., while the control is analogous to the mental processes that take place in determining what operation is to be performed, choosing the proper arguments of the operation, keeping the proper sequence of operations, etc.

The Control. The control itself must perform two functions. It must (1) interpret the instruction; then, based on this interpretation, it must (2) tell the arithmetic unit what to do. The latter function is accomplished through the use of electronic control signals.

In accordance with these two functions, we can separate the part of the control that interprets, or decodes, the instructions, called the instruction decoder, from the part that generates the control signals, called the control generator (see Fig. 2-4).


Fig. 2-4. Instruction decoder and control generator. (Solid-headed arrows indicate information; hollow-headed arrows indicate control signals.)

After an instruction has been transmitted to the instruction decoder, where it is interpreted, the control generator senses this interpretation and then produces signals that tell the arithmetic unit which operation to perform. It also generates signals that choose the proper numbers (arguments) from the memory and sends them to the arithmetic unit at the proper time; and when the operation has been performed, still other control signals take the result from the arithmetic unit back to the memory. After an instruction has been executed, the control generator produces signals that enable the next instruction to go from the memory to the instruction decoder. In this way the instructions are performed sequentially.

Input-Output. There are many means by which numbers and instructions can be initially introduced into and finally read out of the computer memory. They can be typed directly into the computer on specially adapted electric typewriters, read into the computer by means of punched paper tape on a teletypelike machine, punched on cards and read into the computer by means of a punched-card machine, memorized on magnetic tape and read into the computer by a specially built tape recorder, etc. When the computations have been completed, the resulting numbers can be read out of the computer by having the computer operate a typewriter, punch paper tape, punch cards, put pulses on magnetic recording tape, etc. Most computers have several such input units and output units. The in-out selector determines which unit will read information into or out of the computer; it is controlled by signals from the
control generator (see Fig. 2-5). Each of the boxes in Fig. 2-5 represents electronic or electromechanical equipment. It is the purpose of this book to describe the function, use, and design of this equipment.

Summary. The computer's memory stores the instructions and the initial, intermediate, and final numbers involved in a computation. Instructions tell the computer what computations to perform. An instruction includes information about the kind of operation to be performed and the arguments involved in the operation.


Fig. 2-5. Input-output.
The instructor decoder interprets an instruction. This interpretation is sensed by the control generator. Based on that information, the control generator produces control signals that transmit the proper numbers from the memory to the arithmetic unit and that tell the arithmetic unit what operations to perform on these numbers or arguments. When the results have been computed by the arithmetic unit, the control signals guide them back to the memory. Then the control signals bring the next instruction into the instruction decoder, and the cycle continues. When new data is to be read into the memory by means of the input units, the control generator directs the in-out selector to choose the proper input unit. The control generator takes similar action when computed data is to be read out of the memory by means of one of the output units.

## EXERCISES

(a) What are the general purpose and function of an operation? An instruction? The computer memory? The computing unit? The arithmetic unit? The control? The instruction decoder? The control generator? Control signals? Input units? Output units? The in-out selector?
(b) If 2 and 3 are added to obtain 5 , what are the arguments of this operation? The result?
(c) Write a sequence of instructions by means of which $a(b+c d) / f$ can be computed. Letting $a=6, b=4, c=2, d=3$, and $f=5$, perform the sequence of instructions.
(d) Write a sequence of instructions by means of which $\left(1-a^{2}\right)^{3}$ can be computed.
(e) What four functions do the control signals perform?

## 2-3. Functional Description of a Computer

The functional description of a computer involves consideration of further details about the computer's memory and the relation of an instruction to the memory. Two fundamental concepts of modern digital computers are involved in this relationship.

Words. The memory of a computer is composed of a large number of memory boxes, analogous to mailboxes. The information, or items to be memorized, is placed into these boxes as mail is placed into mailboxes. Each memory box, like a mailbox, has a name, or address. These addresses are usually numbers. For example, if the computer contains 100 memory boxes, their respective addresses might be the numbers from 1 to 100 (or 0 through 99). The information or items put into the memory boxes are called words and are analogous to the mail itself. However, only one word can be stored in a memory box at a time. As was seen in Sec. 2-2, there are two basic types of information, or words, that can be put into the boxes: words that are numerical quantities and words that are computer instructions.

At this point a short digression on computer terminology will prove helpful. The memory box of the previous paragraph is more correctly called an address, or alternatively a memory address, memory location, storage location, or cell. Instead of saying, "A word is in a memory box," computer personnel say, "The contents of an address is a word." Instructions are sometimes called commands; quantities are sometimes called data. $\dagger$

An instruction word looks like a number, and there is no way to tell from the word itself whether it is a quantity or an instruction. The computer must be told explicitly which addresses contain instructions and which contain quantities. Ordinarily a word is treated by the control as an instruction and by the arithmetic unit as a quantity. The fact that it is only the interpretation of a word that distinguishes instructions from quantities is the first fundamental concept of modern digital computers. This is fundamental because it enables the computer to operate on instructions. That is, the computer itself can formulate or change an instruction by treating it as though it were a quantity; and then, at a later time during the computations, this changed instruction can actually be executed. In a certain sense, this gives the computer the capability of actually writing instructions as well as executing them; i.e., the computer can "tell" itself what to do-which is the closest that a computer probably ever comes to "thinking." More will be said about this in a later chapter (see Chap. 5).

Instructions and Addresses. To see the relationship between an instruction and the computer's memory, consider, for example, an instruction that tells the computer to add two numbers. The instruction does
$\dagger$ See First Glossary of Programming Terminology, J. Assoc. Computing Machinery, June, 1954; I.R.E. Standards on Electronic Computers: Definitions of Terms, 1956, Proc. IRE, vol. 44, no. 9, September, 1956.
not directly tell the computer to add the numbers themselves but rather tells the computer to add the numbers that are found as the contents of addresses specified in the instruction. If the numbers to be added are located in address $\alpha$ and address $\beta$, the instruction literally says, "Add the contents of address $\alpha$ to the contents of address $\beta$." Of course, the proper numbers to be added must have been previously placed into the addresses $\alpha$ and $\beta$. The same instruction might go on to tell the computer to put their sum into address $\gamma$ and that the next instruction will be found as the contents of address $\delta$. Hence, after our add instruction has been executed, the number that is the sum will be found as the contents of address $\gamma$. It must be certain that the contents of address $\delta$ is actually an instruction and not a number because the contents of address $\delta$ will be interpreted as if it were an instruction in any case.

The fact that instructions deal directly with addresses whose contents are to be operated on, rather than with the numbers themselves, is the second fundamental concept of digital-computing machines. This gives the computer an advantage that is exactly analogous to the advantage of performing algebra on symbols $x, y, \ldots$.

As an example of an instruction, suppose that we wanted to add 125 and 412 and that we put 125 into address 32 and 412 into address 34. Suppose that we want the sum to appear in address 36 and that the next instruction is the contents of address 41. Then our add instruction, when decoded, would say, "Add the contents of address 32 to the contents of address 34 , and put the sum into address 36 ; then the next instruction will be found as the contents of address 41. ."

The Accumulator. Consider now what happens in the arithmetic unit while an instruction is being executed. In most computers only one word at a time can be transferred between the arithmetic unit and the memory. Hence, to perform an operation involving two arguments, the first argument must be transferred from the memory to the arithmetic unit and stored there temporarily while the second argument is being transferred. The special memory cell in the arithmetic unit for this purpose is called the accumulator (see Fig. 2-6). When the operation is performed, the result is formed in the accumulator before it is transmitted back to the memory.

Thus, in the above example, the contents of address 32 , namely, 125, would be brought into the accumulator first; then this would be added to the contents of address 34 , namely, 412 , and the result, namely, 537 , would be formed in the accumulator. Then 537 would be transmitted from the accumulator into address 36.

The Instruction Register and the Current-address Register. Next consider the instruction decoder that interprets an instruction. In order that the instruction decoder perform its function, it must constantly refer to the instruction being interpreted during the time control signals are being set up. To facilitate this, while an instruction is being executed it is stored in a special memory cell, called the instruction register, located in the instruction decoder (see Fig. 2-6).

There is another special memory cell located in the instruction decoder, called the current-address register (see Fig. 2-6). The contents of this register is (nearly) always the memory address from which the instruction being executed came. The reason for this is related to the fact that the address of the present instruction was given as part of the previous instruction.

For example, consider the add instruction described above. Suppose that this instruction were originally the contents of address 40 . Then, while it is being executed, the contents of the instruction register will


Fig. 2-6. Accumulator, instruction register, and current-address register.
be the add instruction itself, and the contents of the current-address register will be 40 . After the add operation has been executed (i.e., after the sum of 125 and 412 has been put into address 36) and just before the next instruction is read into the instruction register, the address of the next instruction, namely, 41, is recorded in the current-address register.

The Four Phases. The functioning of a computer during the execution of an instruction is often summarized in terms of four phases. Assuming that an instruction has already been transmitted into the instruction register, phase 1 involves the transmitting of the first argument from the memory into the accumulator. During this phase the instruction decoder determines the address of the first argument from the instruction, and the control generator produces control signals that transmit the contents of this memory address into the accumulator. During phase 2 the second argument is brought to the arithmetic unit and the operation is performed. Both these functions are included in the same phase because most often the operation is performed as the second argument enters the arithmetic unit. In this phase the instruction decoder determines from the instruction the address of the second argument and what operation is to be performed; the control generator generates signals that set up the
arithmetic unit to perform this operation and signals that transmit the contents of the address of the second argument into the arithmetic unit; the arithmetic unit performs the operation, generally leaving the result as the contents of the accumulator. During phase 3 the contents of the accumulator is transmitted into the memory address specified by the instruction. During phase 4 the address of the next instruction is ascertained, and the contents of the current-address register is changed to the new address; the contents of this new address is then transmitted into the instruction register as the next instruction. Then phase 1 for this instruction is initiated, and the process is repeated.

It should be observed that computers are often designed with phase 1 or 3 omitted. That is, in some computers the memory address of both arguments need not necessarily be specified in a single instruction, nor need the memory address into which the result is transmitted always be specified. In such computers multiple instructions would be equivalent in function to a single instruction as described above. This aspect of instructions is discussed in considerable detail in the next chapter, and we shall not press the point here, except to note that, although the principles described hold in general, the specific details vary with different computers.

Summary. There must be an instruction in the instruction register initially so that the whole process may begin, and there must be a way to stop the computer. These details will be considered in Chap. 4. The important points we wish to emphasize in this section are: (1) instructions and quantities are memorized by the computer as the contents of memory addresses; (2) they are indistinguishable from each other except by interpretation, and (3) instructions explicitly involve only addresses and tell the computer what to do with the contents of these addresses; (4) the functioning of a computer during the execution of an instruction can be summarized in terms of the four phases as described.

## EXERCISES

(a) Discuss the first two fundamental concepts of modern digital computers, using accepted computer terminology.
(b) Consider the example of Sec. 2-2. Suppose that the value of $a$ is found as the contents of address 50 , of $b$ as the contents of address 51 , and of $c$ as the contents of address 52 ; the value of the intermediate result $x$ is to be put into address 53 , and the final result $y$ is to be put into address 54. How would instructions 1 and 2 of that example be written if these instructions themselves were found as the contents of addresses 55 and 56 , respectively?
(c) Describe by naming specific addresses and special memory cells what happens during each of the four phases during the execution of the instruction given as an example in this section. What is the contents of the instruction register? What is the contents of the current-address register? What is the contents of the contents of the current-address register? (Hint: The contents of the current-address register is an address itself.)
(d) During phase 1 what is the relation between the contents of the instruction register and the contents of the current-address register?

## 2-4. Words and Pulses

Binary Numbers and Bits. Words are memorized in the computer as binary numbers. Hence it is necessary to divert our attention for a moment to a description of the binary notation for numbers. Numbers written in the binary system make use of only the symbols 0 and 1 , called bits, just as numbers in the decimal system use the symbols $0,1,2$, $3,4,5,6,7,8$, and 9 , called digits. We say, for example, that 1101 is a binary number composed of 4 bits, just as 8,675 is a decimal number composed of 4 digits. In the decimal system the number 8,675 really means $\left(8 \times 10^{3}\right)+\left(6 \times 10^{2}\right)+\left(7 \times 10^{1}\right)+\left(5 \times 10^{0}\right)$, where $10^{0}=1$; analogously, in the binary system the number 1101 really means ( $1 \times 2^{3}$ ) $+\left(1 \times 2^{2}\right)+\left(0 \times 2^{1}\right)+\left(1 \times 2^{0}\right)$, where $2^{0}=1$. Since $2^{3}=8,2^{2}=4$, $2^{1}=2$, and $2^{0}=1,1101$ is $(1 \times 8)+(1 \times 4)+(0 \times 2)+(1 \times 1)=13$ in decimal. A more general and thorough discussion of the binarynumber system appears in Chap. 3. Our purpose here is simply to show that binary numbers are made up of bits, 0 and 1 , and that a binary number is just another notation for our familiar decimal numbers.

Words as Pulse Trains. As can probably be foreseen by the reader at this point, the reason for using the binary numbers in digital computers is to enable the use of simplified electronic circuitry. For then only two signal voltage levels need be distinguished, the voltage level that is to represent 1 and the voltage level that is to represent 0 . A word is memorized by the computer as a series, or train, of 1 and 0 signal voltage levels, often called pulses, that represent the bits of the word. The number of bits in a single word is called the length of the word. All the words within a particular computer are of the same length; $\dagger$ hence, so are the contents of all addresses in the computer memory. When the proper signals are generated by the instruction decoder, the train of pulses that represents a word goes from the memory address to the arithmetic unit. In some computers this is accomplished in a serial manner in time; i.e., the pulses flow past a fixed point at some fixed rate, say, 1 pulse $/ \mu \mathrm{sec}$. The speed of a computer is usually denoted by this pulse rate, or equivalently by the pulse frequency, i.e., 1 megacycle for our illustration.

It is often important to be able to denote a particular bit in a word by means of its position in the word. For this purpose we number the positions from right to left. Then Pn represents the $n$th bit of a word. For example, consider the 30 -bit word in Fig. 2-7. Here $P 1=0$, $P 2=0, \ldots, P 6=1, P 7=0, P 8=1, \ldots, P 23=1, P 24=0$, etc.

Time Synchronization and Clock Pulses. In the arithmetic unit two word pulse trains are operated on by electronic circuits to form a new word pulse train that represents the result of the operation. In the control the word pulse train is decoded and interpreted as an instruction by other electronic circuits. The circuits that accomplish these func-
$\dagger$ Modern computers are being developed to use different word lengths in different sections of the machine.
tions are called gates, or digital switching circuits. We shall have a little more to say about such gates in Sec. 2-5, and much more in the rest of the book. However, for the purposes of this section it suffices to mention that everything that happens to a word during the four phases takes place in these switching circuits, or gates.

It has been implied in the above discussion that there is some kind of synchronization of the pulses in a computer. In most computers this is indeed the case: all pulses are synchronized with respect to each other by means of clock pulses generated by a clock within the computer. The clock is an oscillator, with a frequency that is usually some integral multiple of the speed of the computer. Every gate is so connected to

#  <br> $A_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{1} R_{4}$ <br> 101011011010011100011110100000 

Fig. 2-7. Example of a 30 -bit word.
the clock of the computer that pulses are allowed to enter or leave the gates only at those times at which a clock pulse is received. The effect is analogous to an orchestra where the conductor beats out the timing, like the clock-the individual musicians, the gates, play notes, the pulses, according to this rhythm as directed by their music sheets, the design of the gating connections. At each beat of the clock all the pulses advance in the computer according to the gating connections, just as the musicians go on to the next musical beat. The purpose of this is to keep the phases of the pulses coordinated, in a manner to be described in detail in a later chapter. In addition, the clock pulses usually play an important role in reshaping the pulses, which become somewhat attenuated and distorted in passing through the gating circuits.

Example of Adding. Let us consider what happens in the arithmetic unit when two numbers are added. To be specific, suppose that these numbers (where $A n$ and $B n$ label the bit positions) are

| 우ㅇㅜㅜ | $\begin{gathered} \stackrel{N}{N} \stackrel{2}{4} \\ \underset{4}{4} \end{gathered}$ |  |  |  |  |  | $\begin{aligned} & 0 \infty N \\ & \varangle \pi \nabla \end{aligned}$ | $\varangle \varangle$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 000 | 010 | 110 | 000 | 00 | 11 | 11 | 00 | 110 | 01 |
| Op్N | $\begin{aligned} & \text { Nolp } \\ & \end{aligned}$ | NNN్N N్M | HiNo | $\begin{aligned} & \infty \\ & \text { AN } \\ & \text { No } \end{aligned}$ |  | $\begin{aligned} & \text { NHO } \\ & \text { MM } \end{aligned}$ |  | 015 H $\triangle Q \perp A$ | $ص \perp \infty$ |
| 000 | 001 | 011 | 101 | 110 | 101 | 111 | 010 | 100 | 000 |

(The decimal equivalents are, for $A, 46,202,483$ and, for $B, 24,600,224$. See Chap. 3 for decimal-to-binary conversion methods.) Suppose that we are in phase 2; i.e., the first argument has already been transmitted into the accumulator. Suppose also that the pulse rate of the computer is $1 \mu \mathrm{sec}$; then the bits advanced once each microsecond. Figure 2-8 shows the situation at the start of phase 2; Fig. 2-9 shows the situation $1 \mu \mathrm{sec}$ later; Fig. 2-10 after $2 \mu \mathrm{sec}$; Fig. 2-11 after $10 \mu \mathrm{sec}$; Fig. 2-12 after


Fig．2－8．Start of phase 2.


Fig．2－9．One microsecond after start of phase 2.
Second argument from a memory address $\quad$ மんよ m
『せ『
$0000101100000011111110011100 \longrightarrow$ Adder

Fig．2－10．Two microseconds after start of phase 2.
Second argument from a memory address


Fig．2－11．Ten microseconds after start of phase 2.


Fig．2－12．Twenty microseconds after start of phase 2.


Fig. 2-13. Thirty microseconds after start of phase 2.
$20 \mu \mathrm{sec}$, and Fig. 2-13 after $30 \mu \mathrm{sec}$. As the two arguments advance bit by bit into the adder, the result is formed bit by bit; the partial results are stored in the accumulator behind the partially used first argument as shown. The double line separates the partial first argument from the partial result so far formed in the accumulator. (The partial result is to the left of the double line; the remaining first argument is to its right.) In Fig. 2-13 the complete result has been formed in the accumulator, namely:

(which in decimal is $70,802,707$ ). The computer is then ready to start on phase 3.
Figures 2-8 to 2-13 illustrate what would happen in a so-called "serial" computer. However, there are other, "parallel" methods for adding. Both serial and parallel adders are discussed in detail in later chapters. Our purpose here was merely to give a general idea of how word pulse trains travel through gates in a synchronous fashion during a computation.

Instruction Decoding. We have given an example of how numerical quantities are gated. Next let us illustrate the method by which an instruction word is written and decoded. Suppose that the words of a hypothetical computer are each 30 bits in length, as above. Let the leftmost six bits, $P 30, P 29, P 28, P 27, P 26, P 25$, represent the operation code, i.e., tell what the instruction is to do: add two numbers, or form the product of two numbers, etc. Suppose, for concreteness, that the binary number 101011 is the code for "add" (see Fig. 2-14). Let the next six bits, P24, . . , P19, represent the address of one of the numbers to be added; $P 18, \ldots, P 13$ the address of the other number; and $P 12, \ldots, P 7$ the address in which the sum is to be stored. The


Fig. 2-14. Example of an instruction word.
last six bits, $P 6, \ldots, ., P 1$, tell where the next instruction is located in the memory. When the instruction word goes into the instruction decoder, it is stored in the instruction register. This register has a circuit for each bit being stored, with an output wire so that, if a 1 is stored, the circuit puts out the 1 signal voltage level on the wire and the 0 signal voltage level for a zero. The outputs on these wires are sensed by gating circuits, and the instruction is thus decoded (see Fig. 2-15).


The control unit generates control pulses which are also binary in character, i.e., are composed only of the 0 and 1 voltage levels. In fact, almost all the circuitry in a digital computer is concerned with only these two voltage levels. This distinction can be made as to the function of pulses in the computer: some pulses represent words (numbers or instructions); other pulses represent control signals. Such a distinction was made in the block diagram of a computer, where solid-headed arrows represented the flow of word pulses and hollow arrows represented the flow of control-signal pulses.

## EXERCISES

(a) Define: length of word; pulses; speed of computer; gates; clock pulses.
(b) In the addition example given in this section what is the contents of the accumulator $15 \mu \mathrm{sec}$ after the start of phase 2? $25 \mu \mathrm{sec}$ after?

## 2-5. Logical Building Blocks

Almost the entire computer is composed of only three basic kinds of simple circuits, often called building blocks. Many of each kind of these circuits are connected to make the computer. The functioning of the computer depends only on how these basic circuits are wired together. Hence the electronic aspect of computers can be divided into two fields: (1) the design of these three very basic circuits; and (2) the design of the wiring connections between these basic circuits for proper functioning of the computer. The three kinds of basic circuits are called and gates, or gates, and not gates. Although the internal electronic design of these building blocks and the theory of how to design wiring connections between them comprise the latter parts of this book, it is felt that some background material on these subjects will aid the reader to visualize in a general way the over-all structure of computers.

The Three Building Blocks. An and gate is a circuit with two (or more) inputs and one output so that a 1 signal voltage level at the output will

|  | Circuit diagram | Voltage-level diagram |
| :---: | :---: | :---: |
| And gate |  |  |
|  | Only when current is flowing in both relay windings will the voltage level of the output rise | The four possible combinations of input-signal voltage levels are indicated with the resulting output voltage level |
| Or gate |  |  |
|  | Only when current is flowing in either or both of the relay windings will the voltage level of the output rise | The four possible combinations of input-signal voltage levels are indicated with the resulting output voltage level |
| Not gate |  |  |
|  | Only when current is not flowing in the relay windings will the voltage level of the output rise | The two possible input-signal voltage levels are indicated with the resulting output voltage level |

Fig. 2-16. The three building blocks as constructed using relays.
occur only when a 1 signal voltage level appears on all inputs. An or gate has two (or more) inputs and one output; it will have a 1 signal-voltage-level output only whenever a 1 signal voltage level appears on any one or more inputs. A not gate has one output and one input and will have a 1 signal-voltage-level output only whenever a 0 signal voltage level appears on its input. Such circuits can be designed using relays, electron tubes, diodes, magnetic cores, transistors, etc. Figure 2-16 illustrates the possible construction of such circuits using relays.

Flip-flops. There is one other type of circuit, called a fip-flop, commonly used in computers. A flip-flop is a circuit that temporarily stores a single bit. Its single output can be either a unit or zero voltage level, and this level will remain fixed until some change occurs at its inputs. Generally a flip-flop has two inputs: a pulse on one input will cause the output to rise to the unit signal level; a pulse on the other input will cause the output to fall to the zero signal level. Registers are often


Fig. 2-17. Relay flip-flop.
made of a number of these flip-flops, one flip-flop being used for each bit of the word (see Fig. 2-15). Flip-flops are ordinarily used for registers owing to their high speed of reaction as compared with other memory devices (see below). They are rarely used for the computer's memory because of their high cost and bulk. These points will be discussed in considerable detail in Part 5.
However, it may prove helpful here to illustrate how a flip-flop can be made from relays (see Fig. 2-17). When input $R$ is a unit voltage level and closes its relay, the output $Q$ becomes a unit voltage level. In this case the output relay $Q$ closes, and the unit-voltage-level output is continued independently of relay $R$ until relay $S$ is activated by a unit voltage level at input $S$. When relay $S$ is activated, the output $Q$ falls to the zero voltage level and relay $Q$ reopens; the zero voltage level is maintained until input $R$ is a unit voltage level. In the circuit shown the simultaneous occurrence of unit voltages on both $R$ and $S$ inputs will result in the $R$ input overriding the $S$ input.
Example of Gating Numerical Quantities. Now we shall show, in a quite preliminary way, how the three building-block circuits can be
connected so as to perform some function. Consider as an illustration the design of a circuit that might be found as part of the arithmetic unit of a computer. The circuit uses two numbers to make a third number, in a serial fashion. That is, the circuit has two inputs such that P1 of one number enters on one input wire at the same time as $P 1$ of the other enters on the other input wire. The output corresponding to these inputs is $P 1$ of the output number. Then, say $1 \mu$ sec later, $P 2$ of each number enters the input wires of the circuit, and $P 2$ of the output number is made, etc. In this way, the 30 bits of the output number are made serially as the corresponding bits of each of the input words pass into the circuit. In our example the output number is to be constructed according to the following rule: $P n$ of the output number is 1 if $P n$ of both the input numbers is the same, i.e., either both 1 or both 0 ; otherwise $P n$ of the output number is 0 . Thus the circuit is to behave as follows:
$\left.\begin{array}{l}\text { Input 1 } \\ \text { Input 1 }\end{array}\right\}$ output $\left.1 \quad \begin{array}{l}\text { Input 1 } \\ \text { Input 0 }\end{array}\right\}$ output 0

For example,
If one input number is $\quad \begin{array}{llllll}101110 & 011001 & 101101 & 011011 & 001100\end{array}$ and the other is then the output number is $\begin{array}{lllllll}001101 & 000111 & 101101 & 100100 & 011001\end{array}$

Such a circuit is called an "equalizer." Figure 2-18 indicates the connections that are necessary to make this circuit.


Fig. 2-18. Equalizer circuit.
In order to see that this circuit actually performs the task, examine the four diagrams of Fig. 2-19, one corresponding to each of the four input possibilities, where the signal voltage level is indicated at each connection.

Example of Gating Control Pulses. The above example illustrated gating of word pulses. We shall now illustrate gating of control pulses (see Fig. 2-20). Suppose that there were at least two circuits in the arithmetic unit, an equalizer and an adder. Then, according to Fig. 2-20, the two arguments to be operated on (i.e., the one coming from the mem-


Fig. 2-19. Analysis of equalizer circuit.
ory and the other already in the accumulator) will enter both the adder and the equalizer. But, because of the control signals, the result of only one of these circuits will be brought back to the accumulator. For example, if an instruction says that the numbers are to be added, then a 1 signal voltage level must be in the control wire going to the adder's output gate and a 0 signal voltage level must be in the control wire going to the equalizer's output gate. Then, as can be clearly seen, no signals from the equalizer's result will get through the equalizer's output gate, but the adder result will go through the adder's output gate.

Next let us illustrate how these control signals are generated. Suppose that

$$
101 \quad 011
$$

is the operation code for addition of the instruction. And suppose that


Fig. 2-20. Example of gating of control pulses.
is the operation code for "equalize." The signals for these positions of the instruction register (that is, $P 30-P 25$ ) are gated by means of an and gate that has more than two inputs. Such a gate will produce a 1 signal voltage level only when there is a 1 signal voltage level on all its inputs. From Fig. 2-21 it can be seen that the add control signal will occur only when 101011 is in $P 30-P 25$ of the instruction register; and the equalizer control signal will occur only when P30-P25 is 001010 . The wires marked $C P$ represent clock-pulse wires. We have included these in the diagram to illustrate how they enter every and gate. Thus we have illustrated the way in which signals can be generated to control which operation result will be allowed to go back to the accumulator.


Fig. 2-21. Generation of add and equalizer control signals.

## EXERCISES

(a) How can the flip-flop of Fig. 2-17 be constructed from and, or, and not gates?
(b) Draw the voltage-level diagram for the flip-flop of Fig. 2-17.
(c) Suppose that in Fig. 2-20 the number from the memory is

$$
\begin{array}{llllllllll}
000 & 010 & 110 & 000 & 001 & 111 & 111 & 001 & 110 & 010
\end{array}
$$

and that the contents of the accumulator at the start of phase 2 is

$$
\begin{array}{llllllllll}
000 & 001 & 011 & 101 & 110 & 101 & 111 & 010 & 100 & 000
\end{array}
$$

Then, if the adder result gate is open during phase 2 (and the equalizer gate closed), what will be the contents of the accumulator at the end of phase 2? (Hint: See Sec. 2-4.) What will it be if the equalizer result gate is open and the adder gate is closed?
(d) Why do we need a gate that is open only during phase 3, as shown in Fig. 2-20?
(e) Why do we need the clock pulses shown in Fig. 2-21?
( $f$ ) How is Fig. 2-21 related to Fig. 2-15? Draw the proper composite figure.
(g) Analyze the output of the given circuit by a method similar to that used in Fig. 2-19.

( $h$ ) If the following numbers are inputs to the circuit of Excrcise $g$, then what will be the output number?

| Input number | 101110 | 011001 | 101101 | 011011 | 001100 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Other input number | 011100 | 100001 | 111111 | 000000 | 101010 |

## 2-6. Input, Output, and Memory Systems

Input Information. As we have seen, there are many ways to get information into and obtain information from a digital computer. In order to give a more concrete picture of the process, we shall describe in some detail the procedures a person would follow in order to put information into a computer. The input information usually consists of a list of numbers and a list of instructions telling the computer what operations to perform on these numbers. For example, a problem might be to compute the trajectory of a missile (i.e., to construct a table giving the position of the missile at each second during its flight) given its initial velocity and angle of take-off. Suppose that the equation of the trajectory is

$$
x=\left(V_{0} \cos \theta\right) t \quad y=\left(V_{0} \sin \theta\right) t-1 / 2 g t^{2}
$$

where $x, y=$ coordinates of missile at any time
$V_{0}=$ initial velocity
$\theta=$ angle of take-off from horizontal
Among the list of numbers that must be entered into the computer are
the values of $V_{0}, \cos \theta, \sin \theta, g$, and the constant 1 (the time interval of $1 \mathrm{sec})$. A list of instructions must also be read into the computer telling it how to compute $x$ and $y$. All these numbers and instructions must be entered into the computer in binary form. The first problem under consideration in this section is just how this might be accomplished.

Punched Paper Tape as an Input Vehicle. Suppose that punched paper tape is to be used for this process. An electromechanical device exists so that a hole in the tape is interpreted by the computer as a 1 , no hole as a 0 . Consider a paper tape with positions for three holes per line. If there are 30 bits to a word, then 10 lines are needed per word. Figure 2-22 illustrates how the following word would look on a tape:

```
111
    111
```

One method for getting the proper holes in the paper tape is to use a paper-tape hand punch machine. This manual punch machine has keys: pushing a single key will


Fig. 2-22. Punched paper tape. punch one line. The keys might be numbered from 0 to 7 , and the array of holes corresponding to

| Key |  |
| :---: | :---: |
| (0) |  |
| (1) | 0 |
| (2) | $\bigcirc$ |
| (3) | 00 |
| (4) | $\bigcirc$ |
| (5) | $\bigcirc$ |
| (6) | 00 |
| (7) | 000 |
|  | now | each key might be as given in Fig. 2-23. Hence the word above would be punched by pushing the following keys in succession:

$$
7,5,3,6,1,7,2,6,3,1
$$

The person who prepares the list of numbers and instructions for a problem is called a programmer, or coder, and the list itself is called a coding sheet. The code is written as a list of computer words. However, the coder does not write the words in binary form but instead puts down, as a shorthand, the numbers of the keys that are to be punched. Hence the coding sheet, instead of the word above, would have
Fig. 2-23.
Punched-
paper-tape code.

The punch operator would push these keys in succession, and the paper tape would be punched in a binary mode. After the punching is complete, the paper tape is run through the computer paper-tape reader, which translates the holes into the units and zeros that are electronically stored in the computer's memory. The computer then calculates the results, and they are read out-
perhaps by having the computer punch a paper tape. This paper tape would then be put into a machine that does the reverse of punching, i.e., that looks at a paper tape and prints on paper the numbers that appear there, in a manner similar to a ticker-tape machine. Figure 2-24 is a photograph of a paper-tape punch machine and a computer paper-tape reader.


Fig. 2-24. Paper-tape punch and reader. (Photograph courtesy Bendix Computer Division of Bendix Aviation Corp.)

Other Input-Output Methods. Although in Part 5 of the book we devote most of Chap. 22 to input-output methods, mentioning some of these here will serve to orient the reader. Besides punched paper tape there are punched cards: the cards are punched in much the same manner as the paper tape, and the device that reads the cards into the computer likewise senses the holes and interprets these in terms of electronic pulses (see Fig. 2-25). A typewriter may be rigged with relays so that when a key is pushed a code is produced by the relays and transmitted directly into the computer. Such methods are often found too slow. A faster method for putting a program or code into a computer is by means of magnetic tape, like sound-recording tape (see Fig. 2-26): here a small magnetized area on the tape is interpreted by the computer as a unit, no magnetized area as a zero. However, before this magnetic tape is read into the computer, the program must be first "written" onto the tape. This may be accomplished on a machine not associated with the computer
itself, often called an "inscriber." There are many varieties of inscribers; some enable the code to be put on the magnetic tape directly from a typewriter, others from previously punched paper tape or cards. For example, one procedure may require that the code first be punched on paper tape and the paper tape "inscribed" onto magnetic tape, which is


Fig. 2-25. Punched-card reader. (Photograph courtesy National Cash Register Co.)
finally read into the computer. Table 2-1 gives some idea of the speeds in bits per second at which information can be transformed from one medium to another. Knowing the number of bits per word, one can then calculate the number of words per minute that can be so transformed.

There are also some unusual means for putting information into the computer. One is a reading machine that can translate digits and letters, as they appear on a printed page, into a binary code and write this code into the memory.

Most of the methods for taking information from the outside world into the computer's memory can be reversed to serve as methods for reading information out from the computer's memory to the outside world in a form that is readily understandable. Hence the computer can work a typewriter, punch paper tape, punch cards, or write onto


Fig. 2-26. (a) Magnetic-tape unit; (b) magnetic tape, showing location of bits. (Photographs courtesy Potter Instrument Company, Inc.)

Table 2-1. Order of Magnitude of Rates

| From | To |  |
| :---: | :---: | :---: |
| Paper tape. | Computer memory | 2,000 bits/sec |
| Punched cards. | Computer memory | 3,000 |
| Typewriter. | Computer memory | 40 |
| Magnetic tape. | Computer memory | 100,000 |
| Paper tape. | Magnetic tape | 2,000 |
| Punched cards. | Magnetic tape | 3,000 |
| Typewriter. | Magnetic tape | 40 |
| Computer memory. | Paper tape | 300 |
| Computer memory. | Punched cards | 2,000 |
| Computer memory. | Magnetic tape | 100,000 |
| Computer memory. | Typewriter | 600 characters/min |
| Paper tape. | Typewriter | 600 |
| Punched cards. | Printer | 10,000 |
| Magnetic tape. | High-speed printer | 100,000 |
| Computer memory. | High-speed printer | 100,000 |
| Computer memory. | Cathode-ray-tube printer | 500,000 |



Fig. 2-27. High-speed printer ( 600 lines per minute, 120 characters to the line). (Photograph courtesy Radio Corporation of America.)
magnetic tape. Of course the "outscriber" is required to transform the information from punched paper tape, punched cards, or magnetic tape into the letter and number characters we are more familiar with. In addition there are methods using so-called "high-speed" printers and specially made cathode-ray tubes (see Figs. 2-27 and 2-28) that, like the typewriter, display numbers and letters directly from the computer.


Fig. 2-28. High-speed printer using Charactron tube ( 4,680 lines per minute, 120 characters to the line). (Photograph courtesy Stromberg-Carlson Division of General Dynamics Corp.)

Other outputs from a computer may be obtained from attaching oscilloscope or television tubes to the computer's memory. Then the computer literally can draw maps, can indicate the movements of dots representing aircraft, etc., or can display other kinds of pictures.

Acoustic-delay-line Memory. Words read into the computer go into the computer's memory. The function of a computer memory is to store the pulses of each word in such a way that they may be called into the arithmetic unit rapidly, upon generation of the proper control signals. In addition, the computer memory must be able to accept rapidly the pulse train of a word for storage. The speed of modern computers is essentially limited by the speeds of access to their memories.

There are many ways for memorizing words within a computer, and
some of these will be considered in detail in Part 5 of this book. However, in order to gain a broader point of view at this time, it might be helpful to describe briefly one of these memory methods. Consider as an example the acoustic mercury delay-line memory. This memory consists of a set of glass tubes, each about 2 ft long and $3 / 4 \mathrm{in}$. in diameter (see Fig. 2-29). Each tube is filled with mercury and has a quartz


Fig. 2-29. Acoustic mercury delay-line memory. (Photograph courtesy National Bureau of Standards.)


Fig. 2-30. Read and write control signals.
crystal at each end. Electrical pulses make the crystal at one end vibrate; the disturbances propagate down the tube in the mercury and vibrate the other crystal; these latter vibrations are changed by the crystal into electrical impulses, which are then sent to an amplifier. The amplifier reshapes the pulses and sends them to the other crystal, etc. Thus the pulses of a word travel serially, i.e., consecutively, down the mercury, through the amplifier, and around. The proper control signals will allow the word pulse train to go to the arithmetic unit or
come from the arithmetic unit into the circuit. Of course the timing of these processes is critical, because when it is desired to read a word out of the memory, the gating must operate precisely as $P 1$ of that exact word is picked up by the second crystal. To maintain the proper speed of propagation in the mercury, the temperature of the line must be held within a narrow band.


Fig. 2-31. Magnetic drum. (Photograph courtesy Royal McBee Corporation.)
An important point that is true for practically all kinds of memories is that when a word is read out of a memory the word is still stored in the memory (unless otherwise specifically stated by the instruction-see Chap. 4). Thus in Fig. 2-30 the read-out control signal opens the gate to the arithmetic unit but does not prevent the recirculation of the word through the memory. On the other hand, when a word is written into the memory from the arithmetic unit, the previous word of that address is automatically erased and replaced by the new word. In Fig. 2-30 the write-into control signal opens the gate from the arithmetic unit at the same time it closes the recirculation gate.

Other Memory Systems. There are several other memory systems that will be described in Chap. 22 of Part 5. However, we shall mention
some of these here for orientation. Magnetic tape, described above as an input-output system, can as well be used for a computer memory. A similar magnetic-pulse technique is incorporated into magnetic drums, which are simply rapidly rotating cylinders with magnetizable surfaces (see Fig. 2-31). Faster memories are constructed from magnetic cores, specially prepared from ferrites having a square hysteresis loop, thereby presenting two stable states. Each core then represents one bit of a word (see Fig. 2-32). An even faster memory has been constructed,


Fig. 2-32. Magnetic cores. (Photograph courtesy International Business Machines Corp.)
using diodes and capacitors. As mentioned above, a memory with the fastest reaction time is one constructed using flip-flops to record bits. The time required to transmit one computer word out of the memory to where it will be used is called the memory access time (see Table 2-2).

In an acoustic-delay-line memory the stored bits come out serially. If more than one word is stored in a single line, the computer must wait

Table 2-2. Order of Magnitude of Memory Access Time
Memory system Time required to transmit a 30-bit word

| Magnetic tape | $5 \mathrm{msec}+$ time necessary to position tape |
| :---: | :---: |
| Magnetic drum. | 10 msec |
| Acoustic delay li | $100 \mu \mathrm{sec}$ |
| Magnetic core. | $5 \mu \mathrm{sec}$ |
| Diode capacitor. | $1 \mu \mathrm{sec}$ |
| Flip-flop register | $1 \mu \mathrm{sec}$ |

for the proper word to pass the read-out gate. In the magnetic-tape memory the whole tape must be searched, and a great deal of time is lost just winding and rewinding tape. For the drum the computer must wait for the word to rotate to the proper read-out position. The magnetic-core arrangement enables any word to be read out with no delays except those inherent in the circuitry involved. A word is read from a core memory in parallel; i.e., all the bits are transmitted to the arithmetic unit at the same time. A similar situation occurs with diodecapacitor memory or with a memory composed of a set of flip-flop registers.

Unfortunately, the faster the memory, the more it costs per bit. Hence a computer usually has several kinds of memory. Most commonly, magnetic tapes and drums are used for the so-called "low-speed" memory of a computer, while a magnetic-core memory or diode-capacitor memory is used as the "high-speed" memory. Often there is also included in the larger computers a battery of flip-flop registers for the really high-speed work. In this way, various parts of a large program can be stored in the relatively low-speed memory system of a computer and then transmitted to the high-speed memory when the actual computations of this part of the program are to occur. We shall have more to say about this later (Chaps. 5, 7, and 8).

## EXERCISES

(a) What keys of a paper-tape puncher would be pushed to punch the number

$$
\begin{array}{llllllllll}
101 & 110 & 011 & 001 & 101 & 101 & 011 & 011 & 001 & 100
\end{array}
$$

(Use the table of Fig. 2-23.)
(b) Draw a picture of paper tape with the number in Exercise a punched on it.
(c) What number does the given hole pattern represent?


Exercise $c$
(d) During what phases might the write-into signal, shown in Fig. 2-30, be "on," i.e., have a unit signal voltage level? During what phases must this signal be "off," i.e., have a zero signal voltage?
(e) During what phases might the read-out signal shown in Fig. 2-30 be on? During what phases must this signal be off?

## 2-7. Digital-computer and -control Engineering

In this chapter the attempt was made to give a broad picture of how a digital computer works. The three disciplines that comprise digitalcomputer and -control engineering were introduced. These were (1) coding and programming, or the study of writing sequences of instructions that direct the computer to perform particular tasks; (2) logical design of computer circuitry, or the study of designing proper connections
between the three building-block gates so that the resultant circuit will perform specified functions; and (3) electronic design of computer circuitry, or the study of specific electronic-circuit representations of the buildingblock gates as well as the electronic design of the input and output equipment associated with a computer. It has been seen how the methods and techniques by which a computer is programmed are intimately associated with the logical design of the computer, which in turn must satisfy the requirements set by the electronic design of the computer gate circuits. Hence, in dealing with almost any aspect of computers, the engineer must have a thorough grasp of all three of these disciplines.

In designing a digital computer, perhaps the engineer's first consideration is choosing the proper coding and programming system which best suits the purpose and function for which the computer is to be used. Although the basic concepts of programming are invariant, the computer engineer can choose from a wide range of possibilities of programming systems. This choice is extremely important, for it forms the basis of the entire structure of a computer design. The rest of the chapters in Part 1 of this book are concerned with this phase of computer engineering. Part 2 is concerned with the operation and use of computers pertaining to various problems-numerical analysis, searching and sorting, etc.

If we assume that the electronic design of the basic building-block gating circuits has been chosen, the fundamental problem of computer engineering becomes that of the logical design of the computer. Part 3 of the book lays the mathematical foundations for such design techniques, and Part 4 applies these to the logical design of common computer components. This aspect of computer engineering will perhaps appear most unusual to electrical engineers. The laborious analysis carried out in Sec. 2-5 is replaced by systematic computational methods based on a rather different kind of algebra-called Boolean algebra.

Part 5 of the book considers the electronic design of the basic buildingblock gating circuits, using various hardware components such as diodes, transistors, ferrite cores, etc. The usefulness of a computer depends to a large extent on the speed, reliability, stability, and other such characteristics of the circuits from which it is made. Hence the careful design, analysis, and testing of these circuits and their components comprise a large part of computer engineering.

## 2-8. Additional Topics

a. Analogy with Desk Calculator. Make a detailed analog between a digital electronic computer and a desk calculator, paying attention to function, structure, sequence of steps in their operation, etc. That is, what are analogous to accumulator, memory, instruction register, control unit, arithmetic unit, etc.?
b. Constructing a Cardiac Computer. A Cardiac computer is made by assigning each person of the class as one of the units or parts of a computer. Each person so assigned becomes responsible for performing all the functions of this assigned part of the computer, but no other functions. Then a program or sequence of instructions is written, and these instructions are executed by means of this human simulation of a
computer. Words and control signals are transmitted by passing around cards or pieces of paper.
c. Memories. For each of five commercially available high-speed digital electronic computers list the kinds of memories they include and their memory access times, and the kinds of input-output equipment they have and the speeds of these units. For example, get commercial advertising from the manufacturer, and consult Martin H. Weik, A Second Survey of Domestic Electronic Digital Computing Systems, BRL Rept. 1010, June, 1957.
d. Background. There are several subjects the student may find interesting as background material to his study of digital-computer engineering. These are cybernetics, information theory, certain aspects of neurophysiology, and the so-called "theory of automata." Readings relating to these subjects can be found in:
Ashby, W. Ross: "Design for a Brain," John Wiley \& Sons, Inc., New York, 1952.
Brillouin, L.: "Science and Information Theory," Academic Press, Inc., New York, 1956.

De Latil, Pierre: "Thinking Machines," Houghton Mifflin Company, Boston, 1957.
McCulloch, W. S., H. Quaster, G. A. Miller, and L. S. Fogel: Human Beings as Computers, a collection of four papers, IRE Trans. on Electronic Computers, vol. EC-6, no. 3, pp. 190-202, September, 1957.
Newman, James R. (ed.): "The World of Mathematics," vol. 4, pp. 2070-2133, Simon and Schuster, Inc., New York, 1956.
Shannon, C. E., and J. McCarthy (eds.): "Automata Studies," Princeton University Press, Princeton, N.J., 1956.
Wiener, Norbert: "Cybernetics," John Wiley \& Sons, Inc., New York, 1948. (Omit chaps. II-IV.)

The student may find it profitable to keep the following questions in mind during the course of his readings: What is the definition of information? Of what importance is information theory to the study of computers? What is the relation between the functioning of a neuron and those of the three building-block gates? In what way is a digital computer like the human brain? In what way does the human brain differ from a digital computer? Compare and contrast the computer's memory and that of the human brain. Can a digital computer think?
e. Terminology. Discuss the problems involved in standardizing computer terminology; i.e., compare definitions and usages of words as found, for example, in First Glossary of Programming Terminology, J. Assoc. Computing Machinery, June, 1954, and The Institute of Radio Engineers Standards on Electronic Computers: Definitions of Terms, 1956, Proc. IRE, vol. 44, no. 9, September, 1956.
f. History. Discuss the history of digital computers, identifying each advance in computer engineering with particular computers; include Babbage's computer, the ENIAC, EDVAC, SEAC, DYSEAC, UNIVAC, Whirlwind, IAS computer, Remington Rand 1103, IBM 704, and NORC, and the modern supercomputers such as LARC and Stretch [see B. V. Bowden (ed.), Faster than Thought, Pitman Publishing Corporation, New York, 1953, and other references in J. Assoc. Computing Machinery and IRE Trans. on Electronic Computers]. Figure 2-33 represents an evolutionary tree of digital computers that may be of aid in the discussion. We cannot claim that this tree is complete, but we hope that the major trends are reflected. Figure $2-34$ is a montage of present-day computers. These photographs have been included to give the student an idea of the variety of modern computers.


Fig. 2-33. The evolutionary tree of computer development.


FIg. 2-34. Present-day computers. (A) FLAC computer for biomedical research; (B) Honeywell 800; (C) Datamatic 1000; (D) UNIVAC solid-state computer; ( $E$ ) UNIVAC 1105; $(F)$ RCA 501; $(G)$ air-borne computer; ( $H$ ) RVS-Mark I (an automatic order-filling system). [Courtesy (B,C) Minneapolis-Honeywell; ( $D, E$ ) Remington Rand; (F) Radio Corp. of America; (G) Librascope, Inc.; (H) Industrial Electronics Engineers, Inc.]


Fig. 2-34. Present-day computers (continued). ( $I$ ) IBM 709; ( $J$ ) IBM 705; (K) IBM 650; (L) Perseus G/7578/1; ( $M$ ) Burroughs 205; ( $N$ ) NCR 304; ( $O$ ) TRANSAC-S-2000; (P) Bendix G-15. [Courtesy (I, J, K) International Business Machines Corp.; (L) Ferranti, Ltd.; (M) Burroughs Corp.; (N) National Cash Register; (O) Philco Corp.; (P) Bendix Computer Division.]

CHAPTER 3

## CODING AND PROGRAMMING A DIGITAL COMPUTER

## 3-1. Introduction

Recapitulation. The previous chapter has given the basic foundations necessary for a detailed discussion of how to direct a computer to perform desired computations. A code was defined as a list of instructions and numbers, the instructions being the specific means by which a person tells the computer what to do. The fundamental concept that instructions are written in terms of addresses, the contents of which are the numbers to be operated upon, was emphasized. We described the procedure by which the instructions are called into the instruction register, one instruction at a time and in sequence; and we indicated how the operations are performed by the computer. The use of the binary number system inside the computer and of some kind of shorthand for coding purposes was discussed briefly. We described the processes involved in transforming numbers written on paper into binary pulses inside the computer's memory. And it was noted that a similar process is involved in the reverse transformation from pulses in the computer's memory to typed numbers on a working paper outside the computer.

Importance of Coding to the Engineer. It is important for the digitalcomputer engineer to be well versed in coding and programming because, first, such knowledge is essential for a clear understanding of the principles of digital computers; second, occasions often arise when the computer engineer will have to run a problem of his own associated with his engineering duties; third, such knowledge is essential in maintaining an existing computer or checking out a new computer; and, finally, the engineer must be capable of evaluating various designs with respect to the final use and application of the computer.

Material Directed to Engineering Needs. The present chapter is the first of three chapters devoted exclusively to programming and coding. This chapter is concerned mainly with an introduction to coding and instruction formats. The next chapter (Chap. 4) is concerned with subroutines and the basis of instruction definitions. The final chapter of this group (Chap. 5) considers the principles of automatic programming. These chapters are directed to the digital-computer engineer and the problems he will face in his work. The engineer must grasp the fundamental ideas involved, and his training cannot be restricted to a single type of computer instruction format. He must understand the principles
behind the definitions of many kinds of instructions, so that he may design new ones and evaluate proposed ones. He must also understand the basis for automatic programming so that he may use or write such programs intelligently in solving engineering problems or in performing computer maintenance. Programming and coding are therefore a fundamental aspect of computer engineering.

Manner of Presentation. In successive sections of this chapter we consider instructions that include explicitly first four addresses, then only three, then two, and finally only one address. We begin with the four-address system because this format includes all the necessary ingredients of an instruction. Then, by omitting one address in the instruction format, we arrive quite naturally at a three-address system, and so forth. As each address is omitted from the instruction format, it must be compensated for by corresponding additional computer circuitry or by using several instructions where one sufficed before. In this way the advantages and disadvantages of various basic instruction formats are clearly observed.

Examples will show that, the smaller the number of addresses per instruction, the greater the ingenuity and work required of the coder, the larger the list of instructions that must be available to the coder, and the longer the equivalent codes. On the other hand, as the number of addresses per instruction is increased, the number of possible addressable memory locations is decreased and the words are made longer. In designing a computer system all these factors must be carefully evaluated with respect to the intended use of the computer, the amount of hardware required, the speed of the computer, the cost of the computer and of programming and coding, etc.

In the current chapter only very basic instruction lists are used in order that the material be as simple as possible at first. Only sequences of instructions and decisions are illustrated. This leaves the student free to concentrate on the fundamental properties and uses of the instruction formats. Consideration of those most important and fundamental programming techniques of loops (i.e., recursions, iterations) and subroutines is left to Chap. 4. In that chapter also, a large number of more complicated and specialized instruction or operation types are considered in detail. We believe that the student will more easily understand the principles of programming if consideration of these somewhat sophisticated ideas is postponed. Any discussion of coding and programming must be preceded by a study of number systems, as will be found in the next sections of this chapter.

Stages in Coding. As will be seen, there are five stages in coding. First the computations to be performed must be clearly and precisely defined. The over-all plan of the computations is diagramed by means of a so-called "flow chart." The second stage is the actual coding. It is often best to write a code in terms of a symbolic language first, for then changes are easily made. Numbers are assigned to the symbols, and the final code is prepared. In the third stage some procedure is
used to get the code into the memory of the computer. The fourth stage consists in "debugging" the code, i.e., detecting and correcting any errors. The fifth and final stage involves the running of the code on the computer and tabulating the results. In this chapter and the next only the first two stages are considered. Techniques for the fourth stage are described in Chap. 5.

Philosophy of Coding. As will become abundantly clear in the following sections, a single error in one instruction invalidates the entire code. Hence coding is an exacting technique, requiring attention to details without losing sight of the over-all plan. Learning to code must be developed from within a person. Following through each instruction of the examples given in this chapter is important, but it is not sufficient. The student must code problems by himself if he is to become aware of all the detailed thinking and reasoning associated with the coding technique. The method of teaching in this text is through example. The student should try to do the examples himself, using the text only as a guide to the methods involved.

## 3-2. Number Systems : Conversion

Number Systems and the Radix. Preliminary to any discussion of coding should come an analysis of various number systems. In Sec. 2-4 we noted that 8,675 really means $8 \times 10^{3}+6 \times 10^{2}+7 \times 10^{1}+5 \times$ $10^{\circ}$, where $10^{\circ}=1$. Since decimal numbers are expanded as illustrated in powers of ten, we say that the decimal number system has a radix of ten. This concept can be generalized to define number systems based on any positive-integer radix $q$ : if a number $N$ is based on radix $q$, then it can be expanded as

$$
N=a_{n} q^{n}+a_{n-1} q^{n-1}+\cdots+a_{2} q^{2}+a_{1} q^{1}+a_{0} q^{0}
$$

for integer $N \geq 1$, or

$$
N=a_{-1} q^{-1}+\dot{a}_{-2} q^{-2}+a_{-3} q^{-3}+\cdots+a_{-m} q^{-m}
$$

for $0<N<1$, where $a_{0}, a_{1}, \ldots, a_{-1}, a_{-2}, \ldots$ are nonnegative integers each less than $q$. Of course, for noninteger $N>1$, the expansion contains both the positive and negative powers,
$N=a_{n} q^{n}+\cdots+a_{2} q^{2}+a_{1} q^{1}+a_{0} q^{0}$

$$
+a_{-1} q^{-1}+a_{-2} q^{-2}+\cdots+a_{-m} q^{-m}
$$

For example,

$$
\begin{aligned}
8,675.8675= & \left(8 \times 10^{3}\right)+\left(6 \times 10^{2}\right)+\left(7 \times 10^{1}\right)+\left(5 \times 10^{0}\right) \\
& +\left(8 \times 10^{-1}\right)+\left(6 \times 10^{-2}\right)+\left(7 \times 10^{-3}\right)+\left(5 \times 10^{-4}\right)
\end{aligned}
$$

that is, $a_{3}=8, a_{2}=6, a_{1}=7, a_{0}=5, a_{-1}=8, a_{-2}=6, a_{-3}=7$, and $a_{-4}=5$. Even though we are most familiar with the system for $q=$ ten, history records ancient civilizations that used $q=\operatorname{six}, q=$ twelve, and
even $q=$ sixty! For our purposes we are most interested in $q=2$ (binary system), $q=8$ (octal system), and $q=16$ (sexadecimal $\dagger$ system).

First note that for radix $q$ the number system must involve $q$ symbols. For example, for $q=$ ten, the ten symbols are $0,1,2,3,4,5,6,7,8$, and 9 ; for $q=2$, the 2 symbols are 0 and 1 ; for $q=16$, the 16 symbols most often used are $0,1,2,3,4,5,6,7,8,9, A, B, C, D, E$, and $F$. Then, if $N=a_{n} q^{n}+a_{n-1} q^{n-1}+\cdots+a_{2} q^{2}+a_{1} q^{1}+a_{0} q^{0}$, where the $a_{i}$ are of course chosen from the $q$ symbols, the number is conventionally written by juxtaposition of the coefficients $a_{i}$ as follows: $N=a_{n} a_{n-1} \cdots a_{2} a_{1} a_{0}$. If $N=a_{-1} q^{-1}+\cdots+a_{-m} q^{-m}$, then the number is usually written by juxtaposition of the $a_{i}$ preceded by [.]-that is, $a_{-1} a_{-2} \cdots a_{-m}$. For noninteger $N>1$ we would have $a_{n} \cdot: a_{0 .} a_{-1} \cdot \cdots a_{-m}$. With this in mind, counting in the four different systems mentioned above is accomplished as in Table 3-1.

Conversion from One Number System to Another. Using number systems based on different radices is like talking in different languages. Just as one can translate one language into another, so also one can "convert" from one radix to another. For example, in Table 3-1 numbers on the same row are equivalent-that is,

$$
28(\text { decimal })=11100(\text { binary })=34(\text { octal })=1 C(\text { sexadecimal })
$$

The binary, octal, and sexadecimal equivalents of the decimal numbers from 0 to 15 should be memorized.

In order to derive a systematic method for converting from one number system to another, we make use of the well-known result that if $N$ and $q$ are positive integers then there always exists a unique (nonnegative) integer $r$ less than $q$ and a unique integer $S$ such that

$$
\frac{N}{q}=S+\frac{r}{q} \quad 0<r<q
$$

Let us apply this to convert an integer number with radix $p$, say $N_{p}$, to its equivalent with radix $q$, say $N_{q}$. In other words, we wish to determine the nonnegative integers $a_{0}, a_{1}, \ldots, a_{n}$, each less than $q$, such that

$$
N_{p}=a_{n} q^{n}+\cdots+a_{2} q^{2}+a_{1} q^{1}+a_{0} q^{0}
$$

Observe that

$$
\begin{aligned}
\frac{N_{p}}{q} & =a_{n} q^{n-1}+\cdots+a_{2} q^{1}+a_{1} q^{0}+\frac{a_{0}}{q} \\
& \text { Integer } \\
& =\quad S_{0}
\end{aligned}
$$

Since the quotient and remainder are each unique, equating the fractional

[^0]Table 3-1. Conversion Table

| Decimal $(q=10)$ | Binary $(q=2)$ | Octal $(q=8)$ | Sexadecimal $(q=16)$ |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| 2 | 10 | 2 | 2 |
| 3 | 11 | 3 | 3 |
| 4 | 100 | 4 | 4 |
| 5 | 101 | 5 | 5 |
| 6 | 110 | 6 | 6 |
| 7 | 111 | 7 | 7 |
| 8 | 1000 | 10 | 8 |
| 9 | 1001 | 11 | 9 |
| 10 | 1010 | 12 | A |
| 11 | 1011 | 13 | $B$ |
| 12 | 1100 | 14 | $C$ |
| 13 | 1101 | 15 | D |
| 14 | 1110 | 16 | E |
| 15 | 1111 | 17 | $F$ |
| 16 | 10000 | 20 | 10 |
| 17 | 10001 | 21 | 11 |
| 18 | 10010 | 22 | 12 |
| 19 | 10011 | 23 | 13 |
| 20 | 10100 | 24 | 14 |
| 21 | 10101 | 25 | 15 |
| 22 | 10110 | 26 | 16 |
| 23 | 10111 | 27 | 17 |
| 24 | 11000 | 30 | 18 |
| 25 | 11001 | 31 | 19 |
| 26 | 11010 | 32 | 1 A |
| 27 | 11011 | 33 | $1 B$ |
| 28 | 11100 | 34 | $1 C$ |
| 29 | 11101 | 35 | $1 D$ |
| 30 | 11110 | 36 | $1 E$ |
| 31 | 11111 | 37 | $1 F$ |
| 32 | 100000 | 40 | 20 |
| 33 | 100001 | 41 | 21 |
| 34 | 100010 | 42 | 22 |
| 35 | 100011 | 43 | 23 |
| 36 | 100100 | 44 | 24 |
| -•• | . . . . . | $\cdots$ | $\cdots$ |

Sec. 3-2] coding and programming a digital computer
parts we have $a_{0}=r_{0}$ and $S_{0}=a_{n} q^{n-1}+\cdots+a_{2} q^{1}+a_{1} q^{0}$. Dividing $S_{0}$ by $q$ and using our above results, we obtain

$$
\frac{S_{0}}{q}=a_{n} q^{n-2}+\cdots+a_{2} q^{0}+\frac{a_{1}}{q}=S_{1}+\frac{r_{1}}{q}
$$

whence $a_{1}=r_{1}$, and so forth.
Hence the systematic conversion method is as follows: Divide $N_{p}$ by $q$; the remainder is $a_{0}$. Divide the resulting quotient by $q$; the remainder is $a_{1}$. Divide the resulting quotient by $q$; the remainder is $a_{2}$; etc. As an example, we have converted 28 (decimal) into binary ( $q=2$ ) in Table 3-2. Hence,

$$
28(\text { decimal })=11100(\text { binary })
$$

Table 3-2. Decimal to Binary Conversion ( $N_{p} \geq 1$ )
Remainders
$2 \underline{28}$

| $2 \mid \underline{14}$ | $0=a_{0}$ |
| :--- | :--- |
| $2 \left\lvert\, \frac{7}{3}\right.$ | $0=a_{1}$ |
| $2 \left\lvert\, \frac{3}{2}\right.$ | $1=a_{2}$ |
| $2 \left\lvert\, \frac{1}{0}\right.$ | $1=a_{3}$ |
| 0 | $1=a_{4}$ |

The work can be more conveniently arranged from right to left, as follows:


As another example, let us convert 28 (decimal) to octal ( $q=8$ ),

whence the converted octal number is 34 .
To convert 28 (decimal) to sexadecimal ( $q=16$ ),

$$
\begin{aligned}
& 0 \leftarrow 1 \leftarrow 28!16 \\
& 1 \quad C
\end{aligned}
$$

Hence the converted sexadecimal number is $1 C$. [Here, of course, $28-16=12($ decimal $)=C$ (sexadecimal) from Table 3-1.]

Next consider $0<N_{p}<1$. We wish to find nonnegative integer
coefficients $a_{-1}, a_{-2}, \ldots, a_{-m}$, each less than $q$, such that

Here

$$
\begin{aligned}
N_{p} & =a_{-1} q^{-1}+a_{-2} q^{-2}+\cdots+a_{-m} q^{-m} \\
q N_{p} & =a_{-1}+a_{-2} q^{-1}+\cdots+a_{-m} q^{-m+1} \\
& =u_{-1}+v_{-1}
\end{aligned}
$$

where $u_{-1}$ is the integral part and $v_{-1}$ is the fractional part of $q N_{p}$; hence
and $\quad v_{-1}=a_{-2} q^{-1}+\cdots+a_{-m} q^{-m+1}$
Again $\quad q v_{-1}=a_{-2}+a_{-3} q^{-1}+\cdots+a_{-m} q^{-m+2}=u_{-2}+v_{-2}$
whence $\quad u_{-2}=a_{-2}$, etc.
The conversion method thus is as follows: Multiply $N_{p}$ by $q$; the integral part is $a_{-1}$. Multiply the resulting fractional part by $q$; the integral part is $a_{-2}$; etc.

As an example, we have converted 0.28 (decimal) to binary ( $q=2$ ) in Table 3-3. Hence 0.28 (decimal) $=.01000111 \cdot \cdots$ (binary). The

Table 3-3. Decimal to Binary Conversion ( $0<N_{p}<1$ )
Integral parts

|  | 0.28 |
| :---: | :---: |
|  | $\times \quad 2$ |
| $a_{-1}=0$ | . 56 |
|  | $\times \quad 2$ |
| $a_{-2}=1$ | . 12 |
|  | $\times \quad 2$ |
| $a_{-3}=0$ | 24 |
|  | $\times \quad 2$ |
| $a_{-4}=0$ | . 48 |
|  | $\times \quad 2$ |
| $a_{-5}=0$ | . 96 |
|  | $\times \quad 2$ |
| $a_{-6}=1$ | . 92 |
|  | $\times \quad 2$ |
| $a_{-7}=1$ | . 84 |
|  | $\times \quad 2$ |
| $a_{-8}=1$ | . 68 |

work can be more conveniently arranged from left to right, as follows:


Note that the process does not necessarily end, as it must for the integral numbers, but may be carried out to any number of significant figures. Conversion to the octal and sexadecimal systems is similarly accomplished.

For nonintegral numbers greater than unity the integral part and the fractional part are done separately as just described.

Note that in converting from binary to octal (or sexadecimal) we divide, or multiply, the binary number by binary 100 (or 1000), which is equivalent to shifting the fraction point to the left, or to the right, by three (four) binary places. Hence for binary to octal conversion we start at the point and count off the binary bits in groups of three, to the left and to the right. Then we write the octal equivalent for each of these groups of three bits. For example, if the binary number is 11100.110100011, the octal equivalent is

$$
\begin{array}{cccc}
3 & 4.6 & 4 & 3 \\
011 & 100.110 & 100 & 011
\end{array}
$$

To convert to sexadecimal, we count off similarly by groups of four. For the same binary number the sexadecimal number is

$$
\begin{array}{ccccc}
1 & C & D & 1 & \cdots \\
0001 & 1100.1101 & 0001 & \cdots & \cdot
\end{array}
$$

(See Table 3-1 for binary-octal and binary-sexadecimal equivalents.) The converse will of course hold.

Converting from Binary to Decimal. Another conversion method, particularly useful for converting from binary to decimal, is based on the following factorization, illustrated for $n=4$ :

$$
\begin{aligned}
N & =a_{4} q^{4}+a_{3} q^{3}+a_{2} q^{2}+a_{1} q^{1}+a_{0} q^{0} \\
& =\left(\left(\left(a_{4} q+a_{3}\right) q+a_{2}\right) q+a_{1}\right) q+a_{0}
\end{aligned}
$$

If $N$ is a binary integer, then $q=2$ and the $a$ 's are either 0 or 1 , but $a_{4}$, the most significant coefficient, must be 1 . Hence, to convert $N$ to decimal, start out with 1 , and double it, obtaining 2 ; then add $a_{3}$, and double the result; add $a_{2}$, and double the result; add $a_{1}$, and double the result; finally add $a_{0}$. For example,

$$
\begin{array}{cccccl}
a_{4} & a_{3} & a_{2} & a_{1} & a_{0} & \\
1 & 0 & 1 & 1 & 1 & =(((2+0) 2+1) 2+1) 2+1 \\
& & & & ((4+1) 2+1) 2+1 \\
& & & (10+1) 2+1 \\
& & & & & \\
& & & &
\end{array}
$$

The method is to accumulate the result while calculating, and the work
from left to right might look like this:


Similarly for $N$ such that

$$
N=a_{-1} q^{-1}+a_{-2} q^{-2}+a_{-3} q^{-3}+a_{-4} q^{-4}
$$

we have the factorization

$$
N=\frac{1}{q}\left(a_{-1}+\frac{1}{q}\left(a_{-2}+\frac{1}{q}\left(a_{-3}+\frac{1}{q} a_{-4}\right)\right)\right)
$$

If $N$ is given in binary, then $q=2$ and the $a$ 's are either 0 or 1 . The decimal conversion is calculated by starting with the least significant unit (for example, $a_{-4}$ in our case), working toward the left as follows: Add $a_{-3}$ to .5 , and halve the result; add $a_{-2}$, and halve the result; add $a_{-1}$, and halve the result. For example,

$$
\begin{aligned}
.1011 & =1 / 2(1+1 / 2(0+1 / 2(1+0.5))) \\
& =1 / 2(1+1 / 2(0+0.75)) \\
& =1 / 2(1+0.375)=0.6875
\end{aligned}
$$

Of course the method is to accumulate while calculating, and the work from right to left might be arranged as follows:


This method can be used for octal and sexadecimal conversion to decimal simply by converting the octal or sexadecimal to binary first; e.g., for octal,

$$
53.53(\text { octal })=101011.101011(\text { binary })
$$

## EXERCISES

Convert the following decimal numbers to binary, octal, and sexadecimal. Carry the conversion far enough so that the converted number differs from the original decimal number by less than $1 / 500$.

Sec. 3-3] coding and programming a digital computer
Answers

|  | Decimal | Binary | Octal | Sexadecimal |
| :--- | :---: | :---: | :---: | :---: |
| (a) | 56 | 111000 | 70 | 38 |
| (b) | 0.79 | .110010100 | .624 | .$C A$ |
| (c) | 56.79 | 111000.110010100 | 70.624 | $38 . C A$ |
| (d) | 0.732 | .101110110 | .566 | .$B B$ |
| (e) 87,231 | 10101010010111111 | 252277 | $154 B F$ |  |
| (f) $87,231.732$ | 10101010010111111.101110110 | 252277.566 | $154 B F . B B$ |  |

(g) Convert -56.79 to binary, octal, and sexadecimal. (Hint: A negative number is converted as if it were positive, and then the negative sign is affixed to the result. Why?)

Convert to decimal:
(h) 70 (octal).
(i) . 624 (octal).
(j) $B B$ (sexadecimal).
(k) 70.624 (octal).
(l) Compare the results of Exercise $k$ with those of Exercise $c$, and explain.

## 3-3. Number Systems : Arithmetic

Addition and Multiplication Tables. We have already considered the arithmetic operation of counting in different number systems. Although all arithmetic can be accomplished by counting, we are more familiar with the laborsaving operations of addition, multiplication, subtraction, and division. Of course these operations may also be carried out in other than the decimal number system. Addition and multiplication are essentially carried out by means of tables. For decimal, binary, and octal the tables are shown in Table 3-4.

Arithmetic Operations. In both addition and subtraction the "carry" or "borrow" is handled in other number systems exactly as it is handled in the familiar decimal system. Of course the addition tables are used during the calculation. For example,


Multiplication and division in other systems also follow the rules familiar to us in the decimal system. Of course the multiplication and

Table 3-4. Arithmetic Tables
Decimal Addition Table
Decimal Multiplication Table

| + | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 1 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| 2 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| 3 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
| 4 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 |
| 5 |  |  |  |  | 8 |  |  | 10 | 11 | 12 |
| 5 | 13 | 14 |  |  |  |  |  |  |  |  |
| 6 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 7 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| 8 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 |
| 9 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 |

Binary Addition Table

| + | 0 | 1 |
| :---: | ---: | ---: |
| 0 | 0 | 1 |
| 1 | 1 | 10 |

Binary Multiplication Table

|  |  |  |
| :---: | :---: | :---: |
| $\times$ | 0 | 1 |
| 0 | 0 | 0 |
| 1 | 0 | 1 |

Octal Addition Table

| + | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
| 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 1 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 10 |
| 2 | 2 | 3 | 4 | 5 | 6 | 7 | 10 | 11 |
| 3 | 3 | 4 | 5 | 6 | 7 | 10 | 11 | 12 |
| 4 |  |  |  |  |  |  |  |  |
| 5 | 5 | 6 | 7 | 10 | 11 | 12 | 13 |  |
| 6 | 6 | 7 | 7 | 10 | 11 | 12 | 13 | 14 |
| 7 | 7 | 10 | 11 | 12 | 12 | 13 | 14 | 15 |

Octal Multiplication Table

| $\times$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 2 | 0 | 2 | 4 | 6 | 10 | 12 | 14 | 16 |
| 3 | 0 | 3 | 6 | 11 | 14 | 17 | 22 | 25 |
| 4 |  |  |  |  |  |  |  |  |
| 4 | 0 | 4 | 10 | 14 | 20 | 24 | 30 | 34 |
| 6 | 0 | 5 | 12 | 17 | 24 | 31 | 36 | 43 |
| 7 | 0 | 6 | 14 | 22 | 30 | 36 | 44 | 52 |
| 7 | 0 | 7 | 16 | 25 | 34 | 43 | 52 | 61 |

addition or subtraction tables are used during the calculations. For example,

| 1011 | (binary) |  | 775 | (octal) |
| :---: | :---: | :---: | :---: | :---: |
| $\times 101$ | (binary) | $\times$ | 56 | (octal) |
| $\overline{1011}$ |  |  | $\overline{5756}$ |  |
| 0000 |  |  | 4761 |  |
| 1011 |  |  | $\overline{55566}$ | (octal) |
| 110111 | (binary) |  |  |  |


| $\frac{1011}{101}$110111 (binary) <br> (binary) $5 6 \longdiv { 5 5 5 6 6 }$ | (octal) <br> (octal) |  |  |
| ---: | ---: | ---: | ---: |
| $\frac{101}{111}$ | $\frac{502}{536}$ |  |  |
| $\frac{101}{101}$ |  | $\frac{502}{346}$ |  |
| 101 | 346 |  |  |

## EXERCISES

(a) Make an addition and multiplication table for sexadecimal numbers. [Hint: In the addition table the rows (and columns) count by 1 ; the row (or column) of the multiplication counts by $n$ if $n$ is the number of the row (column).]

Perform the following operations in binary:

|  | Answers |
| :--- | ---: |
| (b) $111+1$ | 1000 |
| (c) $1010+111$ | 10001 |
| (d) $1110-1$ | 1101 |
| (e) $1-1110$ | -1101 |
| (f) $1101 \times 1011$ | 10001111 |
| (g) $11011 \div 110$ | 100.1 |

Perform the following operations in octal:
(h) $6,754+777$.
(i) $73-56$.
(j) $555-62$.
(k) $5,715 \div 65$.

Using the tables of Exercise a, calculate in the sexadecimal system:

> Answers
(l) $A F C B+1 A D 8 \quad$ CAA3
(m) $842 D-65 A E \quad 1 E 7 F$
(n) $3 C \times D 1 \quad 30 F C$
(o) $1 A 8 E \div 21 \quad C E$

## 3-4. Coding : Sequences of Instructions

We shall initiate our detailed discussion of coding using the fouraddress instruction system. That is, in this section we shall consider instructions which explicitly include four addresses, since a four-address instruction system includes all the essential ideas or basic ingredients of an instruction.

Instruction Format. As we have previously seen, some bits of the instruction are set aside for the operation code designation-i.e., they tell the computer the instruction is add, multiply, divide, etc. The rest of the bits usually denote the four addresses. For the more usual operations that involve two operands, such as addition, multiplication, etc., two of the addresses are the addresses of the operands. The third address
tells where the result is to be put; the fourth address, where to obtain the next instruction. Hence a typical four-address instruction format is as follows (where the four addresses are denoted by $\alpha, \beta, \gamma$, and $\delta$ ):

| Operation <br> code | First operand <br> address $\alpha$ | Second oper- <br> and address $\beta$ | Put result in- <br> to address $\gamma$ | Address of <br> next in- <br> struction $\delta$ |
| :---: | :---: | :---: | :---: | :---: |

For any specific computer using a four-address instruction format the number of bits in each address and in the operation code must be given, as well as the actual operation code itself. In the design of a computer the number of bits reserved for an address presents an upper limit to the number of words in the addressable memory of the computer. If an address is denoted by $n$ bits, no more than $2^{n}$ words can be contained in the addressable memory.
Octal Shorthand. In order to illustrate the coding techniques developed in this section, we assume that there are 9 bits in each address ( $2^{9}=512$ addressable memory words) and 6 bits in the instruction code, a total of $(4 \times 9)+6=42$ bits in a word. This brings up the first important detail of coding: the actual bits in an instruction are not written out; rather, some shorthand is written instead. For example, in our case the bits would be divided into 14 groups of 3 bits each, and the octal equivalent of each group would be written out. In other words, two octal numbers would represent the instruction, and each address would be represented by three octal numbers. Thus, if 101011 is the binary code for add, then the instruction that says, "Add the contents of address 011010110 to the contents of address 011100 101, put the result into address 011110 100, and take the next instruction from $100000001, "$ is written in octal notation as

| Operation | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ |
| :---: | :---: | :---: | :---: | :---: |
| 53 | 326 | 345 | 364 | 401 |

In such cases it evidently facilitates matters to call the addresses in the memory by their octal numbers. It will be assumed throughout the rest of this section that such is the case. Also, numerical quantities will be written on the code sheet in octal (i.e., they will have to be converted from decimal to octal before being written on the code sheet).

The Computer Manual. For our computer we must have a "computer manual" that gives the operation codes of the different instructions and also precisely defines the meaning of the addresses for each instruction type. For example, see Table 3-5. As is clearly seen, the coding manual must always be at the coder's side. Two further observations must be reemphasized before we can proceed with an example. First, when a word is called into the arithmetic unit from the memory, it is not erased from
its memory address, but remains there also. Second, when a word is put into a memory address, it replaces the previous contents of this address, i.e., it erases what had been there.

Table 3-5. Operation Codes

| Code | Operation | Meaning |
| :---: | :---: | :---: |
| 53 | Add | Add contents of address $\alpha$ to contents of address $\beta$; put sum into address $\gamma$; take next instruction from address $\delta$ |
| 42 | Multiply | Multiply contents of address $\alpha$ by contents of address $\beta$; put product into address $\gamma$; take next instruction from address $\delta$ |
| 54 | Subtract | Subtract contents of address $\beta$ from contents of address $\alpha$; put difference into address $\gamma$; take next instruction from address $\delta$ |
| 41 | Divide | Divide contents of address $\alpha$ by contents of address $\beta$; put quotient into address $\gamma$; take next instruction from address $\delta$ |

Example 3-1. As we have noted above, a sequence of instructions is required for a problem. We shall illustrate such a sequence for a code to evaluate

$$
Y=V_{0 y} t-1 / 2 g t^{2}
$$

where $Y=$ altitude of a missile projected with an initial $Y$ velocity component of $V_{0 y}$ computed at time $t$. Suppose that $V_{0 y}=1,000 \mathrm{fps}$, $g=32 \mathrm{ft} / \mathrm{sec}^{2}$, and $t=53 \mathrm{sec}$. Now 1,000 (decimal) $=1750$ (octal), $32($ decimal $)=40($ octal $)$, and $53($ decimal $)=65($ octal $)$. Let us put the numbers

1750 into address 10
40 into address 11
65 into address 12
and 2 into address 13

Let us reserve address 14 for the result of the product $V_{0_{z}} t$, address 15 for $t^{2}$, address 16 for $g t^{2}$, address 17 for $1 / 2 g t^{2}$, and finally address 20 for $V_{0, y} t-1 / 2 g t^{2}$. The first instruction would be "Multiply the contents of address 10 by the contents of address 12 , and put the result into address 14," where we have yet to indicate where the next instruction will be found. This is written as

| Operation | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ |
| :---: | :---: | :---: | :---: | :---: |
| 42 | 010 | 012 | 014 | $?$ |

Now let us put this instruction into address 1. Next we would write an instruction to form $t^{2}$ and put this instruction into address 2. Now we can finish the first instruction,

$$
\begin{array}{lllll}
42 & 010 & 012 & 014 & 002
\end{array}
$$

The third instruction would multiply $t^{2}$ by $g$; the fourth instruction would divide $g t^{2}$ by 2 ; and the last instruction would subtract $1 / 2 g t^{2}$ from $V_{0, y} t$. A code is written on a coding sheet, which usually has the left-hand column labeled with addresses and the remaining columns labeled with the parts of an instruction. In this way a clear account is made of exactly which instructions are located in which addresses. On a coding sheet our code would look like Example 3-1a. The student should carefully check each instruction in this code to be sure that each does what the "remark" says it does. There are several things missing from this code: How do we get the computer started, and how do we stop it when the job is finished?

Example 3-1a

| Address | Instruction |  |  |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ |  |
| 000 |  |  |  |  |  |  |
| 001 | 42 | 010 | 012 | 014 | 002 | Form $V_{0 y} t$ |
| 002 | 42 | 012 | 012 | 015 | 003 | Form $t^{2}$ |
| 003 | 42 | 015 | 011 | 016 | 004 | Form $g t^{2}$ |
| 004 | 41 | 016 | 013 | 017 | 005 | Form $1 / 2 \mathrm{gt}{ }^{2}$ |
| 005 | 54 | 014 | 017 | 020 | 006 | Form Y |
| 006 | See text |  |  |  |  |  |
| 007 |  |  |  |  |  |  |
| 010 | 00 | 000 | 000 | 001 | 750 | $V_{0 y}$ constant |
| 011 | 00 | 000 | 000 | 000 | 040 | $g$ constant |
| 012 | 00 | 000 | 000 | 000 | 065 | $t$ constant |
| 013 | 00 | 000 | 000 | 000 | 002 | 2 constant |
| 014 |  |  |  |  |  | $V_{0 y} t$ temporary |
| 015 |  |  |  |  |  | $t^{2}$ temporary |
| 016 |  |  |  |  |  | $g t^{2}$ temporary |
| 017 |  |  |  |  |  | $1 / 2 \mathrm{gt}{ }^{2}$ temporary |
| 020 |  |  |  |  |  | $Y=V_{0 y} t-1 / 2 g t^{2}$ |

There are many systems in use for initiating a code on a computer. For example, after the code is read into the computer, the computer might automatically take the very first instruction from address 000 . In our example we would then have a dummy instruction, say "Subtract contents of 007 from contents of 007, put result in 007, and take next instruction from 001." We used 007 because our particular code does not involve 007. In order to stop the computer when the computation has been completed, the last instruction should be one that says simply "Stop the computer." For instance, suppose that 60 is the operation code for such an instruction; then we could put

$$
\begin{array}{lllll}
60 & 000 & 000 & 000 & 000
\end{array}
$$

in address 006 . In such an instruction the addresses $\alpha, \beta, \gamma$, and $\delta$ have no use.

The Used Temporaries. Memory space in a computer is often at a premium and should be conserved. From this point of view the above code is not satisfactory. For note that, after $t^{2}$ has been computed, address 015 is not used again. In other words, we could have computed $g t^{2}$ and put this result back into 015 , and then computed $1 / 2 g t^{2}$ and put this back into 015 also, eliminating the necessity for using 016 and 017. Similarly, after computing $Y$, we could put this result into 015, eliminating the use of 020 also.

This brings up an important point about addresses reserved for numbers. There are two kinds of numbers contained in addresses: "permanent," or constant, numbers, such as 2 and $g$, and "temporary," or transient, numbers, i.e., numbers that appear only in intermediate stages of the computation. These temporary numbers can share their address with other temporary numbers that appear at some other time. Hence we call such memory locations temporaries. In our example above, 015 would be such a temporary. The adjusted code becomes Example 3-1b.

Example 3-1b

| Address | Instruction |  |  |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ |  |
| 000 | 54 | 007 | 007 | 007 | 001 | Take first instruction from 001 |
| 001 | 42 | 010 | 012 | 014 | 002 | Form $V_{0 y} t$ |
| 002 | 42 | 012 | 012 | 015 | 003 | Form $t^{2}$ |
| 003 | 42 | 015 | 011 | 015 | 004 | Form $g t^{2}$ |
| 004 | 41 | 015 | 013 | 015 | 005 | Form $1 / 2 \mathrm{~g} \mathrm{t}^{2}$ |
| 005 | 54 | 014 | 015 | 015 | 006 | Form Y |
| 006 | 60 | 000 | 000 | 000 | 000 | Stop computer |
| 007 |  |  |  |  |  |  |
| 010 | 00 | 000 | 000 | 001 | 750 | $V_{0 y}$ constant |
| 011 | 00 | 000 | 000 | 000 | 040 | $g$ constant |
| 012 | 00 | 000 | 000 | 000 | 065 | $t$ constant |
| 013 | 00 | 000 | 000 | 000 | 002 | 2 constant |
| 014 |  |  |  |  |  | $V_{0 y} t$ temporary |
| 015 |  |  |  |  |  | Temporary, where final result is found |

## EXERCISES

(a) Using the instructions defined in this section, write a code that calculates $x=$ $a^{3}-b c$, where $a=313$ (decimal), $b=983$ (decimal), and $c=838$ (decimal).
(b) In the example given in this section why are two temporaries needed, that is,

014 and 015? Write a code using only one temporary. [Hint: $V_{0} t-1 / 2 g t^{2}=$ $\left(V_{0}-1 / 2 g t\right) t$.]
(c) If an instruction format for a computer allowed 12 bits for each address, what is the maximum number of addressable words possible for the memory of that computer? [Ans. $2^{12}=4,096$ (decimal) words.] If the first address of this memory is 0000 , what is the last memory address? [Ans. 7777 (octal) (that is, $2^{12}-1$ written in octal).]

## 3-5. Coding Decisions

The Comparison Instruction. We shall next give an example to be coded where a simple decision is made by the computer. Such decisions are usually made by comparison instructions. For example, a comparison instruction might operate thus: "Compare the contents of $\alpha$ with the contents of $\beta$; if the contents of address $\alpha$ is greater than the contents of address $\beta$, then take the next instruction from address $\gamma$; otherwise, take the next instruction from address $\delta$." A few simple conventions can greatly shorten such a statement: Let ( $\alpha$ ) stand for "the contents of address $\alpha$ "; and let the word take mean "take the next instruction from." Then the above statement becomes "If $(\alpha)>(\beta)$, take $\gamma$; if $(\alpha) \leq(\beta)$, take $\delta$." Let the operation code for this instruction be 43.
Example 3-2. Now consider the code for the following problem: Three numbers, $U, V$, and $W$, are found as the contents of addresses 015,016 , and 017 , respectively. We wish to write a code that will put the largest of these numbers into address 020 . First note that in any case we shall need three instructions that transfer the contents of addresses 015, 016, and 017, respectively, into address 020 , and the rest of the code is to decide which of these three instructions to execute. The transfer problem is easily taken care of by adding the contents of the desired address to the constant zero and putting the result into 020. (Hence we need an address whose contents is zero.) Let us put the three such instructions into 005,006 , and 007 (see the code below). To determine which of these to execute, let us first compare (015) ? (016). If this is the case, then we would compare (015) ${ }_{>}^{?}$ (017). If this is also the case, then (015) $>$ both (016) and (017), that is, $U>V$ and $U>W$, and hence we would execute (005), i.e., transfer (015) to (020). If (015) $\leq$ ( 017 ), then $(017) \geq(015)>(016)$, that is, $W \geq U>V$; hence we transfer (017) to ( 020 ), i.e., execute ( 007 ). If $(015) \leq(016)$, then compare (016) $?$ (017). If this is the case, ( 016 ) $\geq$ both ( 015 ) and ( 017 ), that is, $V \geq U$ and $V>W$; hence we transfer (016) to (020), i.e., execute (006). If $(016) \leq(017)$, then $(017) \geq(016) \geq(015)$, that is, $W \geq V \geq U$; hence transfer (017) to (020), i.e., execute (007). The code is shown in Example 3-2a.

Several general observations can be made that are exemplified by this code. First, coding is a very exacting technique: every path of every instruction must be followed carefully, for a single error invalidates the entire code. Second, note that when using a comparison instruction the significance of the $\leq$ must be carefully considered, as well as that of the $>$. Reading a code does not teach one how to code-actually writing

Example 3-2a

| Address | Instruction |  |  |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ |  |
| 000 | 54 | 021 | 021 | 021 | 001 | Take first instruction from 001 |
| 001 | 43 | 015 | 016 | 002 | 003 | $U>V ?$ <br> Yes, try $U>W$; i.e., take 002 <br> No, try $V>W$;i.e., take 003 |
| 002 | 43 | 015 | 017 | 005 | 007 | $U>W ?$ <br> Yes, $U$ is largest number;i.e., take 005 <br> No, $W$ is largest number; i.e., take 007 |
| 003 | 43 | 016 | 017 | 006 | 007 | $V>W ?$ <br> Yes, $V$ is largest number; i.e., take 006 <br> No, $W$ is largest number; i.e., take 007 |
| $\begin{aligned} & 004 \\ & 005 \end{aligned}$ | 53 | 015 | 021 | 020 | 010 | Transfer $U$ to largest number cell |
| 006 | 53 | 016 | 021 | 020 | 010 | Transfer $V$ to largest number cell |
| 007 | 53 | 017 | 021 | 020 | 010 | Transfer $W$ to largest number cell |
| 010 | 60 | 000 | 000 | 000 | 000 | Stop computer |
| 011 |  |  |  |  |  |  |
| 012 |  |  |  |  |  |  |
| 014 |  |  |  |  |  |  |
| 015 |  |  |  |  |  | $U$ |
| 016 |  |  |  |  |  | $V$ three given numbers |
| 017 |  |  |  |  |  |  |
| 020 |  |  |  |  |  | Largest number cell |
| 021 | 00 | 000 | 000 | 000 | 000 | 0 constant |

a code does. Most students will undoubtedly feel uneasy about the above example until they rewrite it, doing the detailed thinking themselves, using the example only as an occasional guide and final check.

The Sign Bit. Up to now we have been making two tacit assumptions, namely, (1) that all numbers are whole numbers (i.e., have no fractional part) and (2) that all numbers and results are positive. Both the assumptions are not necessarily true. They were made in order to concentrate on the coding problems so far considered and avoid unnecessary complication in those discussions. We shall defer full consideration of the first of these problems for a later section, remarking here only that
a computer can consider numbers whose magnitudes lie within a restricted range which depends on the construction of the computer. We have been illustrating a computer with a range of integers from 0 through $2^{42}-1$. Hence, before putting a problem on a computer, it must be "scaled" so that all numbers that appear will be whole numbers. Similarly problems must be scaled to fit on other computers, depending on their ranges. The second problem is solved as follows: A single bit is added on the left to the length of the word, making the word 43 bits long. If this bit is a zero, then the machine is wired to interpret the number as being positive; if this bit is a unit, then the machine will interpret the number as being negative. The circuitry in the arithmetic unit must sense the signs of the operands and compute the proper values for this so-called sign bit in the results. The meaning attached to this 43 d bit, as far as an instruction is concerned, is different for different computers and is discussed below; it is never a fundamental ingredient of the instruction. On the coding sheet the sign bit is noted by affixing a + to the left of the number if it is positive or zero, and a - if it is negative.

## EXERCISE

(a) Using the instructions defined in this and the preceding section, write a code that calculates $X=$ minimum $(U, V, W)$, where $U, V$, and $W$ are the contents of addresses 010, 011, and 012, respectively.

## 3-6. Coding : Flow Charting and Symbolic Code Aids

A flow chart is a diagram, or picture, of a code that is often helpful for visualizing interrelationships between various parts of a code. Such a diagram is almost always made before the specific instructions are written. There are essentially three kinds of symbols used in a flow chart (see Fig. 3-1). The first represents function calculation; the second represents decisions and the various associated alternatives; and the third, called a (variable) connector, is simply a way to eliminate too many crossing lines in the picture or to indicate which lines to follow when one has to continue the diagram on another page.


Fig. 3-1. Flow-chart symbols.
For illustration, consider the example of Sec. 3-4: The functions $V_{0 y} t$ and $1 / 2 g t^{2}$ are to be calculated, and their difference is the final desired result. Hence we would draw the flow diagram in Fig. 3-2. The first (left) box represents the instruction in address 001 ; the second box repre-
sents the set of instructions in addresses 002 to 004 ; the third box represents the instruction in address 005 . The arrows indicate the order in which the computer does the indicated computing. Note that the symbols representing intermediate results appearing on the left-hand side of the equations, namely, $x$ and $y$, appear later in the chart on the right-hand side of an equation. Only symbols that signify end results, like $Y$, will not appear on the right-hand side of an equation. This observation gives a superficial way to check that all intermediate results are used appropriately.


Fig. 3-2. Simple flow chart.


Fig. 3-3. Flow chart including decision boxes.
A more complicated flow diagram is associated with the problems of Sec. 3-5. Here decision boxes are used (see Fig. 3-3). The lines leadinfs away from the ovals represent the different paths the computer will take, depending on the outcomes of the decisions. The little symbols ( $>$ and $\leq)$ near the lines represent the conditions under which the program will go in the corresponding directions. The proper corresponding condition is indicated when the symbol replaces the colon; i.e., the computer will follow the left-hand path when $U>V$ and the right-hand path when $U \leq V$. The use of the connector is clear. The top decision box represents (001); on the next lower level the left-hand box represents (002), the right-hand box (003). On the next lower level the left-hand function box represents (005), the right-hand box (006), and the lowest box (007).

Symbolic coding is another intermediate aid between the statement of the problem and the final code. Symbolic coding consists in writing a code, not in terms of specific numerical addresses, but rather in terms of
some name description or other symbolism to represent the addresses. Then at a later time specific addresses can be assigned for these symbols, or names, to produce the actual code. The intermediate code in terms of symbols is called the symbolic code. This technique is extremely useful, particularly in those cases where one must write instructions involving addresses of constants or of other instructions that have not yet been specifically assigned. For example, this difficulty is encountered in writing the code for the second example of the previous section, since when writing the instruction for $U: V$, the coder must refer to the not as yet written or located instructions for $U: W$ and $V: W$. A symbolic code for this example might be as shown in Example 3-3a. The symbolism of this code is as follows: $\mathbb{U}$ is the address whose contents is the number

Example 3-3a

|  | Instruction |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Address | Opera- <br> tion | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ |
| U:V | CMP |  | U | V | U:W |
| U:W | CMP | U | W | ULN | WLN |
| V:W | CMP | V | W | VLN | WLN |
| ULN | ADD | U | $\phi$ | LNC | S |
| VLN | ADD | V | $\phi$ | LNC | S |
| WLN | ADD | W | $\boldsymbol{\phi}$ | LNC | S |
| S |  |  |  |  |  |
| U |  |  |  |  |  |
| V |  |  |  |  |  |
| W |  |  |  |  |  |
| LNC |  |  |  |  |  |
| $\phi$ |  |  |  |  |  |

$U$-that is, ( U$)=U . \quad \mathrm{V}$ is the address such that $(\mathrm{V})=V . \quad \mathrm{W}$ is the address such that $(\mathrm{W})=W . \mathrm{U}: \mathrm{V}$ is the address whose contents has the compare instruction concerning $U$ and $V$, and similarly for $\mathrm{U}: \mathrm{W}$ and $\mathrm{V}: \mathrm{W}$; ULN is the address of the instruction that puts the number $U$ into the largest number cell, and similarly for VLN and WLN. LNC is the address of the largest number cell; $\boldsymbol{\phi}$ is the address whose contents is the constant zero; and S is the address of the stop instruction. CMP stands for the compare operation code, and ADD stands for the add instruction code. The assignment of addresses then is shown in Example 3-3b.

Steps in Writing a Code. The procedure for programming or coding is as follows: (1) Understand the statement of the problem. (2) Draw a flow diagram for the problem. (3) Code symbolically each box of the flow diagram. (4) Assign addresses. (5) Write out the final detailed code. The flow diagram presents an over-all visual picture of the prob-

Example 3-3b

| Symbolic name | Address (or code) |
| :---: | :---: |
| U:V | 001 |
| U:W | 002 |
| V:W | 003 |
| ULN | 005 |
| VLN | 006 |
| WLN | 007 |
| S | 010 |
| U | 015 |
| V | 016 |
| W | 017 |
| LNC | 020 |
| \$ | 021 |
| CMP | 43 |
| ADD | 53 |

lem, organizing the coding effort so that it can be concentrated on one box at a time. Symbolic coding enables an instruction to be written before the coder knows the addresses of constants and other instructions referenced by this instruction. In addition, since the symbolic code names for these addresses are suggestive of their contents, the symbolic code is easier to write and follow.

## EXERCISES

Using the instructions defined in the previous section, draw the flow diagram, write a symbolic code, assign addresses, and finally write the final codes to calculate $x$ [where $a=313$ (decimal), $b=983$ (decimal), and $c=838$ (decimal)]:
(a) $x=a^{3}-b \cdot c$.
(b) $x=b(a+c)$.
(c) $x=\frac{a^{3}-b \cdot c}{b(a+c)}$.

If $U, V$, and $W$ are the contents of addresses 010,011 , and 012 , respectively, calculate:
(d) $x=$ minimum $(U, V, W)$.
(e) $x=$ maximum $\left(U^{2}, V^{2}, W^{2}\right)$.
(f) $x=$ maximum ( $U^{3}-V W, V(U+W)$ ).

Hint: The same symbolic code for Exercises $a$ and $b$ appears as parts of the symbolic code for Exercises $c$ and $f$.

## 3-7. Three-address Instruction Systems

Using Less than Four Addresses. Up to now we have considered an instruction format containing four addresses. It was remarked in Sec. 3-1 that each of the four addresses is a necessary ingredient to coding and that computers using fewer addresses must compensate by (1) having the omitted information wired in and by (2) using more instructions to achieve the same ends. From the engineering point of view the primary advantage of having fewer than four addresses in the
instruction is that for the same word length each address will comprise more bits and hence give the computer a larger addressable memory capability. In the 43 -bit format described in Sec. $3-4,36$ bits were reserved for the four addresses, making each address 9 bits long, for a maximum of 512 words in the addressable memory. If three addresses were used, each would comprise 12 bits, allowing a 4,096-word memory; two addresses, 18 bits per instruction, a 262,144 -word memory; one address, 36 bits, $68,719,476,736$ words. Of course shorter words can be designed for machines with one- or two-address instructions, and this in itself can, as we shall see, save a great deal of hardware.

The Three-address Instruction. The usual $\dagger$ three-address instruction is similar to the four-address instruction except that the $\delta$ address is omitted from the format. Hence the format becomes

| Operation <br> code | Address of first <br> operand, $\alpha$ | Address of second <br> operand, $\beta$ | Address into which <br> result is put, $\gamma$ |
| :---: | :---: | :---: | :---: |

How does the computer know in what address to find the next instruction? Except for special instructions the computer will always take as the next instruction the contents of the next consecutive address following that of the present instruction. That is, the computer will normally take the instructions consecutively in the order in which they are written into the memory. This is accomplished in the current-address register.

Example 3-1c. Three-address

$\dagger$ Any of the addresses might be omitted at the whim of the designer.

This register is first set at the address of the first instruction; then, each time an instruction is executed, the contents of this register normally is automatically increased by 1 and is taken by the computer as the address of the next instruction. (Because of this the current-address register is often called the current-address counter.) With this understanding of where the computer will find the next instruction the only change necessary in the add, multiply, divide, and subtract instructions given in Sec. $3-4$ is the deletion of the $\delta$ address. However, the comparison instruction will need redefining thus: If $(\alpha)>(\beta)$, take next instruction from $\gamma$; otherwise take the next consecutive instruction. If ( $\alpha$ ) $>(\beta)$, then the current-address counter will automatically be set at address $\gamma$; if $(\alpha) \leq(\beta)$, the counter will behave as usual, just increasing by 1 .

Examples. For instance, the examples coded in Secs. 3-4 and 3-5 would have to be rewritten as shown in Examples 3-1c and 3-2b.

There is not much difference between Example 3-1c and its four-
Example 3-2b. Three-address

| Address | Instruction |  |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ | $\gamma$ |  |
| 0000 | 54 | 0021 | 0021 | 0021 | Take first instruction from 0001 |
| 0001 | 43 | 0015 | 0016 | 0005 | $\begin{aligned} & U: V \\ & \quad \text { If } U>V \text {, take } 0005 \\ & \text { If } U \leq V \text {, take } 0002 \end{aligned}$ |
| 0002 | 43 | 0016 | 0017 | 0007 | $\begin{aligned} & V: W \\ & \text { If } V>W \text {, take } 0007 \\ & \text { If } V \leq W \text {, take } 0003 \end{aligned}$ |
| 0003 | 53 | 0017 | 0021 | 0020 | Transfer $W$ to largest number cell |
| 0004 | 43 | 0022 | 0021 | 0012 | Jump to stop |
| 0005 | 43 | 0015 | 0017 | 0011 | ```U:W If U>W, take 0011 If U}\leqW\mathrm{ , take 0006``` |
| 0006 | 43 | 0022 | 0021 | 0003 | Jump to transfer $W$ instruction |
| 0007 | 53 | 0016 | 0021 | 0020 | Transfer $V$ to largest number cell |
| 0010 | 43 | 0022 | 0021 | 0012 | Jump to stop |
| 0011 | 53 | 0015 | 0021 | 0020 | Transfer $U$ to largest number cell |
| 0012 | 60 | 0000 | 0000 | 0000 | Stop |
| 0013 |  |  |  |  |  |
| 0014 |  |  |  |  |  |
| 0015 |  |  |  |  | $U$ <br> $V$ |
| 0016 |  |  |  |  | $V$ given numbers |
| 0017 |  |  |  |  | $W$ W |
| 0020 |  |  |  |  | Largest number cell |
| 0021 | 00 | 0000 | 0000 | 0000 | 0 constant |
| 0022 | 00 | 0000 | 0000 | 0001 | 1 constant |

address version. Consider, however, Example 3-2b. Each branch of this code should be carefully reconstructed by the student so that he may grasp just what problems arise from ordering the instructions and how these problems are solved. Note that there appear in addresses 0004 and 0010 dummy comparisons, which artificially force a jump to address 0012, where the stop instruction is located. Also, a dummy comparison was made in address 0006 in order to reuse (0003). A total of 11 instructions were necessary in the three-address system, while 8 sufficed in the four-address system. The placement of the instructions was somewhat complicated; this difficulty is relieved by symbolic coding.

## EXERCISES

(a) By rearranging the order of one of the comparisons together with the order of some of the instructions in Example 3-2b above, one instruction can be eliminatedi.e., the code will take only 10 instructions instead of 11 . Can you find this comparison and rearrange the instructions properly? (Hint: In address 0005 the instruction can be changed so as to jump directly to make $W$ the largest number. But then some other instructions must be reordered.)
(b) Redefine in detail for a three-address system the add, subtract, multiply, and divide instructions given in Sec. 3-4.
(c) Draw flow diagrams for the above examples, and state which sets of instructions belong to each box.
( $d-i$ ) Do Exercises $a$ to $f$ of Sec. 3-6, using the three-address instructions defined in this section. Carry out each of the five steps of coding in every problem.

## 3-8. Two-address Instruction Systems

The Two-address Instruction. In the two-address instruction usually both the $\gamma$ and $\delta$ addresses are eliminated. The format is simply

| Operation <br> code | Operand <br> address $\alpha$ | Operand <br> address $\beta$ |
| :---: | :---: | :---: |

The computer finds the location of the next instruction as in the threeaddress system, taking care of the function of $\delta$. Where does the result of the operation go? This problem is solved in a two-address system by having the result of every arithmetic operation automatically left in a very special memory location, called the accumulator. This special memory cell is located in the arithmetic unit; it has been discussed in Chap. 2 of this book. It suffices to note here that $\gamma$ is most often understood to be the accumulator, although as we shall see in Chap. 4 there can be many variations to this theme. Hence the definitions of our instructions must be rewritten as shown in Table 3-6.

Of course, after the sum is in the accumulator, it must be transferred to an ordinary memory location. Hence we need a transfer instruction. Other versions which might be used are also listed (cf. Chap. 4).

Examples. As mentioned above, the word length is often shortened for two or one-address systems; so let us, for illustration purposes, use a

Table 3-6. Two-address Instructions

| Code | Operation | Meaning |
| :---: | :--- | :--- |
| 53 | Add | Add $(\alpha)$ to $(\beta)$, and put result in accumulator <br> 42 |
| Multiply | Multiply $(\alpha)$ by ( $\beta$ ), and put result in accumulator |  |
| 54 | Subtract | Subtract $(\beta)$ from ( $\alpha$ ), and put result in accumulator |
| 41 | Divide | Divide ( $\alpha$ ) by ( $\beta$ ), and put result in accumulator |
| 43 | Compare | If $(\alpha)>$ (acc), take $\beta$; otherwise go to next consecutive <br> instruction (as usual) |
| 52 | Transfer | Transfer (acc) into $\alpha$, and take $\beta$ <br> 51 |
| Add and transfer | Add ( $\alpha$ ) to (acc), and put result into $\beta$ |  |
| 40 | Multiply and transfer | Multiply ( $\alpha$ ) by (acc), and put result into $\beta$ |

word length of 24 bits plus one sign bit. In order to increase flexibility, the accumulator is often given an address, say, for example, 777. The example codes as revised are shown as Examples 3-1d and 3-2c. Note that two more instructions were needed in Example 3-1d than for the three- or four-address codings. The contents of the accumulator must be carefully watched, or errors might creep in.

In Example 3-2c note how the comparisons were arranged so that the next instruction in sequence could be a transfer instruction direct from the accumulator. This was successfully accomplished for $V$ and $U$. However, $W$ had to be placed in the accumulator especially for its trans-

Example 3-1d. Two-address

| Address | Instruction |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ |  |
| 000 | 54 | 017 | 017 | Take first instruction from 001 |
| 001 | 42 | 010 | 012 | Form $V_{0 y} t$ in accumulator |
| 002 | 52 | 014 | 003 | Put $V_{0 y} t$ into 014 |
| 003 | 42 | 012 | 012 | Form $t^{2}$ in accumulator |
| 004 | 42 | 011 | 777 | Form $g t^{2}$ in accumulator |
| 005 | 41 | 777 | 013 | Form $1 \frac{2}{2} g t^{2}$ in accumulator |
| 006 | 54 | 014 | 777 | Form Y |
| 007 | 52 | 015 | 016 | Put $Y$ into 015 |
| 010 | 00 | 001 | 750 | $V_{04}$ |
| 011 | 00 | 000 | 040 | $g$ |
| 012 | 00 | 000 | 065 | $t$ |
| 013 | 00 | 000 | 002 | 2 |
| 014 |  |  |  | $V_{0 y} t$ temporary |
| 015 |  |  |  | Temporary, where result is found |
| 016 | 60 | 000 | 000 | Stop computer |
| 017 | 00 | 000 | 000 | 0 constant |

fer to the largest number cell. In any event it is to be noted that the placement of instructions and the order of the comparisons become more complicated in a two-address system. Note also that 11 instructions were needed, one more than was absolutely necessary for the threeaddress system (see Exercise $a$ of Sec. 3-7) and three more than for the four-address system.

Example 3-2c. Two-address

| Address | Instruction |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ |  |
| 000 | 54 | 021 | 021 | Take first instruction from 001 |
| 001 | 53 | 016 | 021 | Put $V$ into accumulator |
| 002 | 43 | 015 | 005 | ```U:V If }U>V\mathrm{ , take 005 If U}\leqV\mathrm{ , take 003``` |
| 003 | 43 | 017 | 010 | $\begin{aligned} & W: V \text { (since } V \text { is already in accumulator) } \\ & \text { If } W>V \text {, take } 010 \\ & \text { If } W \leq V \text {, take } 004 \end{aligned}$ |
| 004 | 52 | 020 | 012 | Transfer $V$ from accumulator into 020 |
| 005 | 53 | 015 | 021 | Put $U$ into accumulator |
| 006 | 43 | 017 | 010 | $\begin{aligned} & W: U \\ & \quad \text { If } W>U \text {, take } 010 \\ & \text { If } W \leq U \text {, take } 007 \end{aligned}$ |
| 007 | 52 | 020 | 012 | Transfer $U$ from accumulator into 020 |
| 010 | 53 | 017 | 021 | Transfer $W$ into accumulator |
| 011 | 52 | 020 | 012 | Transfer $W$ from accumulator into 020 |
| 012 | 60 | 000 | 000 | Stop computer |
| 013 |  |  |  |  |
| 014 015 |  |  |  | $U$ |
| 016 |  |  |  | $V$ given numbers |
| 017 |  |  |  |  |
| 020 |  |  |  | Largest number cell |
| 021 | 00 | 000 | 000 | 0 constant |

## EXERCISES

(a) Relate sets of instructions of the above examples to their respective boxes of the flow diagrams.
(b-g) Do Exercises $a$ to $f$ of Sec. 3-6, using the two-address instructions defined in this section.

## 3-9. One-address Instruction Systems

The One-address Instruction. In the one-address instruction only one operand address, $\alpha$, remains. The accumulator does a dual job, standing
in for both the second operand address $\beta$ and the address $\gamma$ into which the result is put. Address $\delta$ is handled as in the three- and two-address systems. There are a large number of variations on this theme, and often additional registers or special memory locations are used. However, in presenting the principles of one-address coding it suffices here to consider only one register, the accumulator. In a one-address system many more kinds of instructions are found essential. For example, in a typical modern one-address computer there are 88 different instructions. This should be compared with the 46 and 16 instructions defined for typical modern two- and three-address computers. It is evident that, the more complex and numerous the instructions that have to be learned by the coder, the harder it is for him to code. In order to help the coder who deals with a machine with, say, 88 instructions, advanced programming techniques are resorted to; these will be discussed in Chap. 5 . The necessity for advanced programming techniques to aid the coder prepare programs for a one-address computer system becomes even more striking when one reads the rather tortuous techniques needed to accomplish the simplest of complete operations, such as comparisons, as illustrated by the examples to be presented below. The list of one-address instructions in Table 3-7 is sufficient to meet our needs for the examples.

Table 3-7. One-address Instructions

| Code | Operation | Meaning |
| :---: | :---: | :---: |
| 53 | Add | Add ( $\alpha$ ) to (acc); put result in accumulator |
| 42 | Multiply | Multiply ( $\alpha$ ) by (acc); put result in accumulator |
| 54 | Subtract | Subtract ( $\alpha$ ) from (acc); put result in accumulator |
| 41 | Divide | Divide (acc) by ( $\alpha$ ); put result in accumulator |
| 43 | Conditional jump | If (acc) is negative, take $\alpha$; otherwise take next instruction in sequence as usual |
| 52 | Transfer | Transfer (acc) into $\alpha$ |
| 51 | Replace add | Add ( $\alpha$ ) to (acc); put result into $\alpha$ |
| 40 | Replace multiply | Multiply ( $\alpha$ ) by (acc); put result into $\alpha$ |
| 44 | Jump | Take next instruction from $\alpha$ |

The transition from two to one address for the add, multiply, subtract, and divide instructions is natural enough, but how is comparison performed? To perform a comparison, one of the numbers is put into the accumulator and the other subtracted from it; then a conditional jump is used. (A computer with more than one register may compare the contents of two registers.)

Examples. Let us shorten our word to 15 bits plus a sign bit, for convenience in this presentation; then the codes for our examples can be written as shown in Examples 3-1e and 3-2d.

Note, for the first, that it is necessary to make sure that the contents of the accumulator was zero before using the add instruction to transfer
a number into the accumulator. Also we calculate $1 / 2 g t^{2}$ first so that after forming $V_{0 y} t$ in the accumulator we can subtract $1 / 2 g t^{2}$ directly from the accumulator, thus avoiding an extra clearing, etc., of the accumulator. More instructions are needed than for the other systems: oneaddress, 12 ; two-address, 7 ; three-address, 7; four-address, 7. One less instruction than used will suffice: the student should check this for himself, revising the code to require one less instruction.

Example 3-1e. One-address

| Address | Instruction |  | Remarks |
| :---: | :---: | :---: | :---: |
|  | Operation | $\boldsymbol{\alpha}$ |  |
| 000 | 44 | 001 | Take first instruction from 001 |
| 001 | 42 | 016 |  |
| 002 | 53 | 021 | Clear accumulator, and form $t^{2}$ |
| 003 | 42 | 021 |  |
| 004 | 42 | 020 | Form $g t^{2}$ |
| 005 | 41 | 022 | Form $1 / 2 g t^{2}$ |
| 006 | 52 | 023 | Put $1 / 2 g t^{2}$ into 023 |
| 007 | 42 | 016 |  |
| 010 | 53 | 017 | Clear accumulator, and form $V_{0 y} t$ |
| 011 | 42 | 021 |  |
| 012 | 54 | 023 | Form $Y=V_{0 y} t-1 / 2 g t^{2}$ |
| 013 | 52 | 023 | Put $Y$ into 023 |
| 014 | 60 | 000 | Stop computer |
| 015 |  |  |  |
| 016 | 00 | 000 | 0 constant |
| 017 | 01 | 750 | $V_{0 y}$ |
| 020 | 00 | 040 | $g$ |
| 021 | 00 | 065 | $t$ |
| 022 | 00 | 002 | 2 |
| 023 |  |  | $1 / 2 g t^{2}$ temporary and result |

There are 25 instructions in the code of the second example as compared with 11 for the corresponding code in the two-address system, 10 in the three-address system, and 8 in the four-address system. By choosing a more convenient set of one-address instructions (cf. Chap. 4) we might have reduced the length of the code somewhat, but not significantly.

One-plus-one-address Systems. There is another kind of two-address instruction that deserves mention. It is a two-address instruction where the $\alpha$ and $\delta$ addresses are retained, instead of the $\alpha$ and $\beta$ addresses. In other words, an addition instruction might read: Add ( $\alpha$ ) to the accumulator, and take the next instruction from $\delta$. Such a system has the coding characteristics of a one-address system; the purpose of the second address is to allow minimum access coding when a drum is being used

Example 3-2d. One-address

| Address | Instruction |  | Remarks |
| :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ |  |
| 000 | 44 | 001 | Jump to first instruction of code, 001 |
| 001 | 42 | 035 | Clear accumulator |
| 002 | 53 | 032 | Put $V$ into accumulator set up comparison |
| 003 | 54 | 031 | Form $V-U$ in accumulator |
| 004 | 43 | 015 | If (acc) negative, $U>V$, try $U: W$; if positive, $U \leq V$, try $V: W$ |
| 005 | 42 | 035 | Clear accumulator |
| 006 | 53 | 032 | Put $V$ into accumulator set up comparison |
| 007 | 54 | 033 | Form $V-W$ in accumulator |
| 010 | 43 | 025 | If (acc) negative, $W>V, W$ largest; if positive, $W \leq V$, $V$ largest |
| 011 | 42 | 035 | Clear accumulator |
| 012 | 53 | 032 | Put $V$ into accumulator $\quad V V$ is largest number |
| 013 | 52 | 034 | Put $V$ into largest number cell) |
| 014 | 44 | 030 | Jump to stop |
| 015 | 42 | 035 | Clear accumulator |
| 016 | 53 | 031 | Put $U$ into accumulator $\}$ set up comparison |
| 017 | 54 | 033 | Form $U-W$ in accumulator) |
| 020 | 43 | 025 | If (acc) negative, $W>U$, $W$ largest; if positive, $W \leq U$, $U$ largest |
| 021 | 42 | 035 | Clear accumulator |
| 022 | 53 | 031 | Put $U$ into accumulator $\} U$ is largest number |
| 023 | 52 | 034 | Put $U$ into largest number cell |
| 024 | 44 | 030 | Jump to stop |
| 025 | 42 | 035 | Clear accumulator |
| 026 | 53 | 033 | Put $W$ into accumulator $\quad\} W$ is largest number |
| 027 | 52 | 034 | Put $W$ into largest number cell) |
| 030 | 60 | 000 | Stop computer |
| 031 |  |  |  |
| 032 |  |  | $V$ given numbers |
| 033 |  |  | W) |
| 034 |  |  | Largest number cell |
| 035 | 00 | 000 | 0 constant |

(see Chap. 2). That is, the second address presents some further flexibility in the placing of the instructions in the drum memory. This is often called a one-plus-one-address system.

## EXERCISES

(a) Relate sets of instructions of the above codes with their respective boxes in the flow diagrams.
(b-g) Do Exercises $a$ to $f$ of Sec. 3-6, using the one-address instructions defined in this section.
( $h$ ) Define one-plus-one instructions corresponding to the one-address instructions given above; then redo the second example. Have a significant number of instructions been saved?

## 3-10. Decimal Systems

Decimal-coded Binary. The only variations in the coding system so far described were with respect to the instruction format and, in particular, to the number of addresses that were explicitly displayed in this format. In all these systems numbers were written in octal-coded binary; i.e., a set of octal characters represented a binary number. In fact the three bits represented by each octal character corresponded to the same number with radix 2: 3 (octal) represented 011,5 (octal) represented 101, etc. The instructions were written with the same shorthand, the octal character representing the real equivalent 3 -bit binary number.

There is another system for coding numbers and an associated shorthand for representing the bits in an instruction, called decimal-coded binary. Of course, either octal-coded binary or decimal-coded binary can be used with four-, three-, two-, and one-address instruction formats.

Usually, in decimal-coded binary, 6 bits are associated with a single decimal number. Since there are 64 different combinations that can be formed with 6 bits, the letters of the alphabet are also assigned binary codes. These assigned codes depend on the logical design of the computer. For example, one such system (UNIVAC) is as shown in Table 3-8.

Table 3-8. UNIVAC X-3 Code

| Symbol | Binary code |  | Symbol | Binary code |  | Symbol | Binary code |  | Symbol | Binary code |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 00 | 0011 | A | 01 | 0100 | $J$ | 10 | 0100 | S | 11 | 0101 |
| 1 | 00 | 0100 | $B$ | 01 | 0101 | K | 10 | 0101 | $T$ | 11 | 0110 |
| 2 | 00 | 0101 | C | 01 | 0110 | $L$ | 10 | 0110 | U | 11 | 0111 |
| 3 | 00 | 0110 | D | 01 | 0111 | M | 10 | 0111 | V | 11 | 1000 |
| 4 | 00 | 0111 | E | 01 | 1000 | $N$ | 10 | 1000 | W | 11 | 1001 |
| 5 | 00 | 1000 | $F$ | 01 | 1001 | 0 | 10 | 1001 | $X$ | 11 | 1010 |
| 6 | 00 | 1001 | G | 01 | 1010 | $P$ | 10 | 1010 | Y | 11 | 1011 |
| 7 | 00 | 1010 | H | 01 | 1011 | $Q$ | 10 | 1011 | $Z$ | 11 | 1100 |
| 8 | 00 | 1011 | I | 01 | 1100 | $R$ | 10 | 1100 |  |  |  |
| 9 | 00 | 1100 |  |  |  |  |  |  |  |  |  |

In such decimal computers a decimal number is written into a word "as is," with no conversion required. Of course the resulting binary number is not a number at all, but a binary code. The arithmetic unit then handles 6 bits at a time, and is wired so as to produce the correct
results. For example, in octal-coded binary we would have

|  | Corresponding binary operation |  |
| ---: | ---: | ---: |
| Octal | as it would appear in computer words |  |

In decimal-coded binary we would have

Decimal

| 5 | 000 | 011 | 001 | 000 |
| ---: | ---: | ---: | ---: | ---: |
| +6 | +000 | 011 | 001 | 001 |
| 000 | 100 | 000 | 100 |  |

In a later chapter examples of decimal adders, etc., will be presented.
Note that a word that contains letters cannot be added to another word since addition is defined only for numbers. Also, an address must be denoted by pure numbers, not letters (for as we shall see in Chap. 4, we must be able to add to or subtract from the addresses). The letters can be used only for the operation code or for some letter constant.

The advantages of a decimal system are simply that no conversion need be made for numbers and that letters can be read into and out of the computer directly. However, the disadvantage of a decimal system is that it is difficult to write codes where the value of a particular single bit of a word has significance, as is necessary, for instance, in switch sensing; while there are methods for determining the value of some bit of the word, in general the bits are used in the computer in groups of six.

Example. As an illustration of a code in such a system, consider the three-address instructions of Table 3-9, where one decimal symbol is used for the operation code and three decimal digits are used for each address. Here $(\alpha)+(\beta) \rightarrow \gamma$ means, "The contents of $\alpha$ are added to the contents of $\beta$, and the sum is put into address $\gamma$," etc.

Table 3-9. Three-address Decimal Instructions

| Code | Operation | Meaning |
| :--- | :--- | :--- |
| $A$ |  |  |
|  | Add | $(\alpha)+(\beta) \rightarrow \gamma$ |
| $S$ | Multiply | $(\alpha) \cdot(\beta) \rightarrow \gamma$ |
| $S$ | Subtract | $(\alpha)-(\beta) \rightarrow \gamma$ |
| $D$ | Divide | $(\alpha) \div(\beta) \rightarrow \gamma$ |
| $C$ | Compare | If $(\alpha)>(\beta)$, take $\gamma$ |
| $P$ | Stop computer |  |

The code for the first of our examples is shown in Example 3-1f.
Example 3-1f. Decimal-coded Binary

| Address | Instruction |  |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ | $\beta$ | $\gamma$ |  |
| 000 | S | 007 | 007 | 007 | Take first instruction from 001 |
| 001 | M | 008 | 010 | 012 | Form $V_{0 y} t$ |
| 002 | M | 010 | 010 | 013 | Form $t^{2}$ |
| 003 | M | 013 | 009 | 013 | Form $g t^{2}$ |
| 004 | D | 013 | 011 | 013 | Form $1 / 2 g t^{2}$ |
| 005 | $S$ | 012 | 013 | 013 | Form $Y$ |
| 006 | $P$ | 000 | 000 | 000 | Stop computer |
| 007 |  |  |  |  |  |
| 008 | 0 | 000 | 001 | 000 | $V_{0 y}$ |
| 009 | 0 | 000 | 000 | 032 | $g$ |
| 010 | 0 | 000 | 000 | 053 | $t$ |
| 011 | 0 | 000 | 000 | 002 | 2 |
| 012 |  |  |  |  | $V_{0 y} t$ temporary |
| 013 |  |  |  |  | Temporary where final result is found |

## EXERCISE

(a) Recode the second of our illustrative examples in three-address decimal-coded binary.

## 3-11. Additional Topics

a. General Background. Read Arithmetic Numbers and the Art of Counting, in James R. Newman (ed.), "The World of Mathematics," vol. 1, pp. 418-453, simon and Schuster, Inc., New York, 1956.
$\therefore$ The Real Numbers. The axiomatic development of real numbers is one of the highlights of modern mathematics. A good description of this development is given by H. A. Thurston, "The Number System," pt. I, Interscience Publishers, Inc., New York, 1956.
c. The Division Algorithm. In Sec. 3-2 we used the reasonable result that, if $N$ and $q$ are positive integers, then there always exist a unique nonnegative integer $r$ less than $q$ and a unique integer $S$ such that

$$
\frac{N}{q}=S+\frac{r}{q} \quad 0 \leq r<q
$$

This is called the division algorithm. For a "proof," see G. Birkhoff and F. MacLane, "A Survey of Modern Algebra," pp. 1-20, The Macmillan Company, New York, 1948.
d. Infinite Decimals: Rational and Irrational Numbers. Observe that the result of converting 0.3 (decimal) into binary is .01001100110011 . . . Of course in a physical situation one might be told, for example, that 0.3 is good to two significant places,
i.e., it would be written as 0.30 ; then there would be no purpose in carrying the binary conversion certainly to more than, say, eight places, i.e., to 01001101 (why?). On the other hand, suppose that we consider 0.3 purely as a number; then we can never write its binary conversion precisely, for it is an infinite binary fraction. Of course we could write $0.3($ decimal $)=\frac{11 \text { (binary) }}{1010 \text { (binary) }}$ precisely. It is easy to tell by looking at 0.3 (decimal) that it can be written as $\frac{3(\text { decimal })}{10 \text { (decimal) }}$. But how could we tell directly by looking at $.010011001100 \cdots$ (binary) that it can be written as $\frac{11 \text { (binary) }}{1010 \text { (binary) }}$ ? This problem brings up the observation that there are two kinds of real numbers, rational and irrational. A rational number can be written as the quotient of two integers; an irrational number cannot be so written. The problem stated above thus resolves itself into the following: By looking at an infinite radical fraction (in a system of any radix $q$ ) how can rational numbers be distinguished from irrational numbers? For a further discussion of irrational numbers see Edward Kasner and James Newman, "Mathematics for the Imagination," pp. 65-111, Simon and Schuster, Inc., New York, 1940.
e. Computer Manuals. For a short description of both a four-address system (SEAC) and a three-address system (DYSEAC) see Computer Development at the National Bureau of Standards, NBS Circ. 551. For a two-address system see the Remington Rand 1103 computer manual, and for a one-address system see the IBM 704 computer manual.
f. Cardiac Computer. Using the Cardiac computer (see Exercise $b$ of Sec. 2-8) as a four-address system, compute the codes given in the examples of Secs. 3-4 and 3-5. Do the same for the three-, two-, and one-address coding examples given in Secs. 3-7 to 3-9.
g. Decision Processes. Decision processes require criteria by which the decisions in any particular case are made. If the criteria are sufficient for a particular set of decisions, then a computer can be coded to make them. In fact, it is remarkable that a single comparison instruction can always effectuate this process. For the criteria can be used by the computer to set up numbers representing the various alternatives, and comparison instructions can then choose between them. In recent years the analysis of decision-making processes has received much thought. The student will profit by reading, for example, J. D. Williams, "The Complete Strategyst," McGrawHill Book Company, Inc., New York, 1954. This deals with the theory of games, which is essentially a theory of value decisions or strategy. See also Herman H. Goldstine and John von Neumann, "Planning and Coding of Problems for an Electronic Computing Instrument," pt. II, vol. I, Institute for Advanced Study, Princeton, N.J., 1947; R. D. Luce and H. Raiffa, "Games and Decisions-Introduction and Critical Survey," John Wiley \& Sons, Inc., New York, 1957.

## CHAPTER 4

## PROGRAMMING FUNDAMENTALS

## 4-1. Introduction

In the previous chapter we have introduced the concept of an instruction in several different instruction systems. We have discussed in some detail the concept of a sequence of instructions and the significance of the order in which instructions are written. Now we turn to extended and more complicated codes, or sequences of instructions, that are often called programs. As we shall note in a future section, almost any computation requires a fairly intricate sequence of instructions. Although each individual instruction is simple enough, the total collection or sequence of instructions, the program, can become considerably involved.

The present chapter considers first recursion codes, or loops, and instruction modification (Sec. 4-2). These concepts, together with those developed in the previous chapter, comprise all the fundamental concepts necessary for coding and programming. The subsequent material simply amplifies and presents further details of these methods. The discussion of recursion codes leads naturally into a consideration of subroutines (Sec. 4-3). It is in the consideration of subroutines that the elements of automatic programming arise, as considered in detail in Chap. 5.

With the material on recursion codes and subroutines in mind, one can readily appreciate the importance of the large variety of possible instruction types that can be designed for a computer. In the previous chapter the definitions of instructions were kept as simple as possible so as not to interfere with the basic concepts presented there. However, we are now in a position to consider the many possible special-purpose instructions that prove so convenient in many coding situations. The method of presentation of instruction types (Secs. 4-4 and 4-5) is not the giving of precise definitions but rather concentration on the basic concepts involved and on the wealth of combinations and variations that can be obtained. In designing a computer the final definition of the instructions ultimately must be up to the engineer, because of technical electronic and logical design problems. Hence it is important for the engineer to understand the various ingredients that go into the make-up of various instruction types and the special purposes for which they are conceived.

To appreciate fully the significance of some of the instruction types, the engineer should see how they are used in specific codes. In Sec. 4-6 some special coding problems are considered; in each case some of the
special instruction types considered in the previous section can be used to full advantage. In almost all the problems considered, the specific codes are left for the student to write. However, in order to write these codes, the student is expected to define precisely those instructions he needs that best suit the purposes of the application. It is felt that the experience gained in defining instructions based on the principles of Secs. 4-4 and 4-5, and then using these instructions in a code, is one of the best possible ways for an engineer to gain flexibility and mastery of instruction design from a computational point of view.

Finally, in Sec. 4-7 the operation of the computer through the control panel is discussed. There the principles of communicating with the computer through the control panel are primarily considered.

## 4-2. Recursion Codes and Instruction Modification

Loops in the Flow Diagram. In Sec. 3-4 we considered the problem of determining the altitude at a time $t$ of a missile projected with an initial $y$ component of velocity $V_{0 y}$. A more realistic problem would be to determine the trajectory of the missile, i.e., the position of the missile, say, after each 10 sec of its flight. For such a problem we use a loop, or recursion code, i.e., a code which uses a certain set of instructions over again several times. For example, at time $t_{i}$ the $x$ and $y$ components of position will be

$$
\begin{aligned}
& x_{i}=V_{0 x} t_{i} \\
& y_{i}=V_{0,1} t_{i}-1 / 2 g t_{i}{ }^{2}
\end{aligned}
$$

where $V_{0 x}$ is the initial $x$ component of the velocity. To be concrete, suppose that $V_{0 x}=2,000 \mathrm{fps}, V_{0 y}=1,000 \mathrm{fps}$, and $g=32 \mathrm{ft} / \mathrm{sec}^{2}$. Then at time $t_{1}(=10 \mathrm{sec})$ we would have $x_{1}=20,000 \mathrm{ft}$ and

$$
y_{1}=10,000-1,600=8,400 \mathrm{ft}
$$

At time $t_{2}(=20 \mathrm{sec}) x_{2}=2,000 \times 20=40,000 \mathrm{ft}$,

$$
y_{2}=1,000 \times 20-16 \times 20^{2}=13,600 \mathrm{ft}
$$

At time $t_{3}(=30 \mathrm{sec}) x_{3}=2,000 \times 30=60,000 \mathrm{ft}$,

$$
y_{3}=1,000 \times 30-16 \times 30^{2}=15,600 \mathrm{ft}
$$

and so forth. During such a computation it is clear that the same formulas are used over again, each time increasing our $t_{i}$ by 10 sec . However, the computation should stop when the missile hits the ground, i.e., when $y_{i}$ is no longer positive. In our case it is easily seen that this is when $t=70$ and $y_{7}=70,000-16 \times 70^{2}=-8,400 \mathrm{ft}$. Table $4-1$ represents the final results, and Fig. $4-1$ is the flow chart of the process. In the flow chart we have introduced the $i$ notation, where $t_{i+1}$ represents the next time around and $i+1 \rightarrow i$ means that for the next iteration we replace the old $i$ th values with the new $(i+1)$ st values.

With this illustration it is seen that there are four basic ingredients to a recursion code. It must contain (1) a set of instructions, called the

Table 4-1. Computation of Trajectory of Missile

| $i$ | $t_{i}$ | $x_{i}$ | $y_{i}$ |
| :---: | :---: | ---: | ---: |
| 1 | 10 | 20,000 | 8,400 |
| 2 | 20 | 40,000 | 13,600 |
| 3 | 30 | 60,000 | 15,600 |
| 4 | 40 | 80,000 | 14,400 |
| 5 | 50 | 100,000 | 10,000 |
| 6 | 60 | 120,000 | 2,400 |
| 7 | 70 | 140,000 | $-8,400$ |

iteration instructions, that are to be reused; (2) another set of instructions that modifies the original set each time around; (3) a set of instructions, often called a tally, that determines when to exit, or break out of the loop, and appropriately notifies the computer; and (4) a set of instructions that sets up the initial conditions and starts the loop. In addition a recursion code often contains (5) a set of instructions that resets the loop so that it may be used again by the computer at some future time. A generalized loop can be indicated by the flow diagram of Fig. 4-2.

Sometimes the tally consists of instructions determining whether or not the result of each iteration is smaller than some given number, as occurs often in function computations; or the tally may just count the


Fig. 4-1. Flow chart for computation of missile trajectory.


Fig. 4-2. Flow chart of generalized loop.
number of iterations until the desired number have been accomplished. As an example of the former tally, consider the computation of $\sqrt{N}$ to within an error of $\epsilon$ by the following process (see Fig. 4-3): First note that $\sqrt{N}$ is the $x$ (and the $y$ ) coordinate where the curves $x=y$ and $N=x y$ intersect. We approach this point by successive approximations starting from ( $x_{0}, y_{0}$ ), where $x_{0}=N, y_{0}=1$, moving along a perpendicular to $x=y$, dropping an altitude to point ( $x_{1}, y_{1}$ ) on $N=x y$, moving from this


Fig. 4-3. Computation of $\sqrt{ } \bar{N}$.


Fig. 4-4. Flow chart for computation of $\sqrt{N}$.
point along a perpendicular to $x=y$, dropping an altitude to point ( $x_{2}, y_{2}$ ) on $N=x y$, and so forth. The next point ( $x_{i+1}, y_{i+1}$ ) is found in terms of the present point ( $x_{i}, y_{i}$ ) as follows:

$$
x_{i+1}=\frac{x_{i}+y_{i}}{2} \quad y_{i+1}=\frac{N}{x_{i+1}}
$$

(see Fig. 4-3). When $x_{i}-y_{i} \leq \epsilon$, the desired accuracy has been obtained. The flow diagram for this loop is shown in Fig. 4-4. A symbolic code for this appears in Example 4-1.

Example 4-1. The Square-root Routine

| Address | Operation | $\alpha$ | $\beta$ | $\gamma$ | Remarks |
| :--- | :--- | :--- | :---: | :---: | :--- |
| 000 |  |  |  |  |  |
| 001 | Divide | $N$ | $x$ |  | $y$ |
| 002 | Subtract | $y$ | $x$ | $\Delta$ | $y_{i+1}=\frac{N}{x_{i+1}}$ |
| 003 | Compare | $\Delta$ | $\epsilon$ | 005 | $x_{i+1}-y_{i+1}$ |
| $\Delta: \epsilon$ |  |  |  |  |  |
| 004 | Stop |  |  |  | $x=\sqrt{N}$ |
| 005 | Add | $x$ | $y$ | $x$ | $\} x_{i+1}=\frac{x_{i}+y_{i}}{2}$ |
| 006 | Divide | $x$ | 2 | $x$ |  |
| 007 | Compare | 1 | 0 | 001 | $N$ |
| 010 |  |  |  |  | $x$ |
| 011 |  |  |  |  | $y$ |
| 012 |  |  |  |  | $\epsilon$ |
| 013 |  |  |  |  | 2 |
| 014 |  |  |  |  | 1 |
| 015 |  |  |  |  | 0 |
| 016 |  |  |  |  |  |

As an example of the latter tally, consider a code that computes $x^{n}$, where $x$ and $n$ are known. Here, after each multiplication, 1 is added
to the tally temporary, and comparison is made with the constant $n$. A symbolic code for this is given in Example 4-2. Note that initially the contents of the $x^{n}$ temporary must be 1 , and the contents of the tally temporary must be 0 (why?).

Example 4-2. $x^{n}$ Routine

| Address | Operation | $\alpha$ | $\beta$ | $\gamma$ | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 000 |  |  |  |  |  |
| 001 | Multiply | $x$ | $x^{n}$ temporary | $x^{n}$ temporary | Form partial product |
| 002 | Add | 1 | Tally temporary | Tally temporary | Adjust tally temporary |
| 003 | Compare | $n$ | Tally temporary | 001 |  |
| 004 | Stop |  |  |  |  |
| 005 |  |  |  |  | $x^{n}$ temporary |
| 006 |  |  |  |  | Tally temporary |
| 007 |  |  |  |  | $n$ |
| 010 |  |  |  |  | $x$ |
| 011 |  |  |  |  | 1 |

The importance of the recursion code cannot be overemphasized. In fact, as we shall see in a future section, special instructions are included in many computers to aid the coding of such codes.

Instruction Modification. One of the fundamental concepts upon which modern computers are based is that of instruction modification, i.e., having a program automatically modify itself. Let us illustrate how instructions can modify instructions by means of the following examples:

Suppose that, during the course of computing for a problem, the computer often needed to know the value of the binomial distribution function $p(x)=\binom{100}{x}(0.1)^{x}(0.9)^{100-x}$, where $\binom{100}{x}$ is the binomial coefficient, for $x=1,2,3,4$, or 5 . One method for performing such a calculation is simply to write a table into the memory of the computer and "look up" the value each time it is needed.

Suppose such a table was written into addresses 001 to 005 ; i.e., in address 001 is located $10^{4} p(1)$, in address 002 is located $10^{4} p(2)$, . . . , in 005 is located $10^{4} p(5)$. Note that we must scale the values of $p(x)$, since $p(x)$ is less than 1 (for all values of $x$ ) but our computer interprets all numbers as greater than 1. Of course the numbers in addresses 001 to 005 will be written in octal.

Suppose also that the value of $x$ (which for this problem can only be $1,2,3,4$, or 5 ) is found in address 006 and that the result, namely, $10^{4} p(x)$, corresponding to this value, is to be put into 007 . To perform this task, the code must have a set of instructions that will transfer the contents of one of the addresses $001,002,003,004$, or 005 into 007. Using the one-address system devised in Sec. 3-9, these instructions
(where the contents of 010 is the constant zero) are:

| Operation | $\alpha$ | Remarks |
| :---: | :---: | :--- |
| 42 | 010 | Clear accumulator |
| 53 | $?$ | Put contents of ? into accumulator |
| 52 | 007 | Transfer (acc) into 007 |

If the contents of 006 were 1 , then 001 should replace the $?$; if $(006)=2$, then 002 should replace the ?; etc. The problem therefore resolves itself into modifying the instruction with the ? so that ? is replaced


Fig. 4-5. Flow chart of table look-up routine, indicating reset instructions.
by the contents of 006 . One way of doing this is to write the instruction first as 53000 . Then add (006) to it, the result being 53001 , etc.

Example 4-3. Binomial-coefficient Look-up Routine

| Address | Instruction |  | Remarks |
| :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ |  |
| 001 | 00 | 003 | $10^{4} p(1)$ |
| 002 | 00 | 020 | $10^{4} p(2)$ |
| 003 | 00 | 073 | $10^{4} p(3)$ table |
| 004 | 00 | 237 | $10^{4} p(4)$ |
| 005 | 00 | 523 | $10^{4} p(5)$ |
| 006 | 00 | 004 | $x=4($ or $1,2,3,5)$ |
| 007 |  |  | $10^{4} p(x)=$ result |
| 010 | 00 | 000 | 0 constant |
| 011 | 42 | 010 | Start here, and clear accumulator) |
| 012 | 53 | 006 | Put (006) into accumulator $\}$ Set up ? instruction |
| 013 | 51 | 015 | Add (acc) to ? instruction $\quad$ ) |
| 014 | 42 | 010 | Clear accumulator |
| 015 | 53 | ? | Now do ? instruction [(015) reads 53004 by time code progresses this far] |
| 016 | 52 | 007 | Transfer (acc) into 007 |
| 017 | 42 | 010 |  |
| 020 | 53 | 023 | Put instruction constant into accumulator ${ }_{\text {R }}^{\text {Reset }}$ instruction |
| 021 | 52 | 015 | Transfer (acc) into 015 ) instruction |
| 022 | 44 |  | End here-jump to another part of program |
| 023 | 53 | 000 | Instruction constant |

But after the code has been used, an additional set of instructions is needed to reset it back to 53000 . The flow diagram is as in Fig. 4-5.

The entire code, then, is as in Example 4-3.
Instruction Modification in Loops. Frequently instruction modification is necessary for the coding of loops. For example, suppose that it is desired to form the sum of a long column of numbers which are located in consecutive addresses of the computer memory from address 030 to


Fig. 4-6. Flow chart for instruction modification.
077. We could use the same add instruction for the successive additions provided that the $a d d$ instruction were modified before each addition so as to add the contents of the next successive address to the partial sum each time round. The flow diagram is as in Fig. 4-6 and the code as in Example 4-4. The arrows in Fig. 4-6 indicate the path of the computer through the instructions. The sum is formed in address 001. The student should be sure to understand the purpose of each of the five sets of instructions of Example 4-4.

Loops within Loops. As an example of multiple loops, or loops within loops, consider the computation of a table of $\sin x$ by means of the infinite series

$$
\sin x=x-\frac{x^{3}}{3!}+\frac{x^{5}}{5!}-\frac{x^{7}}{7!}+\frac{x^{9}}{9!}-\frac{x^{11}}{11!}+\cdots
$$

for each $1 / 100$ radian from 0 to $\pi / 2$, to eight decimal places (see Sec. $6-11)$. First we would have a loop that formed $x^{n} / n!$ by multiplying a partial product successively by $x / P_{i}$ (loop $A$ ); then we would need a loop that adds or subtracts this result to or from the partial sum and increases

Example 4-4. Column-adding Routine

| Address | Instruction |  | Remarks |
| :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ |  |
| 000 | 44 | 002 | Start at 002 |
| 001 |  |  | Final sum (temporary partial sum) |
| 002 | 42 | 024 | Clear accumulator $\quad$ initiate process: put first |
| 003 | 53 | 030 | Put (030) into accumulator initiate process: put first |
| 004 | 52 | 001 | Put (acc) into 001 number into partial-sum cell |
| 005 | 42 | 024 | Clear accumulator ${ }^{\text {a }}$ instruction |
| 006 | 53 | 025 | Increase $\alpha$ of $a d d$ instruction by 1$\} \begin{aligned} & \text { instruction } \\ & \text { modification }\end{aligned}$ |
| 007 | 51 | 012 |  |
| 010 | 42 | 024 | Clear accumulator |
| 011 | 53 | 001 | Put partial sum in accumulator add next number |
| 012 | 53 | 030 | Add instruction $\quad$ to partial sum |
| 013 | 52 | 001 | Put partial sum into its temporary) |
| 014 | 42 | 024 | Clear accumulator |
| 015 | 53 | 012 | Put (012) into accumulator |
| 016 | 54 | 026 | Subtract (026) from accumulator tally |
| 017 | 43 | 005 | $53077>(012)$ ? <br> Yes: add another number <br> No: sum is complete |
| 020 | 42 | 024 | Clear accumulator |
| 021 | 53 | 027 | reset and stop computer |
| 022 | 52 | 012 | Put 53030 into 012 |
| 023 | 60 | 000 |  |
| 024 | 00 | 000 | 0 constant |
| 025 | 00 | 001 | 1 constant |
| 026 | 53 | 077 | 53077 constant |
| 027 | 53 | 030 | 53030 constant |
| $\left.\begin{array}{l}030 \\ \ldots \\ 077\end{array}\right\}$ |  |  | Numbers to be added |

$n$ by 2 until the partial sum becomes correct to eight significant figures (loop $B$ ); and finally we need a loop that increases $x$ by 0.01 and continues to compute the next value of $\sin x($ loop $C)$. The flow diagram for this process appears in Fig. 4-7.

## EXERCISES

(a) Code the flow diagram of Fig. 4-1 for a one-address system as described above.
(b) The symbolic codes of Examples 4-1 and 4-2 are incomplete in that they do not reset the computer for additional runs. Complete these codes accordingly and assign specific addresses.


Fig. 4-7. Flow chart of loops within loops. The notation $P_{i}+1 \rightarrow P_{i}, n_{j}+2 \rightarrow n_{j}$, and $x_{k}+0.01 \rightarrow x_{k}$, etc., is often used to indicate that in the $(i+1)$ st iteration $P_{i+1}=P_{i}+1, n_{j+1}=n_{j}+2$, and $x_{k+1}=x_{k}+0.01$, etc.

If $x$ is found in 001 and $n$ is in 002 , draw flow diagrams and write codes that will compute the following functions using the one-address system and also the threeaddress system as described above:
(c) $x^{n} / n!$. [Hint: Form a partial product by multiplying by $x /(n-i)$.]
(d) $e^{x}=1+x+x^{2} / 2!+x^{3} / 3!+\cdots$. (Hint: Compute enough terms so that $x^{n} / n!<\epsilon$; this test will tally the breaking of the loop.)
(e) The binomial coefficient $n!/ x!(n-x)$ !.
( $f$ ) The first moment of the binomial expansion, namely,

$$
u=\sum_{x=0}^{n} x \frac{n!}{x!(n-x)!} p^{x} q^{n-x}
$$

(g) Write a routine that forms the sum of the squares of numbers found in addresses 030 to 077.
(h) Write a routine that puts the numbers found in 030 to 077 in numerical order. Hint: Successively interchange locations of numbers in adjacent addresses if they
are not in order; keep track of the number of interchanges each time through; when no interchanges are necessary, then the numbers are in order; that is, for example,

| 1st time through: | ¢ | 从 | $x$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 4, 2, 3, 1 | 2, 4, 3, 1 | 2, 3, 4, 1 | 2, 3, 1, 4 |
|  | $\bigcirc$ | め | $\bigcirc$ |  |
| 2d time through: | 2, 3, 1, 4 | 2, 3, 1, 4 | 2, 1, 3, 4 | 2, 1, 3, 4 |
|  | ${ }_{2,1,3,4}$ | 1, 2, 3, 4 |  |  |
| 3d time through: | $\sim$ | $\bigcirc$ | $\bigcirc$ |  |
| 4th time through: | 1,2, 3, 4 | 1, 2, 3, 4 | 1, 2, 3, 4 | 1,2,3,4 |

## 4-3. The Subroutine

Use of a Subroutine. A subroutine is a subcode that may be used many times during the computation of a program but is written only once in the whole code. As the computer proceeds down the main program, the control will occasionally jump to this subroutine and then, after doing the subroutine, will jump back to the main program where it left off. This detour from the main program through the subroutine may occur several times during the computation of the program. Hence a subroutine must have an entrance, a way of getting into it, and an exit, a way of getting out of it. Each time an entrance is made to a subroutine, some initial conditions must be set up that are characteristic of the place in the main program from which the entrance was made. For instance, if the subroutine calculates some function, the initial values of the independent variables at that point in the main program must be given to the subroutine. In addition, as an entrance to a subroutine is made, the exit must be set up; i.e., the subroutine must be told where to transfer control back to the main program. For each time the subroutine is used, its exit is usually to some different part of the main program. Hence, in order to use a subroutine, the coder must know (1) the entrance, i.e., the address of the first instruction; (2) the addresses of the temporaries in which the initial conditions are to be set up; (3) the addresses of the temporaries whose contents will be the results of the subroutine computation; and (4) the exit, i.e., the address of some jump instruction that is to be preset (when entering the subroutine) so that, when the computation of the subroutine has been completed, the computer will transfer control back to the proper address of the main program.

Consider, for instance, the flow diagram in Fig. 4-8, which illustrates the setting up of the initial conditions and different exits of the subroutine. The $A$ in the circle is a connector and of course means that the program jumps to the subroutine at that point. The $B$ connector is called a variable connector; i.e., it indicates that the program jumps either to $B_{1}$ or to $B_{2}$, depending on how the "variable" connector is set. When


Fig. 4-8. Flow chart for setting up initial conditions and different exits of a subroutine.
we say that $B=B_{1}$, we mean that the $B$ connector is set so that it will go from $B$ to $B_{1}$; and when we say that $B=B_{2}$, then the $B$ is set to go from $B$ to $B_{2}$. The rest of the flow diagram is self-explanatory but should be studied carefully by the student.

Example. As a specific example of the use of subroutines, consider a program which is to compute the radiation intensity $S$ of an antenna at a point in space as a function of the directional angles $\theta$ and $\varphi$ and the
radius $R$ given by the equation $\dagger$

$$
S=\frac{30 I_{0}{ }^{2}}{2 \pi R^{2}}\left[\frac{\cos \left(\frac{\pi}{2} \cos \theta\right)}{\sin \theta} \frac{\sin \left(\frac{n \pi}{2} \sin \theta \cos \varphi\right)}{\sin \left(\frac{\pi}{2} \sin \theta \cos \varphi\right)}\right]^{2}
$$

where $n=$ a given integer
$I_{0}=$ a known constant
Now the sine and cosine functions are evaluated by means of their power series. Since these functions appear several times as functions of different arguments, it would be wise to use their respective power-series codes as subroutines. Figure 4-9 is a flow chart for the calculation of $S$ and indicates the use of the subroutines.

This flow diagram can be used to illustrate some of the details involved in using subroutines. For example, suppose that the first instruction of the $\cos x$ subroutine is located in address 700. Then, using a one-address system, the jump instruction to this subroutine would be 44700 , which completes the first step in using a subroutine. The second step is to set up the exit from the subroutine. One method is to have in address 677 (the address preceding 700) a jump instruction 44000 , where $\alpha$ is to be designated. Suppose that the main program will continue after the subroutine, from address 017 . Then we would want (677) to be 44017. Then at the end of the subroutine would appear a jump to 677 , whence the computer will jump to 017 . To set up (677), the main program would put the constant 44017 into the accumulator and then perform a transfer into 677. Another method of accomplishing this return jump to the main program is through some sort of special instruction designed for this purpose. In this case the jump to the first instruction, for example, 44700 , automatically memorizes the address of this instruction in some counter or index register. Then a special jump instruction is placed into address 677 that looks at this counter or register and jumps back to the main program.

For the third step in using a subroutine the main routine must somehow tell the subroutine the values of the initial data, i.e., the independent variables. For this purpose a common agreement is made between the person who writes the subroutine and the user of the subroutine about certain addresses set aside for this purpose. For example, suppose that address 676 were agreed upon to be the address of the initial value of $x$ in the $\cos x$ subroutine. Then, before jumping to the subroutine, the main program would transfer the initial value of $x$ into 676 for the use of the subroutine. Similarly an agreement might be made that the final computed value of $\cos x$ be placed in 675 ; when the computer exits from the subroutine back to the main program, the main program first transfers (675) to some temporary that the main program uses. Of course, there
$\dagger$ See, for example, J. A. Stratton, "Electromagnetic Theory," p. 451, eq. (53), McGraw-Hill Book Company, Inc., New York, 1941.


Fig. 4-9. Flow chart for computation of radiation intensity.
is an alternative method for performing these two tasks. The main program could first tell the subroutine where the initial value of $x$ is located and where the final computed value of $\cos x$ should be placed, and the subroutine could include the transfer instructions. In such a case the instructions of the main program that "tell" the subroutine would do so by modifying some instructions of the subroutine.

Library of Subroutines. As illustrated by the example, several subroutines may be used in one main program. In fact it is found that many common subroutines are used quite often, such as $\sin x, \cos x, e^{x}, \sqrt{x}$, etc. Hence it often becomes profitable to have a library of subroutines available to the programmer, stored at all times in some part of the computer memory. There would also be some catalogue kept outside the computer that the programmer can consult when he wants to use a subroutine. This catalogue would tell where each subroutine is located and all pertinent data about how to use it, such as where to put the initial values of the independent variables, where the computed values of the dependent variables are found, etc. In addition, as we shall discuss in a later section, automatic programming aids are devised to make such a library of subroutines easier to use.

## EXERCISES

Construct a library of subroutines, using our three-address system given above, as follows:
(a) Write a subroutine for $\sqrt{x}$ for your library.
(b) Write a subroutine for $x^{m} / m$ ! for your library.
(c) Write a subroutine for $\sin x$ for your library. (HINT: This subroutine will itself use subroutine $b$.)
(d) Write a subroutine for $\cos x$ for your library.
(e) Write a manual describing how to use your library of subroutines.
(f) Code the example given in this section, using your library of subroutines.

## 4-4. Instruction Types

In this section we present many of the important kinds of instructions that are found in modern digital computers. The object is to describe the concepts upon which the various kinds of instruction are based rather than specific details of the instructions themselves. The concepts are chosen from those which are most commonly used. Instructions based on these concepts may take many different forms in the many different computers. For purposes of clarity in this presentation these instruction concepts have been classified into six major categories: (1) the use of auxiliary bits in an instruction; (2) arithmetic instructions; (3) logical and bit-handling instructions; (4) decision instructions; (5) recur-sion-aiding instructions; (6) read and write instructions. Although there is some overlapping, it is most convenient to consider each instruction as falling into one, and only one, of these categories.

1. Auxiliary Bits. Auxiliary bits are bit positions that are included in the format of the instruction words of a particular computer, but they are not part of the operation code or the addresses. Two common uses of such bits are (a) to halt the computer or to make the program jump to some standard memory location, called breale points, and (b) to indicate relative addresses-both of which will now be described.
a. break points. As was pointed out above, the "sign" bit is an auxiliary bit. The sign bit can be given meaning for instructions as follows: if it is 0 , the computer continues to compute as usual; if it is 1 , then the computer halts. Important use is made of such a system in detecting errors in a program. Suppose that a coder were running a program on a computer for the first time; he might want to stop the computer at intermediate stages in the program to see whether or not the code were correct up to those points. In order to do this, he would put 1 in the sign bits of those instructions at which he wants to stop the computer so that he could examine the partial results. An alternative to this procedure, which serves the same purpose, is to have the computer take the next instruction from a standard, predetermined location in the memory whenever a 1 appears in the sign bit of an instruction. At the standard position a special code might be located that can do various things to aid the coder detect errors and correct this code.
$b$. relative addresses. Another important use for auxiliary bits is concerned with relative addresses. Relative addresses are associated with so-called relative counters, sometimes called index registers, and with auxiliary bits. A relative counter is a very special memory cell or register that can contain only a single address; i.e., it is a "short" memory cell. The computer must also have special instructions that can put a number into such a relative counter, add to the number in the relative counter, etc. Such instructions will be considered later in this section.

An address appearing in an instruction is said to be interpreted "relative" to a counter if the computer, instead of considering the contents of the address indicated, considers instead the contents of the word whose address is the sum of the counter reading and the indicated address. For example, if the index register read 002 and the address in the instruction were 053 , then the computer would consider the contents of

$$
002+053=055
$$

The role of the auxiliary bits in connection with relative addresses is as follows: The auxiliary bits of an instruction can indicate whether an address is to be considered relative or not. For example, consider a three-address instruction format that has three auxiliary, i.e., extra, bits on the right:

| Operation | $\alpha$ | $\beta$ | $\gamma$ | Auxiliary bits |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: |
|  |  |  |  | $P 2$ | $P 1$ |  |

Suppose that there is one relative counter. Then the following meaning can be attached to these bits: If $P 1$ is 1 , then $\gamma$ is to be interpreted as relative to the counter; if $P 2$ is 1 , then $\beta$ is relative; if $P 3$ is 1 , then $\alpha$ is relative. Hence, if the auxiliary bits were 101 and the instruction were "add," then the contents of " $\alpha+$ (counter)" would be added to the contents of $\beta$ and the result put into the address " $\gamma+$ (counter)."

The use of such relative addresses is to aid the coding of iterations, or loops. As illustrated by some of the problems of the previous sections, each time around a loop it is often necessary to increase some addresses of the main set of instructions by 1 (or some other integer). In such cases a set of instructions modifying the instruction must precede the main set of instructions. But with relative addresses all that need be done is to increase the counter by 1 (or whatever is the necessary integer for a particular case) by means of the counter-setting instruction. One variation of this system is to have several such relative counters or registers, which can be used in many different ways. For example, an instruction preceding the use of relative addresses can determine to which counter the addresses are to be considered relative. Or the addresses may be considered relative to the sum or some other function of the numbers in the counters.
2. Arithmetic Instructions. These instructions can be divided into four classes: add, subtract, multiply, and divide. One of the important concepts that appears in arithmetic instructions is the automatic floating decimal point. As was seen in some of the above examples and problems, in ordinary arithmetic instructions the coder was limited to handling numbers within the range of the word length. For example, if the word length is 15 bits plus a sign bit, and if all numbers are interpreted as being nonfractional, that is, if the binary point is considered to be on the right, then only integers that lie between 0 and $2^{15}$, or -1 and $-2^{15}$, can be handled by the computer. Obviously there must be some way out of such a totally unacceptable situation. The method is to multiply all numbers involved in a code by an appropriate scaling factor so that they fall within the desired range during the computer computations. Of course the results put out by the computer must be readjusted to their actual values. However, it suffices to mention here that scaling presents more work for the coder and is a disadvantage. Many computers avoid this disadvantage by having a so-called floating point for arithmetic operations.

In computers with floating-point arithmetic operations a number is memorized in a word composed of two parts: a mantissa, which contains the significant figures of the number, and an exponent. For example, one computer that has a 45 -bit word uses 36 bits for the significant figures and their sign and 9 bits for the exponent and its sign. Hence this computer can handle numbers whose absolute values are as large as $\left(2^{35}-1\right) \times 2^{255}\left(\right.$ since $\left.2^{8}=256\right)$ or as small as $2^{-255}$, that is, numbers within this range with no more than 35 significant bits. A range
such as this covers most cases that usually occur and hence relieves the coder of all scaling considerations.

The terms normalized and unnormalized are often used in connection with floating-point arithmetic operations. These terms are concerned with the problem of determining the appropriate exponent of the result of an operation. The result of an operation is called normalized if the exponent is so adjusted that the leftmost bit of the mantissa is a unit bit. This of course maximizes the number of significant figures that can be recorded in a word. A computer operation that presents normalized results is called normalized; e.g., we would say add-normalized. As an example, suppose that a computer had a 24 -bit ( 8 octal position)

111110101100010010001010011100110000000000000000 After $\begin{array}{lllllllllllllllll}7 & 6 & 5 & 4 & 2 & 2 & 1 & 2 & 3 & 4 & 6 & 0 & 0 & 0 & 0 & 0 & \text { move }\end{array}$ Fig. 4-10. Normalized and unnormalized mantissa.
mantissa and we multiply-normalized the (octal) numbers (with octal exponent): $.00033333 \times 2^{6}$ by $.04444444 \times 2^{3}$. The unnormalized result (double length) is $.0000175304424714 \times 2^{11}$. Of course this is a binary number in the computer, and the problem is to determine that exponent which will move the binary number to the left until a unit bit appears in the leftmost position. The number of bit positions the mantissa will have to be moved to the left in our example is $3 \times 4+2$ [where $3 \times 4$ is the number of bit positions corresponding to four zeros; and since 1 (octal) is 001 (binary), a move two further positions to the left is necessary]. Figure $4-10$ illustrates the binary and octal forms of the double-length mantissa before and after the move.

The final normalized result will therefore be $.76542212 \times 2^{-5}$ [where $11-(3 \times 4+2)=-5$ ]. Of course the computer will do this automatically and will display only the "single-length" result. (See below for further discussion of single- and double-length results of multiplication.) Note that, if the computer binary point is understood to be to the right, the above multiplication would be

$$
00033333 \times 2^{-22} \times 04444444 \times 2^{-25}=00001753 \quad 04424714 \times 2^{-47}
$$

The product could here be normalized by shifting right

$$
(3 \times 3)+1=12 \text { octal places }
$$

to give $76542212 \times 2^{-35}(-47+12=-35)$. If the product were
normalized by shifting left, dropping the last eight places would be equivalent to multiplying by $2^{-30}$ and the exponent would have to be corrected accordingly: $-47-[(3 \times 4)+2]+30=-35$.

When an unnormalized operation is defined, the method for determining the exponent must be clearly stated.

We can now return to a description of the kinds of arithmetic instructions. Consider "add" first.
a. add. 1. Ordinary addition instruction, as described in previous sections.
2. Floating addition-unnormalized. The exponent of the result will be that of the largest exponent of the two operands.
3. Floating addition-normalized. The exponent of the result will be adjusted so that the most significant bit of the number is a unit.
4. Absolute-value " $a d d$." In a two-, three-, or four-address system the result would be $=|(\alpha)|+|(\beta)|$.
5. Add into accumulator. In a one-address system (acc) $+(\alpha)$ is put into the accumulator.
6. Add into memory. In a one-address system (acc) $+(\alpha)$ is put into $\alpha$.
7. Add relative. The instruction code itself tells that the address is to be considered relative to some relative counter.
8. Add with overflow check. If the sum is greater than the largest number that can be stored in a word, then overflow is said to have occurred. If overflow occurs, then the computer is to break the sequence of instructions; e.g., in a three-address system, if no overflow, then take next instruction; if overflow, take $\gamma$.
9. Multiply-add. In a two-address system, form $(\alpha) \cdot(\mathrm{acc})+(\beta)$, and put result into accumulator.
10. Partial add- $\alpha$ address. In a two or more address system, only the $\alpha$ portion of the words is added. Similarly there are add $-\beta,-\gamma$ address instructions.
b. subtract. The kinds of subtract instructions are analogous to the kinds of add instructions but include also:
11. Change sign of register. This is not a subtract instruction but only changes the sign of the accumulator.
c. multiply. Before describing the kinds of multiply instructions we must first describe briefly how multiplication takes place in an arithmetic unit. First note that, if an $n$ digit is multiplied by an $m$ digit number, the result can have as many as $n+m$ digits. In a computer, therefore, the result of a multiplication can contain twice as many bits as appears in a word. Hence there are usually two registers in the arithmetic unit (or one double-word-length register) to record the result of the multiplication. If a word has $m$ bits, then the least significant $m$ bits (which are found in one of the registers, called the minor register) are called the minor multiplication result, while the rest of the bits are called the major multiplication result (and are found in the other register, called the major register).

For example, if we consider a 24 -bit ( 8 octal position) word, and multiply 00033333 by 04444444 , we obtain as a result 0000175304424714. Here 00001753 is the major product, and 04424714 is the minor product.

1. Regular multiplication. Leaving both major and minor results in the registers.
2. Major multiplication-unrounded. The memorized result is the major multiplication result.
3. Major multiplication-rounded. The memorized result is the major multiplication result with a least significant unit added to the major result if the most significant bit of the minor multiplication result is a unit. If the multiplication is normalized also, the normalization is done first, then the rounding.
4. Floating multiplication-unnormalized. The exponents are added, and the mantissas are multiplied.
5. Floating multiplication-normalized. After the multiplication the product is shifted and the sum of the exponents adjusted so that the most significant bit is a unit.
6. Rounding only. This is not a multiplication instruction, but the number in the major register is rounded with respect to the number in the minor register.
d. Divide. In dividing, the quotient appears in the major register, the remainder in the minor register. This brings up some variations in the divide instruction.
7. Quotient divide. The quotient is the memorized result.
8. Remainder divide. The remainder is the memorized result.
9. Quotient divide-rounded.
10. Floating divide-unnormalized.
11. Floating divide-normalized.
12. Divide with overflow check on quotient.

## EXERCISES

(a) Consider the example illustrated by Fig. 4-5. Code this in a three-address system in which the instruction format includes three auxiliary bits as described in Sec. 4-4, under Relative Addresses. Assume a counter-setting instruction that sets the counter to the number $\alpha$ and takes the next instruction from $\gamma$ (here $\beta$ is not used).
(b) What would a counter-setting instruction be in a one-address system?
(c) Code the same problem as in (a), using a one-address system where the instruction format has a single auxiliary bit.
(d) Find the unnormalized and normalized sum of $77770000 \times 2^{5}$ and $00007777 \times 2^{6}$ (where, of course, the numbers are in octal).
(e) Find the unnormalized difference of $00007777 \times 2^{6}$ and $77770000 \times 2^{5}$.
(f) For the numbers $77770000 \times 2^{5}$ and $00007777 \times 2^{6}$ find:

The unnormalized major product, unrounded.
The unnormalized major product, rounded.
The normalized major product, unrounded.
The normalized major product, rounded.
The unnormalized minor product.
The normalized minor product.

## 4-5. Instruction Types (Continued)

3. Logical and Bit-handling Instructions. These instructions are used for two main purposes. First they are used to modify instructions; second they are used when it is desired to find whether the bit in a $P i$ position is zero or a unit, as is often necessary when bits represent switch inputs in a machine.
a. logical arithmetic. 1. Logical addition. There is no carry, and the bits in the corresponding positions of the two operands are "added" according to the rule $1 \pm 1=1,1 \pm 0=1,0 \pm 1=1,0 \mid \pm 0=0$. For example,

$$
\begin{array}{lll}
\text { Logical }+ & 0101 & A \\
& \underline{0011} & B \\
& 0111 & A \pm B
\end{array}
$$

which can, of course, be generalized to a word of any number of bits in length.
2. Logical multiplication. Similar to logical addition except that $1\lfloor 1=1,1 \downharpoonright 0=0,0\lfloor 1=0,0\lfloor 0=0$. For example,

| Logical $\times$ | 0101 | $A$ |
| :--- | :--- | :--- |
|  | $\underline{0011}$ | $B$ |
|  | $\underline{0001}$ | $A[B$ |

which can be generalized as above.
3. Logical ring add (or logical inequality). Similar to logical addition, except that $1|\neq 1=0,1| \neq 0=1,0\lfloor 1=1,0 \mid \neq 0=0$. For example,

$$
\begin{array}{lll}
\text { Logical ring }+ & 0101 & A \\
& \underline{0011} & B \\
& A \neq B
\end{array}
$$

which can be generalized as above.
4. Logical compare (or logical equality). Similar to logical addition, except that $1|=1=1,0|=0=1,1|=0=0,0|=1=0$. For example,

$$
\begin{array}{lll}
\text { Logical compare } & 0101 & A \\
& \underline{0011} & B \\
& A\lfloor=B
\end{array}
$$

which can be generalized as above.
5. Complement. Units are changed to zeros, and zeros to units; e.g., if $(\alpha)=0101$, the complement of $(\alpha)$ is 1010 .
6. Extract. For a four- or three-address instruction, where a bit ot ( $\alpha$ ) is a unit, replace the corresponding bit of ( $\gamma$ ) with the corresponding
bits of ( $\beta$ ). For example,

| $(\alpha)$ | 000 | 111 | 111 | 000 |
| ---: | :--- | :--- | :--- | :--- |
| $(\beta)$ | 010 | 001 | 101 | 110 |
| $(\gamma)$ | 011 | 101 | 110 | 010 |
| 101 |  |  |  |  |

7. Odd-even extractor (used for decimal computers). Replace those digits of ( $\gamma$ ) which correspond (in position) to odd digits of ( $\alpha$ ) with the corresponding digits of ( $\beta$ ). For example,

| $(\alpha)$ | 222 | 555 | 793 | 246 |
| ---: | :--- | :---: | :---: | :---: |
| $(\beta)$ | 134 | 682 | 304 | 765 |
| $(\gamma)$ | 867 | 524 | 116 | 243 |
| $(1076$ |  |  |  |  |
| Result | 867 | $\boxed{5} 682$ | 304 | 243 |

b. Shift instructions. 1. Right shift. The whole ( $\alpha$ ) is shifted to the right by the number of positions specified in the instruction. If the shift is $n$ positions, the effect is the same as multiplying by $2^{-n}$. Those bits which run off the right end of the word are lost; those which come into the left end are zeros.
2. Left shift. Like the right shift, but in the other direction, i.e., like multiplying by $2^{n}$.
3. Circular shifts. Shifts where the bits that go off one end come back at the other as if the ends of the words were connected together. (These are also called "end-around shifts.")
4. Left significant shift. Shift till there is a unit in the most significant place. This differs from the above shift instructions in that the number of positions to be shifted is not given by the instruction but is determined during the operation. The number of positions shifted is often recorded in $\beta$; the shift is performed in the accumulator for a one-address system.
4. Decision Instructions. When a flow chart of a program comes to a branch point, some form of decision instruction must be used to determine which branch should be taken. As far as the segmented execution of the instructions in a program is concerned, a branch point means that the program either will continue on normally or will jump to another part of the program. The term jump is used to indicate that at such a branch point the next instruction is taken from some part of the memory other than the usual sequence.
a. COMPARISON OF WORDS. 1. Usual comparisons. If $(\alpha)>(\beta)$, then take $\gamma$ for four- or three-address computer; if $(\alpha)>$ (acc), take $\beta$ for two-address computers.
2. Absolute comparison. Same as 1 , except that the absolute values of the words are compared.
3. Negative jump. If (acc) is negative, take $\alpha$.
4. Positive jump. If (acc) is positive, take $\alpha$.
5. Zero jump. If (acc) $=0$, take $\alpha$.
6. Nonzero jump. If (acc) $\neq 0$, take $\alpha$.
7. High jump. If (acc) > ( $\alpha$ ), skip next instruction.
8. Low jump. If (acc) < ( $\alpha$ ), skip next instruction.
9. Equal jump. If (acc) $=(\alpha)$, skip next instruction.
10. Least significant jump. If least significant bit of (acc) is 1 , then jump to $\alpha$.

Of course items 3 to 10 are for one-address systems; in items 7 to 9 the number of instructions skipped may be more than one but would be fixed for a given machine.
b. Sensing of signal switches. 1. Special signal transfer. If a certain signal specified by the operation is on, then take $\alpha$. This instruction is used in conjunction with an instruction that turns on the signal. This latter instruction may be separated in the program from the special-signal-transfer instruction so that the jump occurs some time after the signal was turned on. There may be several signals and associated sets of instructions.
2. Manual jump. Here a jump will occur only when a manual external switch has been set before the program reaches the instruction.
3. Manual halt and transfer. The computer will stop if the external switch specified by the instruction has been turned on. Then, when the start button is pushed, the jump to $\alpha$ will occur. If the switch is off, the computer jumps without stopping.
4. Return jump. In a two-address system the program jumps to ( $\beta$ ) for the next instruction; at the same time the contents of the current instruction register (i.e., the address of this particular return-jump instruction) is recorded as ( $\alpha$ ). The purpose of this instruction is that it is often desirable to jump back to the place from which the original program jumped.
5. Recursion, or Loop-aiding, Instructions. These instructions are designed to aid in the programming of loops. In the examples and problems given above each time around the loop the main set of instructions usually needs to be modified by means of additional instructions. As was seen above, relative counters or index registers can aid in eliminating these additional instructions. Also, loop codes require some sort of tally to be kept to allow the computer to jump out of the loop. The purpose of recursion, or loop-aiding, instructions is to facilitate the use of the relative counters and to aid in keeping the tally automatically.
a. index-register modifier. Adds 1 to the index register and jumps to $\alpha$. Here the loop tally is not considered.
$b$. file and modify relative counter. This instruction stores the contents of one of the relative counters (assuming that there are several relative counters) as ( $\alpha$ ); then another designated by the instruction is set to the number $\beta$ (that is, not the contents of $\beta$, but $\beta$ itself), and this counter is then considered the relative counter until another file instruction occurs. Since resetting and going to another relative counter essentially constitutes a jump, this instruction can act as a return jump. However, if the number $\beta$ of the file instruction itself is considered relative to the same counter that the file instruction is setting, then this counter
is set to its original reading $+\beta$; that is, the counter is increased by $\beta$. As we have seen in the index-type instructions, resetting a counter is an aid to recursion codes; however, no tally is considered.
$c$. tally jump. Subtracts 1 from the number $\alpha$ of the instruction; if the result (that is, $\alpha-1$ ) is positive, replaces the number $\alpha$ by the number $\alpha-1$ (in the $\alpha$-address position) of the instruction, and jumps to take as the next instruction the contents of $\beta$; otherwise the program continues sequentially as usual. This instruction does not consider the relative counters.
d. modify index register and tally. Compares the contents of the index register with the number $\alpha$. If the contents of the index register is greater than the number $\alpha$, then the number $\alpha$ is subtracted from the index register and the difference placed in the index register. Then a jump is made to $\beta$. Otherwise the program continues in sequence. Note that the index register acts both as tally and as a relative counter. Of course this must be used in conjunction with an instruction that initially sets the contents of the index register.
6. Read and Write Instructions. These instructions operate the input and output electromechanical units.
a. magnetic tapes. These instructions can enable the computer to move the magnetic tapes forward or backward, or completely to rewind them. They enable the computer to read from the magnetic tapes into the higher-speed memory. The number of words written onto or read from the magnetic tape is specified either in terms of individual words or, more usually, in terms of the number of blocks of words, where by a block of words we mean some predetermined number of words. If, for example, there are eight words in a block, then only multiples of eight words can be handled. Similarly, in just moving the magnetic tapes, the distance to be moved is specified in either single words or blocks of words. The instruction code tells whether to read or write, or move the tapes backward or forward; the number $\alpha$ tells how many words or blocks are to be considered. For reading and writing the number $\beta$ is the address that the first word is written out of or read into.
b. punched tapes and cards. Instructions that tell the machine to read in from paper tape or to punch paper tape either give the initial and final addresses to be read into or out of or else give the first address and the number of words to be considered. Sometimes in reading-in paper tape, only the initial address is given, and a signal is put on the paper tape to tell the computer when to stop reading. Punched-card input-output is similar.
c. display. For displays on an oscilloscope each instruction may tell the display to exhibit one dot or other geometrical pattern, and the instruction gives the coordinates of that dot or of some point on the pattern.
d. concurrent in-out. Some computers have concurrent input and output. In these cases the computer can compute at the same time as words are being read into or out of the computer.

In addition it should be mentioned that some computers have such complicated methods of reading in and out that special codes must be written to facilitate these processes, and these codes must be available at all times inside the computer's memory. Often these codes must be put into the computer at first by hand methods, in a sort of bootstrap operation. Once the routines are in the computer, the operation may never need to be repeated. However, these methods are so peculiar to the particular computer involved that it is not worthwhile considering them here.

## EXERCISES

(a) What combination of other logical instructions would produce the same result as an extract instruction, in a binary computer?
(b) How can return-jump instructions facilitate the use of subroutines?
(c) Use the modify-index-register-and-tally instruction to code the problem described in Fig. 4-5. Write the code in a two-address system.

## 4-6. Special Coding Techniques

Multiway Branch. Our instruction systems described above allow for only a two-way branch in a code. That is, by means of a comparison


Fig. 4-11. Split-tree comparisons for multiway branch.
instruction, the computer can determine along which of two possible directions to continue in the code. However, it often occurs that a many-way branch is needed in a code; this must be programmed. Just as the decision process for a two-way branch was reduced to a comparison of numbers, so a many-way branch may be reduced to comparisons of numbers. For example, if a code is to have a four-way branch, then, to determine which branch is taken in any case, the code might determine a number $N$ which can take only the values $1,2,3$, and 4 . Then one way of coding the four-way branch would be a split tree of successive comparisons as in Fig. 4-11.

However, there is another, more efficient method for coding a manyway branch, using a so-called jump table. Here the number $N$ that
decides which branch the computer should take is used as an instruction modifier (see Fig. 4-12). The basic jump instruction is modified so that, when executed, the computer will jump to the appropriate-branch jump instruction of the jump table. This branch jump then jumps to the proper branch of the code.

Switch Sensing. In real-time applications (see Chap. 1) of digital computers it is often convenient to connect the outside world to the computer by means of a battery of switches. These switches are attached to a very specially built word in the computer's memory, and each switch controls a single bit of this word. If a switch is on, then the computer reads a unit in the position of the word corresponding to this switch; if the switch is off, then the computer reads a zero. Thus this special word gives at any time the status of the corresponding battery of switches. Let us in addition assume that this special word behaves the same as any other word of the computer's memory, except that the computer cannot read into it.

There are two ways of interpreting these switches, called on-off switch sensing and one-shot switch sensing. For on-off switch sensing the computer is to determine for each switch whether it is on or off. The $n$th switch can be sensed in this way as follows: Shift the switch word left until the $n$th bit is in the most significant place; then compare this shifted word with a word of all units except in the most significant place. For


| The jump table |  |
| :---: | :--- |
| Address | Branch jump |
| 161 | Jump to 1st branch |
| 162 | Jump to 2d branch |
| 163 | Jump to 3d branch |
| 164 | Jump to 4th branch |

Fig. 4-12. Jump table for multiway branch. example, consider a one-address system with the following shift instruction: Shift left (acc) the number of positions $\alpha$. Thus suppose that the switch word was 011110101110001 , and that we wanted to determine whether $P 8$ (the eighth bit from the right) were 0 or 1 . We would place this word into the accumulator and perform: Shift left 7; i.e., shift the word left seven positions. To compare, a negative jump would be used after subtracting (acc) from 011111111111111. If the result is negative, then the shifted word had a unit in the most significant position, that is, $P 8=1$; if the result is zero or positive, $P 8=0$.

For "one-shot" switch sensing the computer senses the switch word periodically at a rapid rate. The computer is only to determine which switches have been turned on. The one-shot switch is not to be sensed
when it is either left on or turned off. Thus one-shot switches are sensed according to Table 4-2. To code this we can use the extract instruction.

Table 4-2. When One-shot Switches Are Sensed

| New information <br> about switch | Old information <br> about switch | Sensed |
| :---: | :---: | :---: |
| 0 | 0 | No |
| 1 | 0 | Yes |
| 0 | 1 | No |
| 1 | 1 | No |

The old information is extracted with the new onto all units; then in the resulting word a zero will occur in the position corresponding to the switch that was just turned on. Hence, each time the switching word is sensed, it will be recorded in some other memory location. Then both the previous and the present switching word will be available at all times. To see why the extract instruction works, consider the following:


Hence only when 0 in the old word corresponds to a 1 in the new word will a 0 result. Of course next the position of this zero must be determined. This can be accomplished by shifting left one position at a time, keeping track of the number of times shifted, until a zero is sensed in the most significant position.

Input-Output. Very often the input-output instructions of a computer are not adequate to read in a whole code or read out all of a given portion of the memory. In such a case a subroutine must be used for reading in and out of the computer. For example, consider the following read-in instruction for a one-address computer: Read one word into $\alpha$. If an entire code is to be read into successive addresses of the computer's memory, then clearly a subroutine that iterates this instruction is needed. For example, using such a subroutine, the following procedure might be followed in reading in a code, where it is assumed that the subroutine is already in the computer's memory (see Fig. 4-13): The first instruction of the code to be read in will be a jump to the read-in subroutine. Then, when this instruction is read into, say, address 000 and executed, the computer will jump to the read-in subroutine. The read-in subroutine will read in the next two words of the code; these words will contain the initial and final address where the code is to be put in the computer's memory. Then the subroutine loads the read-in instruction with this initial read-in address and the tally with the final read-in address, and the iteration of the read-in instruction begins. When the complete
code has been read in, the subroutine will jump to the initial read-in address and computation will proceed. It is probably wise to have the computer stop before computation proceeds, to give the computer operator a chance to turn off the input equipment, etc. Then, when the run button is pushed (see the next section), the computations will proceed.

Table Look-up. Consider the problem of coding a computer to look up a function table that has previously been stored in the computer's memory. That is, given a particular value of the independent variable, we


Fig. 4-13. Flow chart of input-output routine.


Fig. 4-14. Setup of table for table lookup routine.
desire a code that will select from the computer's memory the corresponding value of the dependent variable as recorded in the table.
method 1. We have already illustrated above (see Sec. 4-2 under Instruction Modification) one simple technique that can be used when the independent variable in the table takes on successive integer values.
method 2. Consider now the case of nonintegral values for the independent variable, but where the intervals between successive values of the independent variable given in the table are all equal. In this case, given the value of the independent variable for which the value of the function is desired, simply divide it by the interval to obtain an integer; thence this case reduces to the one considered in method 1.

The interesting case occurs when the values of the independent variable given in the table do not have equal intervals between them. Here, to be specific, suppose that we are in a two-address system and the table is recorded in successive cells of the computer's memory as follows: The value of the independent variable is found in the $\alpha$ position of a word, and the corresponding value of the dependent variable is found in the $\beta$ position of the same word (see Fig. 4-14). Let us call the successive values of the independent variable $x_{0}, x_{1}, x_{2}, \ldots, x_{f}$, where of course
$x_{0}<x_{1}<x_{2}<\cdots<x_{f}$, and of the dependent variable $f\left(x_{0}\right), f\left(x_{1}\right)$, $f\left(x_{2}\right), \ldots, f\left(x_{f}\right)$, and suppose that they are recorded in addresses $T_{0}, T_{1}, T_{2}, \ldots, T_{f}$. We desire to find $f(N)$ for some given value $N$, where it is assumed that $N=x_{i}$ for some $i$; that is, no interpolation is considered here.

METHOD 3. One simple procedure is to compare successively $N: x_{0}$, $N: x_{1}, N: x_{2}, \ldots$, until, for some $i, N=x_{i}$; then $f(N)=f\left(x_{i}\right)$ can be


Fig. 4-15. Flow chart for table look-up, method 4.
read from the computer's memory as desired. This, of course, can be accomplished by a simple iteration.
method 4. There is another method that on the average will enable $f(N)$ to be obtained faster. The flow chart for this method appears in Fig. 4-15. The method consists in determining in which half of the table $x_{i}=N$ is located; then the halving procedure is again applied to this smaller part of the table, etc., until a single cell is left. For example, consider Fig. 4-14, and suppose that $N$ is $x_{5}$. Then the first step of this method is to determine that $N$ is included in $T_{4}$ through $T_{7}$. The second step locates $N$ further, as being in $T_{4}$ or $T_{5}$. The third step in this case locates $N$ as being in $T_{5}$. The code would be written as follows: At any step let $t_{L}$ and $t_{U}$ be the lower and upper addresses, respectively, of
the range of addresses in the table under consideration. Then form $t^{\prime}=t_{L}+\Delta$, the address that divides this range of address into two parts, where $\Delta=\left(t_{U}-t_{L}\right) / 2$. Then we look to see whether $N$ lies in the upper or lower half of the range; i.e., is the contents of the $\alpha$ part of $t^{\prime}$ greater or less than or equal to $N$, that is, $\left(t^{\prime}\right)_{\alpha}: N$ ? If $\left(t^{\prime}\right)_{\alpha}>N$, then $t^{\prime}$ becomes the upper address of the new range; that is, $t^{\prime} \rightarrow t_{U}$. If $\left(t^{\prime}\right)_{\alpha}<N$, then $t^{\prime}$ becomes the lower address of the new range; that is, $t^{\prime} \rightarrow t_{L}$. Of course, if $\left(t^{\prime}\right)_{\alpha}=N$, we have the desired result. There is one little complication, however. When $\Delta=\left(t_{U}-t_{L}\right) / 2$ is formed, it may not be an integer; but $t^{\prime}=t_{L}+\Delta$ is an address and therefore must be an integer, hence must be rounded to an integer. A little reflection will show that, if $\left(t^{\prime}\right)_{\alpha}>N$, then the next $\Delta$ should be the nearest smaller integer to $\left(t_{U}-t_{L}\right) / 2$, while if $\left(t^{\prime}\right)_{\alpha}<N$, the next $\Delta$ should be the nearest larger integer to $\left(t_{U}-t_{L}\right) / 2$.

For example, consider Fig. 4-14 in connection with the flow chart of Fig. 4-15, and suppose for argument's sake that $N=x_{5}$ and that $T_{0}=100, T_{1}=101, T_{2}=102, \ldots, T_{7}=107$. Then we would start with $t_{L}=100, t_{U}=107$, whence $\Delta=(107-100) / 2=31 / 2$, rounded up $=4$. Hence $t^{\prime}=100+4=104$. Comparing (104) $: N$, we find $N>(104)_{\alpha}$. Hence 104 is $t_{L}$, and we form $\Delta=(107-104) / 2=11 / 2$, rounded $\mathrm{up}=2$. Thus $t^{\prime}=104+2=106$. Comparing ( 106$)_{\alpha}: N$, find $N<(106)_{\alpha}$. Hence 106 becomes $t_{U}$. Thus $\Delta=(106-104) / 2=1$, whence $t^{\prime}=104+1=105$. Comparing (105) $)_{\alpha}: N$, find $N=(105)_{\alpha}$, and the result has been obtained.

## EXERCISES

In all the exercises below the student should feel free to define explicitly any instructions that he may require or that may help simplify the code (particularly in the oneaddress system), based on the material of the previous two sections (Secs. 4-4 and 4-5), unless specifically stated otherwise by the exercise. These instruction definitions are to be listed preceding the code.
(a) Define appropriate one-address instructions, and code both the split-tree and jump-table method for a four-way branch.
(b) Suppose that only a single on-off switch could be on at one time. Define appropriate one-address instructions, and code a subroutine that will determine the position of a switch that is turned on.
(c) Write a code for the same problem as (b), but now consider one-shot switches.
(d) Write an input subroutine, using the one-address input instruction given in this section.
(e) Using a one-address system, with an input instruction that reads in one word at a time as described in this section, and assuming that the word format has a single auxiliary bit, define appropriate counter-setting instructions, etc., and write a read-in subroutine.
$(f)$ Write a code for method 3 of the table look-up problem. Make use of an extract instruction to extract the successive $x_{i}$ onto all zeros to compare with $N$; then extract $f(N)$ onto zeros for the read-out. Also assume that there are two auxiliary bits and one relative counter to aid the iteration.
(g) Code method 4 of the table look-up problem in a two-address system.

## 4-7. The Control Panel

Purpose of the Control Panel. The control panel has three main functions: (1) to enable the operation and monitoring of the computer during the computation of a program; (2) to aid the checking, or "debugging," of a new program; and (3) to aid the maintenance of the computer by the engineer. The control panel and the program itself are the main communication links between the operator and the computer. By means of the control panel the computer can be started and stopped, computations can be initiated, magnetic tapes can be properly positioned and other input-output equipment controlled, computer voltage and current levels, temperature, power input, etc., can be checked and adjusted, and so forth. There are wide variations in the features of control panels of different computers. In this section we shall discuss some of the possible features that a control panel might have (see Fig. 4-16).

In general, information is transmitted between the operator and computer by means of lights and buttons on the control panel. However, there is one method for monitoring a program during the computations using neither lights nor buttons that deserves special mention. It consists simply of a radio placed near the computer tuned to pick up signals generated during the computation. The computer, operating at a megacycle or more, presents a radio frequency; recursion loops generate audiofrequency modulations that can be detected. Various sound patterns will correspond to the different sequences or loops of instructions in the program. A coder who is computing many reruns of the same code, as would be the case in computing mathematical tables, can frequently relate these sounds to the various iterations of his program. A trained ear can then often detect errors or other troubles that his computations may have, just by "listening" to the program while it is being computed.
Lights and Signals. Usually one first notices the lights and signals displayed by the control panel. By means of these signals the computer can tell the operator something about its internal state. There are in general three kinds of lights and signals: the first kind tells why the computer stops during the course of a computation; the second presents a visual picture of the contents of various registers and memory cells; the third gives the electrical state of the computer.

When the computer stops or halts, usually one of several lights comes on, indicating the cause for the stop; i.e., a stop instruction has been executed (called a final stop), or an instruction being executed may contain an erroneous operation code not meaningful to the computer, or an instruction being executed may have reference to an erroneous memory address not legal for the computer,$\dagger$ or a check stop due to an auxiliary bit may have occurred, and so forth. Control panels are often constructed so that, when the computer has stopped or halted, the contents
$\dagger$ Frequently the full complement of memory address is not constructed for a computer. Hence an erroneous instruction would refer to an address that the computer does not have.


Magnetic-tape control

$$
\begin{array}{cc}
8 & 8 \\
\text { Rewind } & \text { Run }
\end{array}
$$

Clear button
Bit buttons
Fig. 4-16. A simple control panel. In the illustration the accumulator reads 46243712, the instruction register reads 62624607 , and the current-address counter reads 36363.
of various registers can be ascertained from sets of lights. For instance, there may be two small "grain-of-wheat" neon bulbs on the control panel corresponding to each bit of the accumulator. When the top bulb of the pair is on, the corresponding bit might be a unit; when the bottom bulb is on, the corresponding bit would be a zero. Similarly the contents of the instruction register of the current-address counter and of other registers and counters can be displayed. If an electronic failure has occurred, such as a blown fuse or a change in voltage or current readings beyond an allowable limit, appropriate signal lights will come on. Of course there will be a pilot light indicating that the power is on, etc.

Buttons and Switches. The only means the computer operator has to control the computer, other than by the code itself, is by the buttons and switches on the control panel. Besides the on-off switch for the power there is a start button, which initiates the computations. For example, when the start button is pushed, the computer may automatically take as the first instruction the contents of address 000 . There is also a stop button; when pushed, the computations cease. In addition to the start button there may be a run button, which is used to restart computations after a halt has occurred in the middle of a computation. In this case the difference between the start and run button is that the run button tells the computer to continue to perform the instruction already in the instruction register, whereas the start button tells the computer to initiate a particular standard predetermined sequence of events, e.g., take 000 as the next instruction.

The computer can usually be operated in several different modes. For example, by setting a switch the computer can be made to execute only a single instruction each time the start or run button is pushed. In this way a sequence of instructions can be "stepped through" slowly by successively pushing the run button. This would be done, for example, if one desired to see several of the instructions and their results on the lights of the control panel that display the contents of various registers. On the other hand a different setting of this mode switch can make the computer sequence itself through the instructions of a program at a very much reduced rate. Finally of course the mode switch can be set so that the computations proceed at full speed. Often in the single instruction mode, there is a phase-selector switch which makes the computer proceed through just one phase each time the run button is pushed.

So much for the special methods of starting the computer; consider next special methods for stopping or halting the computer. In previous sections we have observed how the operation of manual switches can be used to halt the computation when auxiliary bits are present. These switches are called auxiliary switches. There can be several auxiliary switches, each associated with a different auxiliary bit of the instruction word. Then, by setting the proper auxiliary switch, the computer can be made to stop at different sets of instructions. Other switches may make the computer halt at a particular phase when the stop button is pushed.

One of the most important uses of a control panel is to insert words manually into particular memory locations. Such an occasion may arise, for example, when it is necessary to correct only one or two words in a long program that is already in the computer's memory. There are several methods used to accomplish this. One method is to have one button associated with each bit of the registers that may be displayed by lights on the control panel. When the computer has been halted, the contents of a register may be changed by means of these buttons. For example, there may be one "clear" button for each register that, when pushed, makes the contents of the respective register all zeros. Then the bit buttons of this register are pushed to insert units in the desired bit locations. Under these conditions the procedure for inserting a word into a particular memory position would be as follows: Halt the computer; manually insert the desired word in the accumulator; similarly insert an instruction in the instruction register that will transfer the contents of the accumulator into the desired memory location. Set the mode switch for a single instruction, and push the run button. The inserted instruction will then be executed, and the word will be inserted into the desired memory location. Other methods might make use of the external input equipment to read a single word into the desired memory address.

There is usually a set of switches associated with the input-output equipment. Although, as we have seen, the selection of input-output equipment can be made by the program itself, frequently provision is made on the control panel for the manual selection of external equipment. Other switches present a means for manually winding, rewinding, and positioning magnetic-tape units. More complicated external equipment such as cathode-ray or television displays of course require still additional controls.

Let us now illustrate a possible procedure for initiating a computation by means of our control panel. First the input medium is properly set in the input device. Next the input device itself is turned on, and the external selector is set to choose this input equipment. An instruction is inserted into address 000 that will read in the whole program. The accumulator, instruction register, and current-address counter are all cleared (why?). The mode is set at high speed, and then the start button is pushed. The computer will then execute the instruction found in 000 first.

## EXERCISES

(a) Suppose that a characteristic "click" can be heard on the radio monitor each time the computer goes through a loop. Suppose also (for simplicity in this exercise) that any instruction takes precisely $100 \mu \mathrm{sec}$ to execute on our one-address computer. Write a code that will play the first few notes of the song "Dixie." (Hint: Look up the audio frequency of the first few notes of "Dixie," and code successive loops that will repeat at these frequencies.)
(b) Describe a procedure for finding out, by means of the control panel, what word is in a particular memory address.
(c) Suppose that a subroutine were necessary in order to read in a program. What would be a procedure for initiating a program by means of the control panel?
(d) If a computer needs a read-in subroutine, how is the read-in subroutine itself read in (for the very first time)?

## 4-8. Additional Topics

a. Survey of Instruction Systems. Make a survey and analysis of instruction definitions used in many different presently available computers. Obtain the information from the programming manuals of computers such as the Sperry Rand UNIVAC 1103 and 1105; the IBM 650, 704, 705, and 709; the Bendix G15; the Datamatic 1000; the Datatron; and the Electrodata. Classify the instructions by the categories given in this chapter.
b. Survey of Control Consoles. Make a survey of control consoles and the function of the different switches, buttons, and lights on each. Use instruction and maintenance manuals for the computers mentioned above to obtain the information.
c. Indirect Addressing. If there are $n$ bits in an address, then only $2^{n}$ memory locations can be addressed directly. Indirect addressing must be used when it is desired to address more than $2^{n}$ locations. For example, suppose that we desire to address $w \times 2^{n}$ memory locations. The entire memory would be divided into $w$ parts, each with $2^{n}$ memory locations. For each of these $w$ parts there will be a special register or memory location reserved, the contents of which will be the address desired within this part. Then, to address one of the $w \times 2^{n}$ memory locations, an instruction would simply address one of the $w$ special memory registers, and the contents of this address would itself be interpreted as the address desired in the corresponding part of the memory. Variations of indirect addressing are used in the NBS Pilot computer, the Philco TRANSAC 2000 computer, and the IBM 709. Study these uses of indirect addressing.
d. Microprogramming. R. J. Mercer $\dagger$ defines microprogramming as "the technique of designing the control circuits of an electronic computer to formally interpret and execute a given set of machine operations as an equivalent set of micro-operations, elementary operations that can be executed in one pulse time." There are two logically closely related types of microprogramming, one analogous to indirect addressing, and the other that is concerned mainly with the logical design of the control circuits of the computer. The analogy to indirect addressing occurs when the instruction operation is an address, rather than an operation, and the contents of this address is interpreted as a sequence of micro-operations. The micro-operations might each consist of 4 bits, and there might be 10 of these in a single 40 -bit word. The micro-operations themselves would indicate transfers of words between various registers, setting of switches to be sensed at a later time, various types of shifts, arithmetic operations, logical operations, and so forth. The same effect may be obtained by sequencing micro-operations by means of coding and decoding matrices. See, for example, R. J. Mercer's cited article; M. V. Wilkes and J. B. Stringer, Microprograming and the Design of the Control Circuits in an Electronic Digital Computer, Proc. Cambridge Phil. Soc., April, 1953; H. T. Olantz, A Note on Microprograming, J. Assoc. Computing Machinery, April, 1956; S. V. Blankenbaker, Logically Micro-programmed Computers, IRE Trans. on Electronic Computers, vol. EC-7, no. 2, pp. 103-109, June, 1958.
$\dagger$ Robert J. Mercer, Micro-programming, J. Assoc. Computing Machinery, vol. 4, no. 2, pp. 157-171, April, 1957.
e. The Minimum Computer. It is clear that a general-purpose computer does not really "need" the multiplication or division instructions, for these operations can be formed by a combination of additions or subtractions. Similarly other operations can be omitted and replaced by simpler ones. The question arises: What are the minimum instructions necessary for a general-purpose computer-or, indeed, what criteria can be applied to determine whether or not a computer is actually a generalpurpose computer? These questions have long been of interest to mathematicians and logicians. The so-called Turing machine, or "universal computer," was developed for this purpose (see A. M. Turing, On Computable Numbers, with an Application to the Entscheidungs Problem, Proc. London Math. Soc., ser. 2, vol. 42, pp. $230-265$; a more readable description is given in Martin Davis's "Computability and Unsolvability," chap. 1, McGraw-Hill Book Company, Inc., 1958). More recently S. P. Frankel has considered the minimum general-purpose computer; see his On the Minimum Logical Complexity Required for a General Purpose Computer, IRE Trans. on Electronic Computers, vol. EC-7, no. 4, December, 1958. Frankel's computer can only subtract. Can you program multiplication on Frankel's minimum computer (called the Microcephal AC)?

## f. References on Programming Texts and Periodicals

Alt, Franz L.: "Electronic Digital Computers-Their Use in Science and Engineering," Academic Press, Inc., New York, 1958.
Jeenel, Joachim: "Programming for Digital Computers," McGraw-Hill Book Company, Inc., New York, 1959.
Ledley, R. S., and J. B. Wilson: "Programming and Utilizing Digital Computers," McGraw-Hill Book Company, Inc., New York, in press.
Levin, Howard S.: "Office Work and Automation," John Wiley \& Sons, Inc., New York, 1956.
McCracken, D. D.: "Digital Computer Programming," John Wiley \& Sons, Inc., New York, 1957.
Von Neumann, J., and H. H. Goldstine: "Planning and Coding of Problems for an Electronic Computing Instrument," Institute for Advanced Study reports written under U.S. Army Ordnance Contract W-36-034 ord 7481, Princeton, N.J., 1947-1948.

Wilkes, M. V., D. J. Wheeler, and S. Gill: "The Preparation of Programs for an Electronic Digital Computer," 2d ed., Addison-Wesley Publishing Company, Reading, Mass., 1957.
Wrubel, Marshal H.: "A Primer of Programming for Digital Computers," McGrawHill Book Company, Inc., New York, 1959.

Periodicals (in which special computer programming problems are discussed)
Automatic Control, monthly, New York.
Automation, monthly, Penton Publications, Cleveland, Ohio.
The Computer Journal, quarterly, British Computer Society, Ltd., London.
Computers and Automation, 10 times a year, Edmund C. Berkeley and Associates, New York.
Control Engineering, monthly, McGraw-Hill Publishing Company, New York.
Journal of the Association for Computing Machinery, quarterly, New York.
Journal of Operations Research Society of America, quarterly, Baltimore.

## CHAPTER 5

## ADVANCED PROGRAMMING

## 5-1. Introduction

The previous chapter was concerned with the details of programming and coding at the instruction level. The four-, three-, two-, and oneaddress instruction formats were described and compared. The octalcoded binary and decimal-coded binary systems were compared. The steps in preparing a flow chart, symbolic code, and finally the code itself written in the actual machine language were described. Decision branches, instruction modification, and recursion codes were discussed and examples given. Coding was found to be detailed and laborious, and the one-address system particularly aggravated these qualities.

Advanced programming techniques attempt to lighten the load of the programmer and coder. Its purpose is to try to make the computer itself help prepare the program or code, minimizing the amount of writing a programmer need do. The means used to accomplish this is to prepare or precode the computer with an intermediate, or automatic, program which is always available in the computer memory. This intermediate or automatic code encompasses certain aspects of coding that are common to many programs and of general applicability. Then, when the programmer is coding any specific problem, his work can be shortened by taking advantage of already precoded items of the automatic program that are already in the computer. Such automatic programming can greatly simplify the coding of computers otherwise difficult to code. Hence, in the design of some computers, little attention is paid to ease of coding, and such advanced programming techniques are heavily relied upon to compensate for this. Unfortunately, however, the coder must then learn how to use not only the computer but also the automatic programming schemes. Evidently a balance must be sought in computer design between the amount of automatic programming envisioned and the difficulty of coding. It is clear that automaticprogramming concepts are of great importance to the computer engineer.

Rarely is a program written that is found to be absolutely correct the first time it is run on the computer. Hence in this chapter we first consider automatic aids for analyzing an already coded program for errors. Having discussed automatic programs to aid the coder to correct his code, we turn to such programs that aid the computer engineer to
maintain the computer. Next automatic programs designed to lighten the load of the programmer are considered. These can be roughly classed in two categories-the interpretive routines and the compiling routines. Various examples are discussed as illustrative of the methods and techniques of formulating and using such automatic programs. The specific examples given are intended to illustrate the principles involved, and their particular form as chosen for this chapter was dictated by pedagogical considerations only. As will become clear during the course of the chapter, there are many other ways to solve the problems posed, and in actual practice the final choice depends on the primary purpose of the code and the detailed characteristics of the computer to be used.

## 5-2. Program Debugging Methods and Routines

The Problem of Program Debugging. The first time a program is tried on a computer, it usually does not run correctly. If the start button is pushed and the program allowed to run, one of four results can occur: First, the computer might run up to a point and then just stop, or "hang up." Second, the computer could continue to run for an excessively long time, neither stopping nor producing any results. Third, the computer could run and, as expected, print out results, but wrong results. And finally the program could run correctly. In the first three cases an error is indicated in the program, and the problem is to detect where-at what instruction or instructions-the error occurs and then to correct it. This procedure is often referred to as "debugging" a program.

It is hard to describe in general how to debug a particular program; ingenuity on the part of the programmer, systematic and neat flow charts, coding sheets with detailed remarks, and a thorough knowledge of the code are, of course, all essential. When a program just stops, this usually indicates that the computer has been asked to do an illegal instruction; for instance, the instruction might have an operation code not corresponding to any operation or might contain an address that the computer does not have, etc. Illegal instructions are often the result of an error in instruction modification. When a program never stops, the program usually has a loop with a faulty exit. The exit may not have been properly set up, or else a nonconverging iteration may be in process, etc. The printing out of wrong results requires examination of these results in the light of the problem: Is the scaling wrong? Are the constants correct? Has any phase of the calculation been skipped, etc.?

However, certain techniques can be discussed that are often used to aid the debugging process. These can be generally classified into dynamic debugging and post-mortem debugging. Dynamic techniques try to check the program while it is actually running on the computer; postmortem techniques examine the computer memory after the program has stopped, or "hung up."

Dynamic Program Debugging. Let us first consider dynamic program debugging. There are two generally used methods: the first is called the
break-point (or check-point) method; the second is called the automonitor method. The break-point method consists in writing into the program, at critical intermediate points, instructions that either will stop the computer so that important intermediate results can be observed or will make the computer print out such intermediate results automatically. The sign bit on an instruction word is often used to facilitate such a process. For example, some computers are designed so that after executing an instruction with a negative sign the computer will stop. Usually such computers also have the following additional feature: A manual switch on the control panel can be thrown so that in one position the computer will not stop after a negative instruction-this being called the normal switch position-and so that in the other position the computer will stop-this being called the break-point switch position. The advantage of this control-panel switch is clear: in debugging a program, the negative instruction stops are used, and the switch is set accordingly; when the program has been corrected, these negative stops are no longer desired and hence the switch is thrown to normal.

Another break-point procedure depends on the programmer inserting into the program at intermediate critical points manual-switch jump instructions. In debugging the program, the switches are positioned so that the computer will jump when it encounters such an instruction; usually special print-out routines are included in the program, and the jump instructions transfer the computer to these routines. When the program has been corrected, the switches are turned off and the computer simply ignores the jump instructions.

Use of the Automonitor Program. The automonitor method for dynamic debugging does not require any additions or special considerations in the program itself, as does the check-point method. Instead the automonitor method requires the use of a special automonitor program which is read into the computer in addition to the program to be debugged. The automonitor program is general and once written can be used for every program to be debugged. Occasionally the computer has the properties of the automatic automonitor program already wired in, so that the automonitor process can be carried out simply by throwing a switch on the computer console. An automonitoring program makes the computer print out-while each instruction of the program being debugged is being executed-the instruction itself, the contents of each of the operand addresses, and the computed result. For example, suppose the program to be debugged is as follows:

| Address | Instruction |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
|  | Operation | $\alpha_{0}$ | $\beta_{0}$ | $\gamma_{0}$ | $\delta_{1}$ |
| $\delta_{1}$ | Operation | $\alpha_{1}$ | $\beta_{1}$ | $\gamma_{1}$ | $\delta_{2}$ |
| $\delta_{2}$ | Operation | $\alpha_{2}$ | $\beta_{2}$ | $\gamma_{2}$ | $\delta_{3}$ |

Then the automonitor program would have the computer print out the following:

| Address | Instruction | 1st operand | 2d operand | Result |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
| $\delta_{0}$ | $\left(\delta_{0}\right)$ | $\left(\alpha_{0}\right)$ | $\left(\beta_{0}\right)$ | $\left(\gamma_{0}\right)$ |
| $\delta_{1}$ | $\left(\delta_{1}\right)$ | $\left(\alpha_{1}\right)$ | $\left(\beta_{1}\right)$ | $\left(\gamma_{1}\right)$ |
| $\delta_{2}$ | $\left(\delta_{2}\right)$ | $\left(\alpha_{2}\right)$ | $\left(\beta_{2}\right)$ | $\left(\gamma_{2}\right)$ |

In other words, the automonitor program gives a complete record for the program being debugged of just which instructions are being done by the computer and what the results were. With this information it becomes easy to spot any error in the program being debugged. Note that the automonitor program is a program that operates on another programmore about this point will be said in the succeeding sections.
Of course certain instructions of the program being debugged are handled somewhat differently. For example, in a compare instruction, ( $\gamma$ ) need not be printed, but just $\delta,(\delta),(\alpha),(\beta)$, for the address of the next instruction tells which way the comparison went. Common sense clearly dictates what an automonitor program should print out.

An automonitor program for a three-address computer would be similar to that just described for a four-address system. For a twoor one-address system the contents of the accumulator or other registers becomes of importance, and hence the contents of the accumulator is printed out. For instance, in a one-address system, the print-out would look like this:

| $\delta_{0}$ | $\left(\delta_{0}\right)$ | $\left(\alpha_{0}\right)$ | $(\mathrm{acc})$ |
| :--- | :--- | :--- | :--- |
| $\delta_{1}$ | $\left(\delta_{1}\right)$ | $\left(\alpha_{1}\right)$ | $(\mathrm{acc})$ |
| $\delta_{2}$ | $\left(\delta_{2}\right)$ | $\left(\alpha_{2}\right)$ | $(\mathrm{acc})$ |

The Automonitor Program Itself. In order to grasp more fully the general concept behind an automonitor program, let us examine in a cursory way how such an automonitor program itself might be written for a one-address system. The flow chart is given in Fig. 5-1. This automonitor program is in one part of the memory, and the program to be debugged is in another part of the memory. The automonitor program must be given the address of the first instruction of the program to be debugged. Then the automonitor program prints out the desired record and also executes the instructions of the program to be debugged. First the automonitor program prints the address of this first instruction, $\delta_{0}$; then it copies ( $\delta_{0}$ ) into a special temporary located in the automonitor program's part of the memory. This instruction is printed, and ( $\alpha_{0}$ ) is printed. Next the automonitor program directs the computer to execute the first instruction in its location within the automonitor program. Then (acc) is printed, and the automonitor program goes on to the next instruction, etc. There are a few important details that must be attended
to. When the program to be debugged is being executed, the contents of the accumulator from instruction to instruction is, of course, important. But when the automonitor program executes one instruction at a time and inserts print routines, etc., between these instructions, the contents


Fig. 5-1. Flow chart of automonitor program. of the accumulator becomes lost. In order to correct this situation, the contents of the accumulator (and other registers) must be recorded after the execution of each instruction of the program being debugged. Then, before the next such instruction is to be executed, the registers are properly preset. $\dagger$ In this way the two programs are properly interleaved.

Post-mortem Program Debugging. Consider next post-mortem program debugging. The first method is to run the program through and observe the results. From a knowledge of the program and the erroneous results an error can often be located. For example, if the magnitude of the results is off, the scaling is checked for error, etc. The second method is to print out the entire memory of the computer after the program has been run. If the program got into a loop with no exit, then the tallies can be checked on this memory printout. All instructions that were to be modified by the program can be checked to see whether or not they were correctly modified, etc. A third method is to have another program that examines the program to be debugged after it has run. This program compares the program to be debugged with itself before and after it has been run and tells the programmer where they differ. In this way the programmer can determine if any instructions were inadvertently destroyed, if all differences that should appear actually do appear, etc.

Of course the programmer uses combinations of the techniques that are at his disposal. What we have briefly outlined here is in no way com-
$\dagger$ Also, provision is made in the automonitor code so that jump instructions are not performed directly but rather operate on the automonitor $\delta$-address reading instruction.
plete but rather indicates some of the directions from which aids to programming may arise.

## EXERCISES

(a) Write out precisely what an automonitor program would print if applied to the code of Example 3-1c.
(b) Suppose that a code contains a negative jump instruction. How can the automonitor program handle such an instruction? After the automonitor program executes the negative jump, how can it regain control again?
(c) Write a simple post-mortem debugging program as required for the third method.

## 5-3. Computer Maintenance Routines

Maintenance. If a computer circuit is malfunctioning, then the computer will not always produce the correct results. Evidently these incorrect results must in some way reflect the course of the malfunctioning. Hence it seems possible that specific routines can be designed especially for determining a malfunctioning circuit. Such programs are called maintenance routines. Of course one must be able to read into the computer, read out of the computer, and perform some operations in order that a maintenance routine be capable of application at all. Then there is the fact that even though a programmer using a computer may swear that it is malfunctioning, it may often be in perfect operating condition. Hence a maintenance routine must check to see whether or not the computer is indeed malfunctioning. However, if the user of the computer can demonstrate that it gives two different results to the same program, then the computer must be malfunctioning no matter what the maintenance routines determine. Finally observe that a maintenance routine often cannot detect a particular malfunctioning circuit but can determine only that one of several circuits is not operating correctly. Then, of course, the computer maintenance engineer must make electronic tests on these circuits themselves inside the computer.

Actually maintenance routines are composed after a detailed knowledge of the computer logical circuitry has been mastered. However, we have placed this discussion in Part 1, rather than at the end of Part 4, to illustrate for the prospective computer engineer the necessity of a thorough understanding of coding.

Locating Malfunctioning Parts. Maintenance routines usually are designed to determine whether or not some particular part of the computer is working correctly. For example, a routine may test the inputoutput equipment, another may test different parts of the memory, another may test the add operation, another the multiply operation, etc. The logic most often used in interpreting the meaning of a maintenance routine test is: if the part of the computer tested by the routine is operating correctly, then the malfunctioning circuit must be located in some other part of the computer. In this way the possible malfunctioning
circuit is located by the elimination of correctly operating circuits. The fact that a maintenance routine test fails does not necessarily mean that the malfunctioning circuit is located in the part tested by this routine, whereas the fact that a maintenance routine test passes does mean that the circuits in the part tested are in operating order. The reason for this is that it is extremely difficult to distinguish by means of a maintenance routine between a malfunctioning circuit in the control unit and some malfunctioning circuit in the arithmetic unit.

As an example of a maintenance routine, suppose it has already been determined that the first sixteen memory cells are operating correctly, in addition to the accumulator and the add, subtract, transfer, and jump instructions. The problem is to test the rest of the memory. To see whether or not a memory location is dropping a bit, a word of all units is read into an address and, after a time, read out again. If the word read out is not all units, i.e., has at least one zero, then it can be concluded that this address is malfunctioning. Hence the entire memory from 020 on is filled with words of all units; and the program of Table $5-1$ will test

Table 5-1. Maintenance Routine

| Address | Instruction |  | Remarks  <br> (preload accumulator with 77 777 ) |
| :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ |  |
| 000 |  |  |  |
| 001 | Subtract | 020 | Subtract contents of a memory address from accumulator, and put result into accumulator |
| 002 | Add | 012 | Add a word of all units to accumulator; if there is an overflow, we are assuming that computer will stop |
| 003 | Subtract | 012 | Clear accumulator |
| 004 | Add | 001 | Modify subtract instruction found as (001) to consider |
| 005 | Add | 013 | the next successive memory address |
| 006 | Transfer | 001 |  |
| 007 | Subtract | 001 | Clear accumulator |
| 010 | Add | 012 | Set up initial conditions for next loop; take next |
| 011 | Jump | 001 | $\}$ instruction from 001 |
| 012 | 77 | 777 | Constant: a word of all units |
| 013 | 00 | 001 | Constant: 00001 |

whether or not any bits are being dropped, where it is assumed that the computer is designed so that an overflow will cause a stop and that an illegal $\alpha$ will also cause a stop. For this code (accumulator) must initially be a word of all units-i.e., initially (acc) $=77777$. Now, if a memory address being tested does not drop a bit, then the result of the subtraction will be all zeros and hence, after (012) is added to the accumulator, the initial conditions are once more set up and the next memory address can be tested. On the other hand, if a memory address did drop a bit, then some unit would be a zero and the result of the subtraction
would contain a unit in the position where the memory address had a zero. Hence, when this result is added to a word of all units, overflow will occur and the computer will stop. (It was, of course, assumed that the computer in question had this property.) Then the $\alpha$ address of the instruction stored in address 001 is the malfunctioning address; and the position where the units of the accumulator turn to zero is the position where the bit is being dropped, i.e.:

$$
\left.\begin{array}{c}
\text { Dropped bit } \\
(\cdots 111 \\
\cdots 111
\end{array}\right)-(\cdots 110 \quad 111)=(\cdots 001 \quad 000) ~ ? ~(\cdots)
$$

whence

$$
\begin{aligned}
\left(\begin{array}{ll}
\cdots & 000
\end{array}\right)+\left(\begin{array}{ll}
\cdots 111 & 111
\end{array}\right) & =\left(\begin{array}{ll}
\cdots 000 & 111
\end{array}\right) \\
& \text { Position of dropped bit }
\end{aligned}
$$

When a bit is dropped, this can often be due to either the control circuitry or the memory itself. Then these must be checked electronically.


Fig. 5-2. Comparison (or equalizer) circuit.
As another example, suppose that the add, compare, and transfer instructions and the memory were operating; the problem is to check the shift-left instruction. Since shifting ( $\alpha$ ) left $n$ positions is the same as forming $2^{n} \cdot x$ [where $(\alpha)=x$ ], we can perform the equivalent of shifting by adding a number to itself, and the result to itself, etc., repeated $n$ times. Hence we perform the shift and also perform the add interpretation of a shift, and then see if we have gotten the same answer. Note that two things need to be checked: first that the bits do shift from each position to the next successive position to the left; also that the number of positions shifted is the number called for in the instruction.
Locating Malfunctioning Gates. Up to now we have discussed maintenance routines that attempt to locate the malfunctioning circuit down to some rather gross part of the computer. On the other hand it is sometimes possible to locate the actual gate or gates that may be causing the trouble. For example, consider the comparison (or equalizer) circuit described in Sec. 2-5, which is redrawn in Fig. 5-2.
Suppose that the gates were the relay gates described in Sec. 2-5. Let us assume that, if a normally open relay is malfunctioning, its contact is dirty and it does not close properly; also that, if a normally
closed relay is malfunctioning, its relay arm is stuck and it will not open. Under these assumptions, let us try to write a routine for determining which gates are not operating correctly, if any at all. To do this, note that there are only four possible different input conditions for this circuit, which are summarized by the four columns in the following table. If the circuit is operating correctly, then the outputs for each gate in the circuit corresponding to each input are also given in the table.

$$
\begin{aligned}
& \text { Inputs: } \\
& \text { A.................. } 0101 \\
& \text { B.................. } 0011 \\
& \text { Outputs: } \\
& \text { Gate 1.............. . } 1010 \\
& \text { Gate 2.............. . } 1100 \\
& \text { Gate 3............. . . } 1000 \\
& \text { Gate 4.............. . . } 0001 \\
& \text { Gate 5............. . } 1001
\end{aligned}
$$

If any other output appears, then the circuit is malfunctioning and the problem is: How can such an output be interpreted in terms of a specific malfunctioning gate? We shall assume that only one of the gates is ever malfunctioning at a time. Hence suppose that the not gate for $A$ is malfunctioning. Since it is made of a single, normally closed relay, according to our above discussion, instead of putting out not $A$, it will put out all units, no matter what $A$ is. Similarly for the not gate of $B$.

Now consider an and gate. If either of the two relays cannot close, the output of the gate will be all zeros. For the or gate, if either relay will not close, then the input of this relay will not get through the gate but the other input will get through. If both relays will not close, then the output will be all zeros. Hence three possible outputs can occur if the or gate is malfunctioning.

We can summarize the above discussion by writing the four possible input conditions together with the outputs of each gate of the circuit, assuming that one at a time of the gates is malfunctioning:

| Input: |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 |
| $B$. | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 |
| Output: |  |  |  |  |  |  |
| Gate 1. | 1010 | $1111 \dagger$ | 1010 | 1010 | 1010 | 1010 |
| Gate 2. | 1100 | 1100 | $1111 \dagger$ | 1100 | 1100 | 1100 |
| Gate 3. | 1000 | 1100 | 1010 | $0000 \dagger$ | 1000 | 1000 |
| Gate 4. | 0001 | 0001 | 0001 | 0001 | 0000† | 0001 |
| Gate 5. | 1001 | 1101 | 1011 | 0001 | 1000 | $\left.\begin{array}{l} 1000 \\ 0001 \\ 0000 \end{array}\right\} \dagger$ |

$\dagger$ Malfunction.
Only the output of gate 5 goes to the memory and can be observed by a
computer program. Now suppose that we choose for the input to $A$ a word such that $P 4, P 3, P 2$, and $P 1$ are the bits 0101 and for $B$ a word such that $P 4, P 3, P 2$, and $P 1$ are the bits 0011 . Then the first four bits of the output word will correspond to the four different possible input conditions. Hence we can say that if $P 4, P 3, P 2$, and $P 1$ of the output word (i.e., the output of gate 5) are

1101 Then gate 1 is malfunctioning
1011 Then gate 2 is malfunctioning
0001 Then either gate 3 or gate 5 is malfunctioning
1000 Then either gate 4 or gate 5 is malfunctioning
0000 Then gate 5 is malfunctioning
Hence it becomes clear how a code can be written to determine which gate or gates are malfunctioning. Note that in some cases it cannot be determined which of two gates is malfunctioning, but only that one or the other is. Of course we can again observe that the detailed circuit design must be known in order to write such a code.

## EXERCISES

(a) Write a three-address code to check the shift-left instruction, assuming that the add, compare, and transfer instructions are operating, in addition to the memory.
(b) If add, shift-left, compare, and transfer instructions are operating, how would the multiplication instructions-both major and minor-be checked? (Hint: Be careful about not allowing any overflow when doing the additions.)
(c) Write the actual maintenance code for the gating circuit used in the above illustration. Use a one-address system.

If gate 1 is malfunctioning, put a 1 into 001
If gate 2 is malfunctioning, put a 2 into 001
If gate 3 or gate 5 is malfunctioning, put a 3 into 001
If gate 4 or gate 5 is malfunctioning, put a 4 into 001
If gate 5 is malfunctioning, put a 5 into 001
(d) Analyze the given circuit which does an extract instruction (in serial-see Chap. 2) for a maintenance code (where it is again assumed that the gates are relays that can malfunction as described above).


Exercise d

## 5-4. Interpretive Routines: Mathematical

Automatic Programming. There are two general kinds of automatic programming, called interpretive routines and compiling routines. The
purpose of automatic programming techniques is to reduce the number of instructions actually written by the coder. The method for accomplishing this is previously to place in the computer a library of subroutines that can be used by every coder, so that these routines will not have to be rewritten each time they are needed. A set, or library, of particular subroutines, together with a method for using them, is called an automatic program. The difference in the two kinds of automatic programs lies in their use: In the interpretive program the subroutines are to be used by the coder's program while it is running on the computer, whereas in the compiling program the subroutines are used by the coder's program only at the time the coder's program is read into the computer.

We have arbitrarily classified interpretive routines into two types: (1) mathematical, and (2) simulational. The subroutines of the mathematical type of interpretive routines compute values of functions, while those of the simulational type are usually designed to make one computer look like some other kind of computer.

Use of Mathematical Interpretive Routines. Let us first consider an example of a mathematical interpretive routine. The purpose of such a routine is to enable a coder to form such functions as $\sin x, \cos x, e^{x}$, $x!, \sqrt[n]{x}$, etc., merely by writing a couple of instructions. Of course these functions would appear as subroutines already in the computer, as part of the interpretive routine. However, the interpretive routine must also contain a section that can interpret the instructions that the programmer writes. When a function subroutine is to be used, the following information must be recorded: (1) the address that contains the value of the independent variable $x$; (2) the address into which the result $f(x)$ is to be put; (3) the address in the program from which the jump to the subroutine was made, so that after the subroutine has been completed the computer will know where to jump back to the original program; and (4) the address to which to jump in order to go to the subroutine itself. Consider a two-address system: two words are needed to go to a subroutine (since four addresses are required). We could arrange the words as follows:

Operation $\alpha \quad \beta$

| Return jump | Standard address | Address of 1st instruction of <br> function subroutine |
| :---: | :--- | :--- |
| ..... | Address of $x$ | Address of $f(x)$ |

The first word is a return jump instruction; the second word is not an instruction but is just to tell the subroutine where $x$ is and where $f(x)$ is to be put. Recall that the return jump instruction jumps to $\beta$, and in addition the instruction memorizes as the contents of $\alpha$ its own address. Hence the return jump takes care of items 3 and 4 above and the second word of items 1 and 2 . Thus the programmer, each time he
wants to use a subroutine listed in the interpreter library to evaluate a function, need write only the following "instructions": (a) a return jump instruction, where $\alpha$ is a standard address (standard, that is, for this particular interpreter), and where $\beta$ is looked up in a book of instructions for the interpreter which lists the proper $\beta$ for each function; (b) the word following the return jump, as described above. This has illustrated the procedure for using a mathematical interpreter.

The Interpretive Routine Itself. Now let us consider the interpreter program itself. Besides consisting of the function subroutines, as we observed above, it must also consist of a part that interprets the two words that the programmer writes. This part looks at the standard address to find out where the address of the return jump is. Knowing that the next word gives the locations of $x$ and where $f(x)$ should be put, this part of the code then relates that information to the appropriate subroutine and transfers control to this subroutine. This part can be thought of as a subroutine also; we shall call it subroutine $Q$. The flow diagram might appear as in Fig. 5-3, where, to be specific, suppose that it is desired to use a $\cos x$ subroutine. The long dashes indicate the path of the computer through the program and subroutines; the short dashes, the operating of one subroutine on another subroutine. We let $Z$ be the address of the return jump instruction; then $Z+1$ is the address of the data word, and the program should resume at address $Z+2$.

As an example of the type of things that occur in the subroutine $Q$, consider how it inserts the value of $x$ into the subroutine for $f(x)$. Subroutine $f(x)$ has a certain cell reserved for the value of $x$; call this cell $T_{x}$ for "temporary for $x$ "; within subroutine $Q$ is an instruction that transfers the value of $x$ to $T_{x}$ from the address given by the data word of the program. Suppose that the instruction were "Transfer ( $\alpha$ ) into $\beta$." Then $Q$ must have a previous instruction that puts into the $\alpha$ address of the transfer instruction the address of $x$ as given by the data word, i.e., an extract instruction that takes the $\alpha$ address of the contents of $Z+1$ and puts it into the $\alpha$ position of the transfer instruction. But this extract instruction must involve the address $Z+1$, which is obtained from the standard address associated with the return jump. Hence there must be previous instructions that take $Z$ as given in the standard address, add 1 , and insert this into the $\alpha$ part of the extract instruction. Next consider the $\beta$ part of the $x$-to- $T_{x}$ transfer instruction: this must be some address specifically reserved in the subroutine of $f(x)$ for the value of $x$. Since subroutine $Q$ is a general subroutine, it must be told this address each time a subroutine for $f(x)$ is to be used. This is done in the part of the subroutine for $f(x)$ denoted in Fig. 5-3 by "In subroutine $Q$ set $R=R_{2}, f(x)=\cos x$." In this part there is an instruction which extracts the address reserved for $x$ into the transfer instruction of subroutine $Q$. This process is valid since the computer will pass through this instruction before getting to subroutine $Q$. Summarizing, there is an instruction in the subroutine for $f(x)$ that sets $\beta$ of the transfer instruction; and there is a series of instructions preceding the transfer instruc-
tion in subroutine $Q$ that leads to the setting up of the $\alpha$ address of the transfer instruction.
Our example of a mathematical interpretive routine has several interesting features: First, one subroutine uses another subroutine-i.e., each subroutine for $f(x)$ uses the subroutine $Q$. Such a feature may occur in other ways also. For example, in evaluating $\cos x$, suppose that the power series were used,

$$
\cos x=\sum_{n=0}^{\infty}(-1)^{n} \frac{x^{2 n}}{(2 n)!}
$$

Then the subroutine for $\cos x$ will use the subroutine for $a^{x} / x!$, where $x=2 n$ in this case. In fact, to use the subroutine for $a^{x} / x!$, the same technique of the return jump and data word is used (why?). Of course the use of subroutines by subroutines can be carried deeper than two or three. Second, note how many instructions are actually needed to perform the simple transfer described above. The moral of this is that coding a simple job can be complicated on a computer. Of course this is the reason that it pays to have a separate subroutine $Q$ rather than to repeat the instructions of this subroutine for each $f(x)$ routine. Finally, the main purpose of this mathematical interpretive routine is to make the coding problem easier by allowing only two words to be written when a function is to be evaluated. Of course the process described here was greatly simplified, since many other complications may arise-telling the $f(x)$ subroutine to what accuracy the function is to be calculated, taking care of the proper scaling, etc.

## EXERCISES

(a) Write in symbolic code the series of instructions that lead to the setting up of the $\alpha$ address of the transfer instruction.
(b) How would the evaluation of a function of two independent variables affect the discussions of this section?

## 5-5. Interpretive Routines: Simulational

Use of Simulational Interpretive Routines. Next let us consider simulational interpretive routines. The purpose of these routines is to make one computer appear as an entirely different computer. For example, suppose that we had a computer that did not have floating operations. By means of the proper routine we can make this computer appear to be a computer that has built-in floating-point operations. Or we can make a one-address computer appear to be a two- or three-address computer. Another example might be the making of an ordinary computer into a special-purpose war-gaming computer. Of course the coding for the simulated computer will be quite different from the coding of the actual computer. However, the purpose of the simulational interpretive routine is to enable the programmer to write his code in the language of the simulated computer; he need never know that this is not the actual


Fig. 5-3. Flow chart of interpretive routine.
method of coding for that computer. Obviously, then, the interpretive routine must interpret every instruction of the programmer's simulationlanguage code. Thus the interpretive routine looks at the first instruction of a simulation-language code, interprets it, then goes to the next instruction of the simulation-language code, interprets it, etc., for each instruction passed through in the simulation-language code. Immedi-
ately we see that the interpretive routine must also keep track of what instruction of the simulation-language code to take next; i.e., the interpretive routine must contain a simulated-instruction address counter, a simulated "simulation-language" instruction register, simulated decoder, simulated accumulator, etc. In other words, the simulation routine must perform all the functions that the electronic circuitry would perform if the simulated computer had been real.

The Interpretive Routine Itself. For the sake of illustration let us discuss a simulation interpretive routine that makes a two-address nonfloating operation computer appear like a one-address floating operation computer. To be specific, suppose that there are 6 bits in the operation and 9 bits in each of the two addresses of the real computer. Suppose also that in the simulated computer there are to be three octal symbols for the operation and five octal symbols for the address. Of course, since the real machine can address only $2^{9}$ memory cells, even though theoretically $2^{15}$ memory cells can be addressed by the simulated oneaddress instruction, only $2^{9}$ memory cells are available. Hence three octal positions in the simulated-instruction format are meaningless. However, one could interpret these as addressing cells on magnetic tape, etc. In so far as the simulated numbers are concerned, the rightmost two octal positions of a word will represent the exponent, the rest of the positions the value of the number. These formats are then as follows, where each wide box represents an octal digit (i.e., three binary bits):


Let us suppose that the real computer has the two-address operations listed in Sec. 3-8, as well as the following additional instructions:
Code Description of operation
$30 \quad$ Shift (acc) to left $\alpha$ positions; put result into $\beta$
$31 \quad$ Shift (acc) to right $\alpha$ positions; put result into $\beta$
20 Extract ( $\alpha$ ) into $\beta$, using (acc) as the mask; i.e., replace those bits of ( $\beta$ ) with corresponding bits of ( $\alpha$ ) in those positions where (acc) has units, and put result into $\beta$

Suppose that the one-address instructions to be simulated are:

## Description of operation

001 Add ( $\alpha$ ) to (acc), put result in acc, floating unnormalized
002 Multiply ( $\alpha$ ) by (acc), put result in inc, floating unnormalized
003 Subtract ( $\alpha$ ) from (acc), put result in acc, floating unnormalized
004 Divide (acc) by ( $\alpha$ ), put result in acc, floating unnormalized
005 Conditional jump: if (acc) is negative, take ( $\alpha$ ) as next instruction
006 Transfer (ace) into $\alpha$
007 Jump: take ( $\alpha$ ) as next instruction
Of course the accumulator referred to in these instructions is the simulated accumulator. To be more specific, let address 776 be the simu-lated-instruction address counter, 775 the simulated-instruction register, 774 the simulated accumulator.


Fig. 5-4. General flow diagram indicating how interpretive routine sequences the computer through the simulation-language code.

The programmer will now code in terms of these simulated instructions only (never writing down any of the real instructions). It is up to the interpretive routine to sequence through these simulation-language instructions, interpreting them as it goes along. Obviously the interpretive routine is written in the real machine language. Figure 5-4 is a general flow diagram showing how the interpretive routine sequences the computer through the simulation-language instruction code. The
student should study it carefully. We shall first discuss some of the details of box 1 of this flow diagram.

The heart of box 1 is a pair of instructions that transfer the proper simulation-language instruction from its location in the code to the simulated-instruction register. Preceding this pair of instructions are instructions that set up this pair to operate on the proper addresses. In symbolic code, the pair might look like this:

| $\alpha$ | $\beta$ |  |
| :---: | :--- | :--- |
| Add, i.e., <br> 53 | Address of a constant of all <br> zeross, i.e., $\phi$ | Address of proper simula- <br> tion-language instruction |
| Transfer, <br> i.e., 52 | Simulated-instruction regis- <br> ter, i.e., 775 | Address of first instruction <br> of box 2 |

The address of the proper simulation-language instruction is found in the simulated-instruction address counter. Hence the contents of the $\beta$ part of this word (i.e., the contents of 776) must first be extracted into the $\beta$ part of our add instructions:

| Operation | $\alpha$ | $\beta$ | Remarks |
| :---: | :---: | :---: | :---: |
| Add, i.e., <br> 53 $\phi$ Address of a constant that has all <br> units in $\beta$ position and zeros else- <br> where | Set up mask |  |  |
| Extract, <br> i.e., 20 | 776 | Address of above add instruction | Do extraction |

Suppose that we put the first instruction of box 1 into address 600; then we would have altogether for box 1:

| Address | Operation | $\alpha$ | $\beta$ | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| 600 | 53 | 604 | 605 | Set up mask |
| 601 | 20 | 776 | 602 | Do extraction |
| 602 | 53 | 604 | $\cdots$ | Transfer |
| 603 | 52 | 775 | 606 | fransfer |
| 604 | 00 | 000 | 000 | Zero constant, i.e., $\phi$ |
| 605 | 00 | 000 | 777 | Mask |

Each of the simulation-language operations is performed, of course, by a subroutine contained as part of the interpreter routine. Hence box 2 consists of these subroutines, in addition to a jumping table that looks at the simulation-language operation and jumps to the proper subroutine. The shift instruction would be used in this procedure. The simulation-
language instruction is shifted to the right 17 (octal) positions [15 (decimal )], putting the operation code in the $\beta$ position, leaving zeros elsewhere. Then this shifted word is added to the transfer instruction that will jump to the proper jump instruction of the jump table. In this way the simulated operation code is used to enter the proper subroutine from the jump table. Note that first the transfer instruction that jumps to the table must be reset, for it becomes modified each time it is used. Hence, in the first part of box 2 , we have:

| Address | Operation | $\alpha$ | $\beta$ | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| 606 | 53 | 604 | 610 | $\left.\begin{array}{l} \text { Put jump constant into } \\ \text { accumulator } \end{array}\right\} \text { Reset jump }$ |
| 607 | 52 | 614 | 611 | Put constant into 614 instruction |
| 610 | 52 | 777 | 614 | Constant used to reset jump instruction |
| 611 | 53 | 604 | 775 | Shift simulated-language instruction to |
| 612 | 31 | 017 | 777 | $\}$ right 17 (octal) positions in accumulator |
| 613 | 51 | 614 | 614 | Add shifted instruction to jump instruction |
| 614 | 52 | 777 | 614 | Jump instruction |
| 615 | 52 | 777 | Add subroutine |  |
| 616 | 52 | 777 | Multiply subroutine |  |
| 617 | 52 | 777 | Subtract subroutine |  |
| 620 | 52 | 777 | Divide subroutine | Jump table that sends control to proper |
| 621 | 52 | 777 | Conditional <br> jump <br> subroutine | (simulated operation subroutine |
| 622 | 52 | 777 | Transfer subroutine |  |
| 623 | 52 | 777 | Jump subroutine |  |

When a 52 or transfer instruction is used as a jump, the $\alpha$ address does not have much meaning. Hence we always put 777, the address of the real accumulator, for $\alpha$ to ensure no change due to this part of the jump instruction.

Let us examine briefly the subroutine for the simulation-language multiplication, floating unnormalized, as an example of our arithmetic subroutines. The purpose of this subroutine is to multiply ( $\alpha$ ) by (774), where $\alpha$ is the address found in the contents of 775, the simulatedinstruction register (see the instruction and number formats for the simulated computer above). The result is to be put into 774, the simulated accumulator. In order to perform this multiplication, $P 7$ through P24 of each word are to be multiplied, while $P 1$ through $P 6$ of each word are extracted into initially empty temporaries, the temporaries
are added, and the result extracted into $P 1$ through $P 6$ of 774 . In performing the addition, P7 of the sum must be checked for overflow: the exponent of the result cannot be larger than six positions. After performing such a subroutine the computer would go to box 3 of the general flow chart.

## EXERCISES

(a) Write out the subroutine for the multiplication, floating unnormalized, in detail, letting 500 be the address of the first instruction.
(b) Write out a subroutine for the divide, floating unnormalized.
(c) Write out the codes for boxes 3 to 6 of the flow chart of Fig. 5-4.

## 5-6. Memory Space, Speed of Computation, and Automatic Programming

Sharing of the High-speed Memory. As we have seen above, a computer can have a high-speed memory (often magnetic cores), a mediumspeed memory (magnetic drums), and finally, a slow-speed memory (magnetic tapes). As one might guess from our previous discussions, the high-speed memory may often be filled when an interpretive routine is stored in addition to a program. Hence careful attention must be paid to the location of the interpretive routine so that it will not interfere with memory space required for the program. It may often happen that the interpretive routine has to be stored on the drum. This may slow up the rate of computation because, as will be recalled, in order to use a word from the drum one must wait for the drum to turn to the proper address before a word can be read out.

This problem may be approached as follows: At the time a particular subroutine of the interpretive routine is to be used, this subroutine is transferred out of the drum into the high-speed memory, where the computations take place. In this way subroutines of the interpretive routines will be performed in the high-speed memory even though they are usually stored in the drum. However, this means that subroutines must be continually transferred out of the drum and into the high-speed memory and back into the drum, which takes precious time. Also, we have added a new requirement for the interpretive routine to perform. Now it must not only interpret the simulated instructions but must also transfer from the drum to the high-speed memory the subroutines of the interpretive routine as they are needed, and then transfer the subroutine back to the drum.

Complications. This problem becomes quite complicated when one is desirous of putting some flexibility into the procedure; for, in general, when transferring a subroutine from the drum to the high-speed memory it is best to be able to put the subroutine in that part of the high-speed memory which may not be in use at the moment. Hence it must be determined where in the high-speed memory to transfer the subroutine. This means that a subroutine may be located in different places when
used at different times. Obviously the assignment of addresses often depends upon the exact location of the instructions being performed. Hence the interpretive routine must be able to translate this subroutine and fix up the addresses as required, depending upon the location of the subroutine. We shall discuss this problem in the next section in more detail.

The complexity of an interpretive routine can be increased still further. Observe, for example, that a function subroutine may be used repeatedly in the course of computation and hence it might be desired to leave it in the high-speed memory' after it has been transferred there. Other subroutines that are transferred to the high-speed memory may have to be used only once in that program and hence after their use need not take up room in the high-speed memory. Therefore a distinction must be made as to subroutines that should be transferred temporarily. Further, during the computation for a problem, one subroutine may use another subroutine. Suppose that both these subroutines have already been transferred to the high-speed memory. Somehow the interpretive routine should remember not only that these subroutines have already been transferred to the high-speed memory so that the transfer will not have to be repeated, but also where they have been put. The solutions to these problems are too complex to be treated in this textbook. Our purpose has been to give the student an appreciation of the complexities that can develop in planning and writing interpretive routines.

Advantages of the Compiler Routine. Until now we have been considering the use of subroutines as the interpretation of simulation instructions during the running or computation of a program. An alternative method is initially to replace the simulation instructions with the proper subroutines before the program is run. That is, the program is written in terms of simulation instructions, but as the program is read into the computer, these simulation instructions are automatically replaced by the proper subroutines-the subroutines then becoming an integral part of the program. Of course, just as the interpretive routine handled the subroutines in our above discussions, so in this new case an automatic routine called a compiler routine performs the task of initially inserting the proper routines into the program. Examples of compiler routines will be described in the next section; in this section we wish only to discuss why such routines are used.

The first advantage of a compiler routine over the interpretive routine is that, since in the compiler routine the subroutines are initially amalgamated into the program before the problem is run, the necessity for transferring subroutines from drum to high-speed memory is eliminated. Hence the problem of time lost in transferring subroutines during computation no longer appears, because the subroutines will already have been made part of the main program. Another important advantage of the compiler routine over the interpreter routine is that, since the compiler routine is only used initially, it need not be stored in the computer when
the compiled program is running. The interpreter routine must always remain in the computer memory since it operates during the running of the program. Hence, when a compiled routine is run, more space is available for the main program.

On the other hand, as can immediately be seen, after all the required subroutines have been incorporated into the main program, this program can be exceedingly long. Some of the space advantage of a compiler routine is thereby lost. The usual method for handling such long programs is to divide them up into sections, each of which can fit entirely into the high-speed memory. Then one section at a time is put into the high-speed memory and computed. Meanwhile the other sections are stored in the drum and on the magnetic tapes. Of course a relatively great amount of time is spent in changing sections from drum and magnetic tape to high-speed memory, and hence some of the timesaving advantages of the compiler routine are lost. The relative advantages of a compiler routine over an interpretive routine, if any, depend on the particular characteristics of the routines in question as well as on those of the program to which the routines may be applied. Further, compiler routines can become very complicated, for the compiler routine must break the program into the proper sections and assign the sections to parts of the drum or magnetic tapes. It must also form instructions additional to the main routine which will change sections at the proper time. Another problem arises when a subroutine appears in a program many times. For example, suppose that the program uses the sine routine often. It would be wasting space to compile the $\sin x$ routine each time it is required, having duplicates of this $\sin x$ routine incorporated into the program. It would be much wiser to have only one sine routine in the memory and to use it in the manner of a usual subroutine. If the program is compiled as it is read in, the compiling routine must sense that the $\sin x$ subroutine will be used many times and so must arrange to have it as a subroutine. Of course, if we have too many subroutines, so many that we have to put some in the drum, then we are in the dilemma described for the interpretive routine.

In the previous section we have discussed interpretive routines that enable a program to utilize subroutines while it is being computed. We have seen that owing to lack of high-speed-memory space this can be a slow process. The alternative, namely, that of compiling a program as it is read in, is considered in the following section. We must always keep in mind that the major object in using either interpretive or compiling routines is to reduce the amount of coding that the programmer must do.

## 5-7. Compiling Routines: Translator; Address Assigner

Kinds of Compiler Routines. The purpose of a compiling routine is to reduce the amount of necessary coding by allowing the programmer to write simulated-language instructions which are interpreted by the
compiling routine. The difference between interpretive and compiling routines is that a compiling routine can be erased from the high-speed memory after it has completed its task. Evidently a compiling routine can compile mathematical subroutines as well as interpret and compile simulation subroutines of the kind described in Sec. 5-5. However, there are other uses of compiling routines that lend themselves more to the technique, and this section and the one following are devoted to these. We shall consider four such uses: (1) as a translator, (2) as an address assigner, (3) as a decoder of algebraic symbols, and (4) as a decoder of recursion, or loop, symbols.

Translator. Suppose that we are considering a decimal-coded binary computer for which we have written a symbolic code. Ordinarily specific addresses would have to be assigned before the symbolic code were put into the computer. However, it is possible to construct a compiling routine that enables the symbolic code itself to be read into the computer, the addresses being assigned automatically by the compiler. Such a compiler is called a translator, since it translates from symbolic language into computer language. In these discussions the student should keep in mind that two codes are under consideration: the compiler routine itself and some program upon which the compiler operates.

To be specific, let us consider a one-address decimal-coded binary instruction format having two characters for the operation and three for the address. Suppose, for simplicity in illustration, that the program is to add two numbers, 8,818 and 7,080 . The symbolic code for this might be:

| Address | Instruction |  | Remarks |
| :---: | :---: | :---: | :---: |
|  | Operation | $\alpha$ |  |
| CLR | MT | ZRO | Clear accumulator |
| A1C | AD | 1ST | Add 1st number to accumulator |
| A2C | AD | 2ND | Add 2d number to accumulator |
| TRR | TR | SUM | Transfer result into sum temporary |
| 1ST | 08 | 818 | 1st number |
| 2ND | 07 | 080 | 2 d number |
| ZRO | 00 | 000 | 0 constant |
| SUM |  |  | Result: sum temporary |

If the compiler routine is to assign addresses to these instructions and numbers, then, in addition to the instructions themselves, in symbolic form, the symbolic address corresponding to each instruction, constant, or temporary must also be read into the computer. We might make the convention that the symbolic address will be read in immediately preceding its associated symbolic contents. For example, for our code we
would initially read the following into the computer:
$\left.\begin{array}{cc} & \text { CLR } \\ \text { MT } & \text { ZRO } \\ & \text { A1C } \\ \text { AD } & \text { 1ST } \\ & \\ \text { A2C } \\ \text { AD } & \text { 2ND } \\ & \text { TRR } \\ \text { TR } & \text { SUM }\end{array}\right\}$ Instructions
$\left.\begin{array}{ll} & \text { 1ST } \\ 08 & 818 \\ & 2 \mathrm{ND} \\ 07 & 080 \\ & \\ & \text { ZRO } \\ 00 & 000 \\ & \text { SUM } \\ 00 & 000\end{array}\right\}$ Constants and temporaries

As yet there is no way for the compiler to distinguish between instructions and constants or temporaries. If the convention were made that only instructions will appear first and that all the constants and temporaries are to be put at the end, and if, in addition, the number of instructions in the program were to be given to the compiler, then the compiler would be able to distinguish the instructions from the constants and temporaries. Of course the desired first address of the program must also be given to the compiler. Hence one word would precede the symbolic code, with the convention that the number of instructions appears in the operation positions and the first address appears in the $\alpha$ positions. For our example this first word would be

$$
04 \quad 600
$$

if we desired the code to begin at address 600 . Of course the symbolic code with its first word must be read into a standard position in the computer memory so that the compiler routine will know where to work. Suppose that the convention is made that the symbolic code is to be read into the memory starting with the first word in address 001.

Writing the Translator Compiler Routine. It now remains to discuss how to form a compiler routine that will assign specific addresses to a code when all the above-described conventions are adhered to. A general flow diagram for such a compiler appears in Fig. 5-5.

Consider box 1 of Fig. 5-5. First the real addresses would be assigned to the symbolic addresses of the instructions. By our conventions it is known that these symbolic addresses are found in every other word of the
symbolic code, starting with the second word. The first symbolic address is assigned to the address found in the $\alpha$ position of the first word of the code. Next the assignment of real addresses for the constants and temporaries is made. This is done by looking at the contents of each instruction: if the symbolic address (in its $\alpha$ position) is not that of another instruction, then it must be that of a constant or temporary. Such addresses are then assigned in sequence. (Note that we cannot have the compiler assign addresses to the constants and temporaries in the same manner as it did for the instructions since we have not informed the compiler of how many constants and temporaries there are.) A detailed flow diagram of box 1 appears in Fig. 5-6.

Now that a table has been computed assigning real addresses for the symbolic addresses, the instructions and constants can be transferred into these locations, with the $\alpha$ positions of the instructions changed from the symbolic to the real address. Our convention of preceding each instruction and constant by its symbolic address again plays an impor-


Fig. 5-5. General flow chart of a compiler routine. tant role. When the code is compiled into its real position, the instructions and constants will appear in the usual consecutive sequence.

Finally we must replace the symbolic operation code with the real operation code. For this the compiler routine must be given a table relating these operation codes.

Several further details must be observed. There are some instructions in which no address appears in the $\alpha$ positions, e.g., shift instructions where the number of positions to be shifted appears instead. Care must be taken that this is not interpreted as a symbolic address to be assigned a real corresponding address. Hence the instruction itself must be examined by the compiler to ensure that it is not one of these exceptional cases. Also, some constants may involve a symbolic address. Care must be taken to recognize these and replace them with the proper real address.

Summarizing, we can draw the following conclusions from our example: First, the writing of a compiling routine can be "tricky" if we are to be certain that all possibilities are taken care of. Second, in order to use a compiler routine, the programmer must adhere carefully to all conventions required by the routine.

Address Assigner. Suppose that it is desired to write many subroutines and it is not known beforehand where they are to be located in the memory. One procedure might be to write each subroutine as if it were to be located with its first instruction in some standard address,
say 003, and then later to use a compiler to assign new addresses to each subroutine when the final decision is made as to where it shall be located. (Recall that a similar requirement arose in connection with the transferring of subroutines from the drum to various locations in the highspeed memory.) To perform this task, the compiler routine merely has


Fig. 5-6. Detailed flow chart of box 1 of Fig. 5-5.
to add to each address appearing in the code the difference between the desired address of the first instruction and 003 . The only problem is to determine which are the addresses. For some instructions such as shift instructions do not contain addresses in all the address positions, and these positions should not be changed. On the other hand some constants may contain addresses, and these must be recognized and changed. One procedure is to require the programmer to list all the instructions first, then any constants that contain an address, finally any other
constants. In addition the programmer is required to insert words in front of the program that list (1) the desired address of the first instruction, (2) the total number of words in the code, (3) the total number of instructions in the code, and (4) the total number of words other than instructions that contain addresses. Suppose that we were considering a two-address system; we could then put these numbers, respectively, into the $\alpha$ and $\beta$ positions of the word in 001 and the $\alpha$ and $\beta$ positions of the word in 002.

The compiler routine will first determine which instructions contain addresses and will add to these addresses appropriately. Next the program will look in the $\alpha$ and $\beta$ positions of the constants that have addresses-recognizing these addresses as numbers between 003 and 003 + the total number of words in the code-and will add to these addresses appropriately. Finally the compiler routine will transfer the code from the standard position to the required position.

## EXERCISES

(a) Write the specific code for the flow diagram of Fig. 5-6.
(b) Write the code for box 2 of Fig. 5-5.
(c) Draw a detailed flow diagram for the address-assigner compiler routine described in this section.

## 5-8. Compiling Routines: Algebraic

Decoder of Algebraic Symbols. The purpose of this compiling routine is to enable the programmer merely to type into the computer an algebraic formula, the compiling routine automatically writing the detailed machine language code. Of course the programmer must also tell the compiling routine in what addresses the values of the independent variables will be found and into which address the result is to be placed. Let us consider first a function involving only the operations addition and multiplication, such as $((((a+b) \cdot c)+d) \cdot e)$. In order to avoid ambiguity, certain conventions must be observed: A dot is to be used for multiplication; i.e., we must write $a \cdot b$ and not $a b$. Also the parentheses must be placed wherever necessary and never left understood. For example, $a+b \cdot c$ is never written, but rather $(a+(b \cdot c))$. There is to be a parenthesis at the beginning and at the end of the function. Also the parentheses are to indicate binary operations only-i.e., operations involving two operands and no more. Thus $a+b+c$ would never be written, but rather $((a+b)+c)$-or $(a+(b+c))$; it makes no difference. Similarly, $a \cdot b \cdot c$ must be written as $((a \cdot b) \cdot c)$.

Evidently the parentheses play an important role in such a formulafor they tell in what order operations are to be performed. For example, in $((((a+b) \cdot c)+d) \cdot e)$ the order in which the operations must be performed is $a+b=w ; w \cdot c=x ; x+d=y ; y \cdot e=z$, where $z$ is the final result. A study of the proper use of parentheses shows that they are
never ambiguous. $\dagger$ To see which operations should be done first, number the parentheses, say from left to right. Successive opening parentheses get successively larger numbers from left to right. A closing parenthesis directly facing an opening parenthesis is given the same number as that opening parenthesis. Other closing parentheses are given the next successive lower numbers that have not previously been used on a closing parenthesis.

Consider the following illustrations:

$$
\begin{align*}
& \left.\left.\left.\underset{1234}{(()}(\underset{4}{ }+\underset{3}{ }) \cdot{ }_{2}\right)+d\right) \cdot e\right)  \tag{1}\\
& \underset{12}{((a \cdot} \underset{3}{(b}+c))+\underset{32}{(d} \cdot(e+f)))  \tag{2}\\
& \left.\underset{1234}{((((a \cdot b)}+\underset{5}{(c} \cdot d)) \cdot e)_{2}\right)+\left(\left(\left(g+h_{8}\right)+\underset{9}{(k}+\underset{97}{ }\right) \cdot m_{61}\right) \tag{3}
\end{align*}
$$

Notice that a pair of opening and closing parentheses turns out to have the same number, which was of course the purpose for the above numbering rules. Also there are the same number of pairs of parentheses as there are + and operations in the expression.

Now we have gained some insight into how a compiling routine might work to code an algebraic function automatically. The compiling routine would number the parentheses according to the above rule and would then proceed to write instructions to perform the operations between directly facing opening and closing parentheses which will have the same number: i.e., in illustration (1), to compute $(a+b)$; in illustration (2), to compute $(\underset{3}{(b}+\underset{3}{ })$ and $\underset{5}{(e}+f)$; in illustration (3), to compute $\underset{4}{(a \cdot b)}$, $\underset{5}{(c \cdot d)},(g+h)$, and $\underset{9}{(k+l)}{ }_{9}$. Each of these sets of symbols would then be replaced by the result of the operation: i.e., in illustration (1) let $s=a+b$; then (1) would read $\underset{123}{(((s \cdot c)} \underset{3}{c}+\underset{2}{d)} \cdot e)$, In (2) let $t=b+c$ and $u=e+f$; then (2) would read $((a \cdot t)+(d \cdot u))$. In (3) let $v=a \cdot b, w=c \cdot d, x=g+h$, and $y=k+l$; then (3) would read $\left.\left.\left.{ }_{123}^{((v}+w_{3}\right) \cdot e\right)_{2}+\underset{67}{ }(x+y) \cdot m_{61}\right)$. The computations between the new facing pairs is carried out. Thus in (1) instructions to compute $\underset{3}{(s \cdot c)}$ would be written; in (2) instructions to compute $\underset{2}{(a \cdot t)}$ and $\underset{4}{(d \cdot u)} \underset{4}{ }$ would be written; and in (3) instructions to compute $\left.\underset{3}{(v}+w_{3}\right)$ and $\left.\underset{7}{( } x+y\right)$ would be written. In this way the code for systematically evaluating the function would be constructed.

Writing the Algebraic Compiler. To describe possible additional details of such a compiling routine, suppose that we consider a three-address system with 12 bits in each address and 6 bits for the operation. Hence

[^1]words will be 42 bits, plus a sign bit, long. Now suppose that we arrange for the paper-tape punch machine to punch a 7 -bit code to distinguish among letters of the alphabet and the symbols (, ), $\cdot$, and + . That is, when a key corresponding to a letter of the alphabet or a symbol is pushed, a unique 7 -bit code will be punched on the paper tape. Then successive words will contain the formula; i.e., for illustration (1) we shall need $17 \times 7=119$ bits, or 2 and $5 / 6$ words. Let us suppose that the first two bits of the 7-bit code tell whether or not this is the code for a parenthesis, operation, or letter; for example, 10 ___ is a parenthesis, $01 \ldots$ is an operation, $11 \ldots$ is a letter. In particular let (be 1000000 and ) be 1010000 . Then, when the compiling routine counts parentheses, the count can be put into the rightmost four position, for example, 1000101 would be (, and 1010101 would be ). (Of course this limits us to 16 pairs of parentheses, but these suffice for our example.) Also we could have up to 32 different kinds of operations. Let + be 0100001 and - be 0100010. Let the letters of the alphabet be denoted by their position in the alphabet, that is, $a$ is $1100001, b$ is 1100010 , $c$ is $1100011, \ldots, ., z$ is 1111010 . For example, illustration (1) would look as follows after being punched and read into the computer:

| 100 | 0000 | 100 | 0000 | 100 | 0000 | 100 | 0000 | 110 | 0001 | 010 | 0001 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 110 | 0010 | 101 | 0000 | 010 | 0010 | 110 | 0011 | 101 | 0000 | 010 | 0001 |
| 110 | 0100 | 101 | 0000 | 010 | 0010 | 110 | 0101 | 101 | 0000 | 000 | 0000 |

where the last seven bits of the third word are filled in as all zeros and it is to be understood that seven zeros have no meaning for a formula.

First the compiling routine will number the parentheses as described above. The result will be

| 100 | 0001 | 100 | 0010 | 100 | 0011 | 100 | 0100 | 110 | 0001 | 010 | 0001 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 110 | 0010 | 101 | 0100 | 010 | 0010 | 110 | 0011 | 101 | 0011 | 010 | 0001 |
| 110 | 0100 | 101 | 0010 | 010 | 0010 | 110 | 0101 | 101 | 0001 | 000 | 0000 |

Next the compiling routine will search these words to determine which instructions to write first, as described above. After doing this, it will assign another letter to the combination and put all zeros in the 7-bit groups no longer needed. In illustration (1), as we have seen, instructions to compute $(a+b)$ would be written, and then the substitution $s=\underset{4}{(a}+\underset{4}{b}$ ) would be made, resulting in the following for our three words:

| 100 | 0001 | 100 | 0010 | 100 | 0011 | 000 | 0000 | 111 | 0011 | 000 | 0000 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 000 | 0000 | 000 | 0000 | 010 | 0010 | 110 | 0011 | 101 | 0011 | 010 | 0001 |
| 110 | 0100 | 101 | 0010 | 010 | 0010 | 110 | 0101 | 101 | 0001 | 000 | 0000 |

where it is to be recalled that seven zeros are to be ignored. With these new numbers the same thing is repeated, etc. The flow diagram therefore becomes as in Fig. 5-7.

It can easily be seen how other operations such as division and subtraction can be included in the repertoire of the compiling routine. Note that five groups of memory addresses are involved in this compiling routine:

1. The locations of the compiling routine itself
2. The locations of the words punched from the symbols
3. The location of the table relating the letters of the function to the addresses that will contain the values of these letters as independent variables
4. The location of the values of the independent variables

5 . The location of the program written by the compiling routine
When the compiling routine is writing the function-evaluation pro-


Fig. 5-7. Flow chart of algebraic-compiler routine. gram, (1) to (5) are needed; when the resulting program is being run, only (4) and (5) are needed.

Recursive Compiler. Consider the problem of constructing a compiler program that will automatically code loops. This problem can become very complicated, depending on the generality with which it is desired to have the program perform. $\dagger$ However, to illustrate the concept, let us consider the following oversimplified example. Suppose that we desire to construct a compiler that will evaluate a single function by successive substitutions-in other words, one that will automatically construct a code to perform the flow diagram of Fig. 5-8. Here let us assume that the function $f(x)$ is given by a subroutine: then the only information the compiler needs is the number of the subroutine for $f(x)$, the initial value of $x$, namely, $x_{0}$, and the accuracy $\epsilon$ for which the function is to be evaluated. Of course in this oversimplified case we are tacitly assuming that $f(x)$ has certain properties. (Why?)

One very simple way of constructing such a compiler is to write a code as indicated by the flow diagram of Fig. 5-8. Then all the compiler need do is interpret the form in which a particular $f(x), x_{0}$, and $\epsilon$ are introduced into the computer and put these values into the proper addresses of the code. Of course conventions must be made for the form of the particular $f(x), x_{0}$, and $\epsilon$, for the exit, and for the final location of the compiled code.

Simple extensions of such a compiler might enable it to compile loops
$\dagger$ For example, see Edward K. Blum, Automatic Digital Encoding System II, NAVORD Repts. 4209 and 4411.
within loops, where now some notation must be introduced to tell the compiler which loops are within which loops. We may make the compiler more versatile by enabling it to form partial products or partial sums as well as successive iterations. Again perhaps more general functions than these can be introduced. The whole thing could be


Fig. 5-8. Flow chart for the evaluation of a single function.
integrated and amalgamated with the algebraic compiler to act as one large compiler, and so forth.

## EXERCISES

(a) To use the algebraic-compiler routine, a word should precede the code for the symbols of the function. What information do you think the compiling routine should obtain from this word?
(b) Write a subroutine, using a three-address system, that would be contained in the algebraic compiler to number the parentheses.
(c) Write a program for the simplified recursive compiler.

## 5-9. The International Algebraic Language (ALGOL)

Languages. The purpose of automatic programming is to make the computer itself help prepare the program or code, thereby minimizing the amount of writing the programmer must do. In previous sections we have studied how the computer can be prepared or precoded with various automatic programs to aid the use of subroutine, to translate symbolic codes, to transfer parts of a code, to decode algebraic symbols, and to compile a loop, or recursion code. There were essentially two parts to each of these discussions: the part that told how to use the automatic program in writing a code, and the part that described how the automatic program itself could be constructed. We have been building up to the idea of a general automatic language system, where the procedures for
using a combination of such automatic programs are unified and standardized (i.e., the language), and where the collection of such automatic programs themselves are made compatible with each other (i.e., the system).

Two processes are involved: First unified language itself (i.e., the procedures for using the automatic programs) must be established. Second, for the particular computer involved, the system of compatible automatic programs themselves must be constructed to enable the computer to interpret codes written in the language and compile the actual instructions to be executed. The principles involved in the latter process have already been considered in previous sections (see Exercises $a$ and $b$ below) and therefore are not considered here. We shall limit our discussion in this section to the former process and illustrate the principles involved in terms of a certain unified language.

With the combinations of methods presented in previous sections it is clear that a language can be devised that is independent of particular computer instructions. Thus a code can be written in terms of the language alone, and specific computer instructions need never be mentioned. If automatic programs were written for different computers to interpret the same language, then any code written in the language could be run equally well on any of the different computers. This fact indicates the feasibility of the important concept of establishing an international automatic language that may be universally accepted, analogous to the universal language of written music. Toward this goal the Association for Computing Machinery, representing American computer users, and the Association for Applied Mathematics and Mechanics, representing European computer users, sent representatives to Zurich, Switzerland, in May, 1958, to define a generally acceptable automatic language. The language agreed upon by this meeting has been named $A L G O L$, for "algorithmic language." In the remainder of this section we shall present a simplified version of ALGOL. (See also Sec. 5-10, Additional Topics.)

Anatomy of a Language. ALGOL and the simplification to be described are called algebraic languages. The term algebraic refers to the fact that they are intended primarily for algebraic computations. In general the requirements for a language are similar to the requirements for a specific instruction system: it must be able to tell a computer how to compute a function, to jump out of a normal sequence of computations, to decide between alternatives, to compute loops, or recursion processes, and to use subroutines.

Three syntactical entities are distinguished: expressions, statements, and declarations. The statement is the operational unit that tells the computer what to do and is analogous to a generalized instruction. Statements are composed of expressions combined with delimiters (i.e., punctuation marks, etc.), where expressions are numbers, names, labels (i.e., symbolic addresses), etc. Declarations are composed as are statements but are not operational, i.e., they tell the automatic programs certain
facts about the entities referred to within the program, such as whether a variable is floating or a fixed point, the size of an array, the definition of a function, or what variables are required by a subroutine.

In order to illustrate how our language works, consider the following simple example of a code to compute the roots of $A x^{2}+B x+C=0$ for $A=+3, B=+1.7$, and $C=-0.31$. One of the two roots is given by

$$
x=\frac{-B+\sqrt{B^{2}-4 A C}}{2 A}
$$

Then the code becomes

$$
\begin{aligned}
; \mathrm{A}:=3 ; \mathrm{B}:=1.7 & ; \mathrm{C}:=-0.31 ; \\
& r o o t:=(-\mathrm{B}+\operatorname{sqrt}(\mathrm{B} \uparrow 2 \downarrow-4 \times \mathrm{A} \times \mathrm{C})) /(2 \times \mathrm{A}) ; \text { stop } ;
\end{aligned}
$$

The meaning of this jumble of symbols becomes more or less obvious with the following explanation: First the symbols between semicolons (; . . . ;) are statements. This is analogous to putting instructions, constants, etc., on the separate lines of a coding sheet or to placing English sentences between periods. Statements are normally executed in sequence. The first three statements record the desired values of $A, B$, and $C$; the fourth statement computes the root; and the last statement stops the routine. In our example the expressions are $\mathbf{A}, \mathbf{3}, \mathbf{B}$, 1.7, C, -0.31 , root, $2,4, \mathrm{C}, \operatorname{sqrt}(\mathrm{B} \uparrow 2 \downarrow-4 \times \mathrm{A} \times \mathrm{C})$, and stop. The other symbols, namely, $:=,-\uparrow, \times, /, \uparrow, \downarrow,($,$) , and the semicolon; , are the$ delimiters. The automatic program that is to interpret this language compiles the appropriate instructions, and in case of the square root (sqrt) refers to the appropriate subroutine in the library.

In the following paragraphs we shall describe the detailed anatomy of our language in more formal terms.

Expressions. We shall distinguish five types of expressions: (1) numbers, (2) simple variables, (3) subscripted variables, (4) functions, and (5) arithmetic expressions.

1. If $a$ represents a digit, that is, $0,1, \ldots, 9$, then a number can be an integer $a a \cdot \cdots a$, a fraction $a a \cdot \cdots a$, or a scale factor ${ }_{10} \pm a a \cdots \cdots$, or any combination of these. For example, 6, 4,711, 137.06, 2.9997 ${ }_{10} 12$ $\left(=2.9997 \times 10^{12}\right),{ }_{10}-12$, and $3_{10}-12$ are numbers. In this language a number can only be the contents of an address, and not the address itself.
2. Simple variables are designations for numbers or scalar quantities, as used in ordinary algebra. A little reflection will show that a simple variable is essentially an address whose contents is the numerical value of the variable. Simple variables may be represented by several adjacent characters the first of which must be a letter, not a number (so that numbers and simple variables may be distinguished). For example, b, P63, QR82T, ALPHA are all simple variables.
3. Subscripted variables designate the addresses of quantities that are components of multidimensional arrays, such as, for example, the com-
ponents of a list, a vector, or a matrix, etc. What would normally be the subscripts are placed in brackets. Thus a vector $V_{i}$ would be written as VECTOR[i], a matrix $M_{i, j}$ as MATRIX[i,j], and so forth. The "subscripts" themselves may appear as integral numbers, simple variables, subscripted variables, or arithmetic expressions (see below). Note that subscripts are intrinsically integer-valued, no matter in what form they appear. The comma distinguishes the different subscripts; e.g., a three-subscripted variable is VAR[6,ALPHA, $3 \times \mathrm{i}+\mathrm{k}$ ].
4. Functions are denoted by the usual algebraic functional notation: The independent variables, which can be simple variables, subscripted variables, or other functions, are enclosed in parentheses and separated by commas, for example, FUNCT ( $x, y, z$ ), where FUNCT (that is, the function name) can be thought of as essentially the first address of a subroutine that can evaluate the function. The ( $x, y, z$ ) is the ordered set of independent variables, the numerical values of which must be ascertained before evaluating the function. Certain function names should be reserved for the standard functions, such as $a b s(\mathbb{N})$ for the absolute value of a variable $N, \operatorname{sign}(\mathrm{~N})$ for the sign (i.e., + or - ) of the value $N, \operatorname{sqrt}(\mathbb{N})$ for the square root of $N, \sin (\theta)$ for the sine of $\theta$, and so forth.
5. Arithmetic expressions are combinations of simple variables, subscripted variables, or functions with the operators,,$+- \times$, and /, which have the usual meaning of addition, subtraction, multiplication, and division, respectively. A pair of arrows $\uparrow$ and $\downarrow$ are used for exponentiation, i.e., raising to a power. For example, $2 \uparrow 3 \downarrow$ means $2^{3}$, $2 \uparrow 3 \uparrow 4 \downarrow \downarrow$ means $2^{\left(3^{4}\right)}, 2 \uparrow 3 \downarrow \uparrow 4 \downarrow$ means $\left(2^{3}\right)^{4}$, and so forth. Ordinary parentheses are evaluated as described in the preceding section, except that the following rule of precedence can be used: $\times$ or $/$ before + or - . Thus $a+b \times c$ means $a+(b \times c)$. However, $(a \times b) / c$ should be used rather than $a \times b / c$. An example of the use of all these symbols is the arithmetic expression

$$
(-\mathrm{B}+\operatorname{sqrt}(\mathrm{B} \uparrow 2 \downarrow-4 \times \mathrm{A} \times \mathrm{C})) /(2 \times \mathrm{A}) \quad \text { for } \quad \frac{-B+\sqrt{B^{2}-4 A C}}{2 A}
$$

Finally it is important to remember that an expression which is not an actual number really (eventually) represents an address or location of the numerical value of the expression and in the case of a function refers (eventually) to a subroutine that can compute a value of the function. We use the word eventually to denote that an expression can be the address of another expression which itself is the address of a number, and so forth.

Statements. Now that we have described the ingredients from which statements are made (i.e., expressions), let us consider the statements themselves. Since the statement is the operational unit, we must describe what each statement does, analogously to describing the meaning of operations in considering instructions. But first let us recall that statements are set apart by semicolons. Thus the statement ; S; means
"Execute the computations called for by S." It is often desirable to give a statement a label or name, L, analogous to the address of an instruction. The label $L$ may be a simple or subscripted variable. If $L$ is to be the name of statement $S$, we write $; L: S$; Thus ; L:S; tells the computer to assign label $L$ to the statement $S$ and perform statement S. Then some other statement may refer to the labeled statement simply by means of its label L. The analogy to addresses is evident.

Occasionally it is desired to consider a compound statement, i.e., a statement that itself consists of statements. Such compound statements are set between the words begin and end, e.g., begin $\mathrm{S} ; \mathrm{S} ; \mathrm{S} ; \mathrm{S}$ end is a compound statement of four statements. A compound statement can also be labeled, but the label must appear after the word end as well as before the word begin, for example, ; L: begin S; S; S; S end L; .

Five types of statements (of a total of seven) can now be described:

1. The first type, called the assignment or substitution statement, is probably the most important, although it is almost the simplest. The form of the assignment statement is
; VAR:=EXPR;
where VAR represents a variable (simple or subscripted) and EXPR can be any type of expression. This is a statement telling the computer to compute the value of the right-hand side and store that value (i.e., a number) in the storage location designated by the left-hand side, i.e., to assign the value of the expression to the variable. The coloned equal sign $:=$ is used to indicate that the left-hand side is to be the name (or address) of the value of the right-hand side. If the expression is in terms of numbers, such as $1.7 \uparrow 2 \downarrow-4 \times 3 \times(-0.31)$, then the indicated operations are performed. Thus Y: $=1.7 \uparrow 2 \downarrow-4 \times 3 \times(-0.31)$ tells the computer to assign $2.89+3.72$, or 6.61 , as the value of $Y$. A statement such as $A:=3$ of course requires no computation and merely assigns the value of 3 to the variable $A$. If the expression contains variables and functions, then the computer obtains the values of the variables, which must have been previously assigned, and evaluates the functions, by means of appropriate subroutines. Thus, to compute $(-\mathrm{B}+\operatorname{sqrt}(\mathrm{Y})) /(2 \times \mathrm{A})$, where Y represents $\mathrm{B} \uparrow 2 \downarrow-4 \times \mathrm{A} \times \mathrm{C}$ and $A$ is $3, B$ is 1.7 , and $C$ is -0.31 , we would write the following sequence of statements, which would be executed from left to right:

$$
\begin{array}{r}
; \mathrm{A}:=3 ; \mathrm{B}:=1.7 ; \mathrm{C}:=-0.31 ; \mathrm{Y}:=\mathrm{B} \uparrow 2 \downarrow-4 \times \mathrm{A} \times \mathrm{C} ; \\
\operatorname{root}:=(-\mathrm{B}+\operatorname{sqrt}(\mathrm{Y})) /(2 \times \mathrm{A}) ;
\end{array}
$$

When the new value of a variable is a function of the previous value of the variable, the expression symbols appear on both sides of the statement. For example, suppose that we desired to add 2 to $J$. We would write $; \mathrm{J}:=\mathrm{J}+2$; which really means $J$ (new value) $=J$ (previous value) +2 .
2. The stop statement is used to stop the computer when a code has been completely executed. See below for an example.
3. Normally a sequence of statements is executed in the order in which they appear from left to right. This normal sequence of execution can be interrupted by the use of a go to statement that is analogous to an unconditional jump instruction. The form of the go to statement is

## ; go to L ;

where $L$ is an expression specifying the label of the statement to be executed.
4. Another type of statement that can change the normal sequence of executing instructions is the if statement, of the form

## ; if REL;

where REL must be a "relational" expression that can be either true or false. For example, REL could be $(A>N)$, or $(A=B)$, or $(A \leq B)$, and so forth. For such a statement the computer would first determine whether REL is true or false (i.e., whether it holds or not). If REL is true, the statement following the if statement will be executed; otherwise it will be skipped, and the statement following it will be executed next. As an example of both the if and go to statements, consider the problem of finding the largest of three given numbers $U, V$, and $W$. The sequence of statements according to Fig. 3-3 will be

> ; if $(\mathrm{U}>\mathrm{V}) ;$ go to $\mathrm{UW} ;$ if $(\mathrm{V}>\mathrm{W}) ;$ go to $\mathrm{VLN} ; \mathrm{WLN}: \mathrm{LNC}:=\mathrm{W} ;$ go to $\mathrm{T} ; \mathrm{VLN}: \mathrm{LNC}:=\mathrm{V} ;$ go to $\mathrm{T} ; \mathrm{UW}:$ if $(\mathrm{U}>\mathrm{W}) ;$ go to $\mathrm{ULN} ;$ go to WLN $; \mathrm{ULN}: \mathrm{LNC}:=\mathrm{U} ; \mathrm{T}: s t o p ;$

Here the largest number is to be assigned as the value of LNC. Five statements were labeled to be referenced by the go to statements, namely, WLN, VLN, and ULN (which assign $W, V$, and $U$ to LNC, respectively), UW [if ( $\mathrm{U}>\mathrm{W}$ )], and T, where T is the stop statement. This is somewhat reminiscent of a one-address code.
5. The automatic compilation of loops, or recursion codes, is accomplished by the for statement. The for statement causes the next statement (which may be a compound statement) to be executed repeatedly, where the value of some variable is changed for each repetition. The successive values to be assigned to this changing, or recursive, variable are given in the for statement itself by the initial value NUI, the final value NUF, and the incremental change in the value $\Delta \mathrm{N}$, which should be successively added to the initial value until the final value is attained or exceeded. The form of the for statement is

$$
\text { ; for VAR:=NUI( } \Delta N) N U F ;
$$

where VAR is a simple variable and NUI, NUF, and $\Delta \mathbb{N}$ are numbers or simple variables. As an example, consider again the problem of finding the largest of three given (positive) numbers $N[1], N[2]$, and $N[3]$.
; LNC:=0; for $\mathrm{J}:=1(1) 3$; begin if (LNC $<\mathrm{N}[J]) ; \mathrm{LNC}:=\mathrm{N}[\mathrm{J}]$ end $;$ stop;

Here we initially set the contents of LNC at 0 ; then we compare successively each of the three numbers with the contents of LNC, assigning the number to LNC if it is larger than LNC; finally, then, the value of LNC will be the largest of the three numbers. Note that the for statement acts on the statement following, which in this case is a compound statement.

Frequently the number of iterations around the loop, namely, (NUFNUI)/ $\Delta \mathrm{N}$, is not known beforehand, as is the case in evaluating a function by means of a power series. Here the exit from the loop is usually determined by comparing some computed value with a small number $\epsilon$. In such a case the compound statement being iterated contains an if and a go to statement that can jump out of the loop before the value of the recursive variable has reached the final value. Since it is not known how many iterations will be necessary, the final value NUF is made very large. For example, consider computing

$$
\sin \theta=\theta-\frac{\theta^{3}}{3!}+\frac{\theta^{5}}{5!}-\frac{\theta^{7}}{7!}+\cdots
$$

until $\theta^{2 n+1} /(2 n+1)!<\epsilon$. The code is as follows:

$$
\begin{array}{r}
\text {; TERM }:=0 ; \text { SUM }:=0 ; \text { for } \mathrm{J}:=1(1) 50 ; \\
\text { begin TERM }:=(-1 \times \text { TERM } \times(0 \uparrow 2 \downarrow)) /((2 \times \mathrm{J}+1) \times 2 \times \mathrm{J}) ; \\
\text { if }(\mathrm{TERM}<\mathrm{\varepsilon}) ; \text { go to } \mathrm{R} ; \mathrm{SUM}:=\mathrm{SUM}+\mathrm{TERM} \text { end } ; \\
\mathrm{R}: \mathrm{VSIN}:=\mathrm{SUM} ; \text { stop; } ;
\end{array}
$$

Here we multiply the previous term by $-\theta^{2} /(2 J+1)(2 . J)$ to obtain the present term. One rule, however, must be obeyed: An if statement can never immediately precede the word end.

The index of a for statement need not appear explicitly in the following statement. For example, consider the computation of $\sum_{i=1}^{5} n_{i}$, where $n_{j+1}=3 n_{j}^{2}-9 n_{j-1}^{2}, n_{0}=0$, and $n_{-1}=1$. The code is ; SUM:=0; na:=1; nb:=0; for $\mathrm{J}:=1(1) 5$;
begin $\mathrm{nc}:=3 \times(\mathrm{nb} \uparrow 2 \downarrow)-9 \times(\mathrm{na} \uparrow 2 \downarrow) ;$ SUM: $=\mathrm{SUM}+\mathrm{nc}$; $\mathrm{na}:=\mathrm{nb} ; \mathrm{nb}:=\mathrm{nc}$ end; stop;
Each time around the loop $\mathbf{J}$ is increased by 1 ; then the process ends after five iterations as desired, when J has become 5 . Note that $a, b$, and $c$ really correspond to $j-1, j$, and $j+1$, respectively.

Finally observe that loops can contain loops; or in other words for statements can act upon for statements. For example, consider the code for $\sum_{i=1}^{5}\left(\sum_{j=1}^{3}(i+1)(j+2)\right)$,
; SUM:=0; for $\mathrm{i}:=1(1) 5$; begin for $\mathrm{j}:=1(1) 3$;
SUM: $=$ SUM $+(\mathrm{i}+1) \times(\mathrm{j}+2)$ end $;$ stop $;$

A general rule to apply is that no jump may be made into the range of a for statement except during the use of subroutines not affecting the for indices. The following diagram indicates valid jumps (i.e., if followed by go to statements):


Declarations. Declarations serve to inform the computer of certain facts required by the code. They have no operational meaning as far as the code is concerned. Five declarations will now be described.

1. Array declarations tell the computer how many numbers there are in a vector or matrix array, so that the appropriate memory space may be reserved. The form of an array declaration is
; array (VAR[L:U]);
where VAR is the subscripted variable in question, $L$ is the list of the lowest values the subscripts take, and U is the list of the largest values the subscripts take. Thus, if

$$
\text { MATRIX }_{\mathbf{i j}}=\left(\begin{array}{ll}
a_{11} & a_{12} \\
a_{21} & a_{22} \\
a_{31} & a_{32}
\end{array}\right)
$$

we would write array (MATRIX[1,1:3,2]). For a vector with five components $V_{1}, V_{2}, V_{3}, V_{4}$, and $V_{5}$ we would write array ( $\mathrm{V}[1: 5]$ ), and so forth.
2. Type declarations classify variables or functions for the automatic program so that they may be treated accordingly. For example, arithmetic operations involving fixed-point variables differ from those involving floating-point variables. Labels of statements cannot have numerical values and therefore are treated differently from variables, and so forth. A type declaration would be as follows:
; TYPE (EXPA,EXPB, . . . ,EXPC);
where TYPE stands for some type, as fixed point (FXD), floating point (FLT), or label (LAB), that can be recognized by the program and EXPA, etc., represent the variables or functions of that type.
3. A switch, or variable-connector declaration, specifies (by their labels) alternative statements to which a go to statement may jump. The form of a variable-connector declaration is
; switch NAME:=(LA,LB, . . . ,LC);
where NAME is the name of the connector and LA, LB, . . . , LC are the ordered set of labels of the possible statements that can be distinguished by the connector. The variable connector is used by a go to statement in the form
where NAME[ $\mathbf{N}$ ] is a subscript variable and $\mathbf{N}$ is an integer telling which label of the switch declaration to use. Thus if LA, the first label, is to be used, then $\mathbf{N}$ would be set to 1 ; if the second label, LB, is to be used, then N would be set to 2 ; and so forth. For example, consider the problem of forming $A=X^{2}+Y$ if $N=1, A=X+Y^{2}$ if $N=2$, and $A=0$ if $N=3$. We form the required $N$ and then jump by means of a variable connector for the proper arithmetic statement,

$$
\begin{array}{r}
; \text { switch } \mathrm{S}:=(\mathrm{P}, \mathrm{Q}, \mathrm{R}) ; \mathrm{J}:=\mathrm{N} ; \text { go to } \mathrm{S}[\mathrm{~J}] ; \mathrm{P}: \mathrm{A}:=(\mathrm{X} \uparrow 2 \downarrow)+\mathrm{Y} ; \text { go to } \mathrm{T} ; \\
\mathrm{Q}: \mathrm{A}:=\mathrm{X}+(\mathrm{Y} \uparrow 2 \downarrow) ; \text { go to } \mathrm{T} ; \mathrm{R}: \mathrm{A}:=0 ; \mathrm{T}: \text { stop } ;
\end{array}
$$

4. Comment declarations are used to add informal comments to a program; they have no effect on the program and are intended only as additional information for the reader. This declaration must start with the word comment, and there cannot be a semicolon within the declaration. (Why?) For example,

## ; Comment This code will compute $\sin \theta$ with an error no greater than $\varepsilon$;

5. A function declaration describes the computing rule to be used in evaluating the function in terms of its variables. The form of a function declaration is
; FUNCT(VARA,VARB, . . . ,VARC):=EXP;
where FUNCT is the name of the function, the independent variables are listed in the parentheses, and EXP is the computing rule. For example, if $f(u, v)=a u^{2}+b u v+c v^{2}$, we would write

$$
\text { ; QUADRATIC }(\mathrm{u}, \mathrm{v}):=a \times(\mathrm{u} \uparrow 2 \downarrow)+b \times u \times v+c \times(v \uparrow 2 \downarrow) ;
$$

To use the function in a code, consider the evaluation of

$$
Z=A f\left(r^{2}, s^{2}\right)+B f\left(r^{3}, s^{3}\right)
$$

After declaring the quadratic as above we would write

## ; Z: =A $\times$ QUADRATIC( $\mathrm{r} \uparrow 2 \downarrow, \mathrm{~s} \uparrow 2 \downarrow$ )

$$
+B \times \text { QUADRATIC }(\mathrm{r} \uparrow 3 \downarrow, \mathrm{~s} \uparrow 3 \downarrow) ;
$$

Note that it is the order of the variables appearing in the function declaration that is important. Thus, in QUADRATIC(r $\uparrow 2 \downarrow, s \uparrow 2 \downarrow$ ), since $r^{2}$ occurs first it is substituted for $u ; s^{2}$ occurring second is substituted for $v$. The computation actually performed is $a\left(r^{2}\right)^{2}+b\left(r^{2}\right)\left(s^{2}\right)+c\left(s^{2}\right)^{2}$. The variable substituted may be a function itself, as we shall see in the example below.

The computer computes QUADRATIC( $u, v$ ) only when it is confronted with the computation of $Z$. The arguments $u$ and $v$ must first be computed by the program, and then, having $u$ and $v$ (namely, $r^{2}$ and $s^{2}$ in the first case and $r^{3}$ and $s^{3}$ in the second), the program can refer to the declaration to find out how to compute QUADRATIC( $u, v$ ). How does the computer distinguish between QUADRATIC $(u, v)$ when it is used as a
declaration and when it is used as a function in a statement? If QUADRATIC( $\mathrm{u}, \mathrm{v}$ ) appears to the left of the := relation, it can only be a function declaration; if it appears to the right of the $:=$ relation, it must represent an actual function that refers to a declaration.

Consider a more complicated function that may be defined by a compound statement rather than a single arithmetic expression. The problem arises as to where the value of the function, as computed by the compound statement, will be found. The convention is used that the address of the final result should be called by the name of the function, e.g., FUNCT. For example, consider a series approximation to $\sin \theta$ such that the last term is less than $\epsilon$ :

```
; sin(0,\varepsilon):= begin TERM:=0; SUM:=0; for J:=1(1)50;
    begin TERM:=(-1\timesTERM }\times(0\uparrow2\downarrow))/((2\timesJ+1)\times2\timesJ)
if (TERM <\varepsilon); go to R; SUM:=SUM+TERM end;R:sin:=SUM end;
```

Note that this is all just a declaration of the function $\sin (\theta, \epsilon)$, and the result is found in the address $\sin [$ not $\sin (\theta, \varepsilon)$, because that represents a function, not a variable or address]. This function declaration would be used as follows: Consider the computation of

$$
z=3 \sin ^{2}(u-v, \epsilon)+\sqrt{1-\sin ^{2}\left(u^{2}-v^{2}, \epsilon\right)}
$$

for $\epsilon=1 / n$. After declaring $\sin (\theta, \varepsilon)$ we would write

$$
\begin{aligned}
; \mathrm{z}:=3 \times(\sin (\mathrm{u}-\mathrm{v}, 1 / \mathrm{n})) \uparrow & \underset{2}{ } \downarrow \\
& +\operatorname{sqrt}(1-(\sin (\mathrm{u} \uparrow 2 \downarrow-\mathrm{v} \uparrow 2 \downarrow, 1 / \mathrm{n})) \uparrow 2 \downarrow) ;
\end{aligned}
$$

 because they are explicitly written into the automatic programming routine itself.

Use of Subroutines: Procedure Statements and Procedure Declarations. As previously discussed in Chap. 4, a subroutine must be "told" initial conditions and in what addresses to put the final results. (The automatic program takes care of the return jump back to the original code.) In our present code this is done by a procedure statement of the form
; SUBR(IA,IB, . . . ,IC)= :(FL,FM, . . . ,FN);

Here SUBR is the name of the subroutine, IA, IB, . . ., IC are the initial conditions (i.e., expressions that can be evaluated), and FL, FM, . . ., FN are the addresses where the final results are to be located (i.e., simple or subscripted variables). The subroutine itself is considered as a procedure declaration. Its form is

[^2]A special statement, denoted simply by return, is placed in the subroutine proper at that point from which the return jump back to the original code should occur. Note that, if a subroutine has a single value as its final result, then we could have as well used a function declaration referred to by a function in a statement. As in the case of the function the order of the variables is used to distinguish among them.

As an example, consider a subroutine that computes $e^{x}, \sin x$, and $\cos x$. Since

$$
\begin{aligned}
e^{x} & =1+x+x^{2} / 2!+x^{3} / 3!+x^{4} / 4!+x^{5} / 5!+\cdots \\
\sin x & =x-x^{3} / 3!+x^{5} / 5!-\cdots \\
\cos x & =1-x^{2} / 2!+x^{4} / 4!-\cdots
\end{aligned}
$$

and
we can form $x^{m} / m$ ! and then add this (with the appropriate sign) to the respective partial sums as called for by the series (i.e., alternating oddand even-power terms). We use a switch declaration for the alteration. The procedure declaration (and the included subroutine) would be
; procedure TRIG(0, $)=:($ EXPO,SIN,COS $) ;$ begin switch SAC: $=(\mathrm{S}, \mathrm{C})$;
TERM:= $;$ SUME $:=1+\theta ;$ SUMS $:=0 ;$ SUMC: $=1 ; \mathrm{J}:=2 ; \mathrm{I}:=2$;
B: TERM: $=(T E R M \times \theta) / J$; if $(T E R M<\varepsilon) ;$ go to R;
SUME:=SUME+TERM; go to SAC[I];
C: SUMC:=SUMC+((-1) 个J/ $2 \downarrow) \times$ TERM $;$ I:=1; go to $T$;
S: SUMS:=SUMS+((-1) $\uparrow(\mathrm{J}-1) / 2 \downarrow) \times$ TERM $; \mathrm{I}:=2$; go to T ;
$\mathrm{T}: \mathrm{J}:=\mathrm{J}+1$; go to B ;
R: EXPO:=SUME; SIN:=SUMS; COS:=SUMC; return end;
Note that the inputs to the subroutine are $\theta$ and $\varepsilon$ in that order; the outputs are EXPO, SIN, and COS in that order. The switch is reset to go through the alternate sin (or cos) loop at the end of each loop. Finally the computed results SUME, SUMS, and SUMC are assigned to their corresponding variables. Next suppose that we wanted to use this subroutine to compute $e^{-\omega t}(A \sin (\omega t)+B \cos (\omega t))$. The procedure statement with the appropriate code would be simply

$$
\text { ; TRIG }(\omega \times \mathrm{t}, \mathrm{\varepsilon})=:(\mathrm{U}, \mathrm{~V}, \mathrm{~W}) ; \mathrm{Z}:=(\mathrm{A} \times \mathrm{V}+\mathrm{B} \times \mathrm{W}) / \mathrm{U} ;
$$

As another example of a procedure declaration and its included subroutine consider matrix multiplication where it is desired to compute $C_{i k}=\sum_{j} A_{i j} B_{j k}$. If $i=1, \ldots, I ; j=1, \ldots, J ;$ and $k=1, \ldots, K$, the procedure declaration would be
; procedure MATMULT(A[i, j$], \mathrm{B}[\mathrm{j}, \mathrm{k}], \mathrm{I}, \mathrm{J}, \mathrm{K})=:(\mathrm{C}[\mathrm{i}, \mathrm{k}])$; begin array (A[1,1:1, J]); array (B[1,1:J,K]); array (C[1,1:1, K]); for $\mathrm{i}:=1(1) \mathrm{I} ;$ begin for $\mathrm{k}:=1(1) \mathrm{K} ; \mathrm{C}[\mathrm{i}, \mathrm{k}]:=0 ;$ begin for $\mathrm{j}:=1(1) \mathrm{J} ; \mathrm{C}[\mathrm{i}, \mathrm{k}]:=\mathrm{C}[\mathrm{i}, \mathrm{k}]+\mathrm{A}[\mathrm{i}, \mathrm{j}]$ $\times \mathrm{B}[\mathrm{j}, \mathrm{k}]$ end end; return end;

Finally consider an example of integration by means of the trapezoid rule (see Sec. 6-7, for example), namely,

$$
A=\int_{a}^{b} f(x) d x=\frac{h}{2}(f(a)+2 f(a+h)+2 f(a+2 h)+\cdots+f(b))
$$

Here we shall include a comment declaration as well:
; procedure $\operatorname{TRAP}(\mathrm{F}(\mathrm{x}), \mathrm{a}, \mathrm{b}, \mathrm{e}, \mathrm{V}):=(\mathrm{A})$; begin comment a and b are the $\min$ and max, resp., of the points defining the interval of integration. $F(x)$ is the function to be integrated, $\varepsilon$ is the permissible difference between two successive trapezoidal sums, and V is greater than the maximum absolute value of $\mathrm{F}(\mathrm{x})$ on $(\mathrm{a}, \mathrm{b}) ; \mathrm{Ibar}:=\mathrm{V} \times(\mathrm{b}-\mathrm{a}) ; \mathrm{h}:=(\mathrm{b}-\mathrm{a})$; $\mathrm{J}:=(1 / 2) \times(\mathrm{F}(\mathrm{a})+\mathrm{F}(\mathrm{b})) ; \mathrm{S}:=0 ; \mathrm{n}:=1$; for $\mathrm{i}:=1(1) 50$; begin for $\mathrm{k}:=$ $1(1) \mathrm{n} ; \mathrm{S}:=\mathrm{S}+\mathrm{F}(\mathrm{a}+\mathrm{h} \times(\mathrm{k}-1 / 2)) ; \mathrm{I}:=\mathrm{h} \times(\mathrm{J}+\mathrm{S})$; if $(\mathrm{\varepsilon}>\mathrm{abs}(\mathrm{I}-\mathrm{Ibar})$ ); go to $\mathrm{T} ; \mathrm{n}:=2 \uparrow \mathrm{i} \downarrow ; \mathrm{h}:=\mathrm{h} / 2$; Ibar:=I end; $\mathrm{T}: \mathrm{A}:=\mathrm{I} ;$ return end;
Note that for the $i$ th iteration we add $2^{i}$ more points to $S$, namely, the points dividing the previous points. Then $\mathrm{h} \times((1 / 2) \times(\mathrm{F}(\mathrm{a})+\mathrm{F}(\mathrm{b}))+\mathrm{S})$ becomes the new approximation to the integral.


Fig. 5-9. Use of procedures as building blocks.
The building-block method of using procedures (or subroutines) is illustrated in Fig. 5-9. The final code can be just a sequence of procedure statements; similarly each of these procedure declarations referred to by the statements can itself be a sequence of procedure statements, and so forth. The advantage of this building-block technique is that a large code can easily be subdivided into more elementary codes, and several coders and programmers at once can work on the subdivisions. Then the parts can be compiled into the large program, in as many levels as required.

## EXERCISES

(a) At the beginning of this section we remarked that by the ". . previous sections it is clear that a language can be devised that is independent of particular
computer instructions." What previous sections do we have in mind, and how can these be used for such a language? (Hint: For example, Sec. 5-8 is concerned with an automatic program that interprets algebraic symbols, but the procedure for using this program given in that section depends on the word format of the computer. However, Sec. 5-7 describes a symbolic address translator, the use of which can easily be made independent of the word format. Thus the methods of the two automatic programs can be combined to result in a process for using algebraic-symbol interpretation that is independent of computer instructions.)
(b) Make a flow chart for the automatic program that can interpret each of the seven statements given in the above language.

Write codes in the symbolic algebraic language to compute the following functions:
(c) $n!/ x!(n-x)!$.
(d) $u=\sum_{x=0}^{n} x \frac{n!}{x!(n-x)!} p^{x} q^{n-x}$.
(e) $S=\frac{30 I_{0^{2}}{ }^{2}}{2 \pi R^{2}}\left[\frac{\cos \left(\frac{\pi}{2} \cos \theta\right)}{\sin \theta} \frac{\sin \left(\frac{n \pi}{2} \sin \theta \cos \varphi\right)}{\sin \left(\frac{\pi}{2} \sin \theta \cos \varphi\right)}\right]^{2}$.
(f) Write a subroutine in the algebraic language to put the numbers $V_{i}(i=1$, . . , $n$ ) in numerical order (see Exercise $h$ of Sec. 4-2).
(g) Write a subroutine in the language for Simpson's integration rule (see Sec. 6-7).
( $h$ ) Write a subroutine in the language to evaluate a determinant.
(i) Write a subroutine in the language to form the inverse of a matrix.

## 5-10. Additional Topics

## a. References to Computer Maintenance and Program Debugging

Electronic Computers, Session III, IRE Natl. Conv. Record, 1954.
Ledley, R. S., and J. B. Wilson: "Programming and Utilizing Digital Computers," McGraw-Hill Book Company, Inc., New York, in press.
McCracken, D. D.: "Digital Computer Programming," John Wiley \& Sons, Inc., New York, 1957.
Symposium on Diagnostic Programs and Marginal Checking for Large Scale Digital Computers, IRE Conv. Record, pt. 7, 1953.
Von Neumann, J.: Probabilistic Logics and the Synthesis of Reliable Organisms from Unreliable Components, "Automata Studies," Princeton University Press, Princuton, N.J., 1956.
Wheeler, D. J., and J. E. Robertson: Diagnostic Programs for the Illiac, Proc. IRE, vol. 41, pp. 1332-1340, October, 1953.
b. The Iniernational Algebraic Language. The automatic language described in Sec. 5-9 was a simplification of the proposed International Algebraic Language, now called ALGOL (see J. Perlis and K. Samelson, for the Association for Computing Machinery-GAMM Committee, Preliminary Report-International Algebraic Language, Com:rinuns. Assoc. Computing Machinery, vol. 1, no. 12, December, 1958). In our discussions several statements were omitted and others severely simplified, and the Boolean expression was omitted. By referring to the above-mentioned article, complete the study of ALGOL.
c. FORTRAN $I$ and II. The most well-known algebraic language presently in common use is the IBM FORTRAN I and II (FORTRAN means "formula transla-
tion'"). Many aspects of this language are similar to the International language. By means of the FORTRAN I and II manuals, compare and contrast FORTRAN I and II and the International Language. (See "Programmer's Primer for FORTRAN," "Programmer's Reference Manual, FORTRAN," and "Reference Manual, FORTRAN II," all published by IBM for the 704 computer.)
d. Automatic Coding Systems. In order to give the reader an idea of how extensive has been work on automatic programming systems, we present in Table 5-2 a selected list of automatic programs, chosen from a more detailed compilation of over 90 that can be found in Proc. Fourth Ann. Computer Appls. Symposium, Oct. 24-25, 1957, Armour Research Foundation. (See especially R. W. Bemer, The Status of Automatic Programming for Scientific Problems.)

Table 5-2. List of Selected Automatic Programming Systems $\dagger$

| Computer | Name or acronym of automatic coding system | Developed by | Interpreter | Compiler | Algebraic |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IBM 704, 705, and 709 | AFAC <br> FORTRAN I and II | Allison GM <br> IBM |  | $x$ | $\mathrm{x}$ |
| IBM 650. | Bell Li <br> IT <br> FORTRANSIT <br> APT <br> SOAP I and II | Bell Tel. Labs. Carnegie Tech. IBM-Carnegie Tech. Applied Physics Lab. IBM | x | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |
| Sperry Rand 1103A | COMPILER I USE QUICKTRICK $\mathrm{APT}$ IT | Boeing, Seattle <br> Ramo-Wooldridge <br> Operations Research Office <br> Applied Physics Lab. Carnegie Tech., RamoWooldridge | x | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\mathrm{x}$ |
| Sperry Rand UNIVAC I and II. | AT3 | Sperry Rand |  | x | x |
| Datatron 205. | IT | Purdue University |  | x | x |
| Whirlwind... | Algebraic <br> Summer Session | $\begin{aligned} & \text { MIT } \\ & \text { MIT } \end{aligned}$ | x | x | x |
| Proposed for all computers | ALGOL | Association for Computing MachineryGAMM | x | x | x |

$\dagger$ Information concerning these and many other automatic programs is being made available by the Association for Computing Machinery, New York.

# FUNCTIONAL APPROACH TO SYSTEMS DESIGN 

## CHAPTER 6

## FUNDAMENTALS OF NUMERICAL ANALYSIS

## 6-1. Introduction ${ }^{\text {? }}$

The systems design of a digital computer or control is the over-all block diagram and description of its parts, including its operational characteristics, input-output facilities, and coding or information-handling structure. The purpose of this part of the book is to discuss the functional approach to such systems design.

Consider first the so-called general-purpose digital computer, which is designed to perform the processes of numerical analysis. Actually we have already described its systems design in Part 1. It is important for the engineer to understand the basic concepts of numerical analysis as a foundation for appreciating criteria for the systems design of such a computer. In the decision on the instruction system of a proposed computer the engineer must comprehend the problems involved and the techniques used in reducing a mathematical problem to sequences of additions, subtractions, multiplications, and divisions. In addition the engineer will often find use for these methods in his own analytical problems.

Numerical analysis is a large and growing subject in itself, and our discussion must be limited to those aspects which are considered of importance to the computer engineer. These questions naturally arise in the study of digital computers: If a computer can do little more than the elementary arithmetic operations, how can it be used to perform function evaluation, integration, or differentiation, or to solve ordinary and partial differential equations? Also, in performing long sequences of arithmetic operations, how is the accuracy of the computing results analyzed and controlled? We can give in this chapter no more than a brief introduction to the answers to these questions, but it is felt that such an elementary survey can well serve to orient the student in this field.

The chapter starts with a technique for solving linear simultaneous equations (Sec. 6-2), which arise frequently in all fields of science and engineering. Next solution of algebraic and transcendental equations by means of successive approximations is considered (Sec. 6-3). Then
the following three sections introduce the fundamental concept of polynomial approximations for the evaluation of functions. In passing, continued fractions are considered, so that the reader will not think there are no other methods for evaluating functions. The best-fit polynomial approximations are emphasized because of their extreme importance in digital-computer work. In order that the reader may develop a "numerical feeling" for such approximations, graphs are given of actually computed examples. The next four sections show how the same fundamental idea of polynomial approximation is used in numerical integration and differentiation and in the solution of differential equations. To complete the picture, the method of undetermined coefficients is given, so that the student can experiment and derive formulas for himself.
Up to this point discussion of error was omitted to allow full concentration on the concepts involved: the final section of this chapter is concerned with accuracy and error. Our discussion will be limited to fundamental definitions and to consideration of the arithmetic operations. In performing a computation on a digital computer, the significance and accuracy associated with arithmetic operations are usually uppermost in the mind of the computer user. Such considerations can greatly influence the systems design of new computers through the over-all word format, word length, and operations designs. Hence an appreciation of the problems involved becomes of prime importance to the computer engineer.

## 6-2. Simultaneous Linear Equations

The Problem. Consider a set of $n$ simultaneous linear equations in $n$ unknowns $x_{1}, \ldots, x_{n}$,

$$
\begin{equation*}
a_{11} x_{1}+a_{12} x_{2}+\cdots+a_{1 n} x_{n}=y_{1} \tag{1}
\end{equation*}
$$

$$
\begin{equation*}
a_{21} x_{1}+a_{22} x_{2}+\cdots+a_{2 n} x_{n}=y_{2} \tag{2}
\end{equation*}
$$

$$
\begin{equation*}
a_{n 1} x_{1}+a_{n 2} x_{2}+\cdots+a_{n n} x_{n}=y_{n} \tag{n}
\end{equation*}
$$

These equations admit of a unique set of solutions,

$$
x_{i}=x_{i}\left(a_{11}, \ldots, a_{n n}, y_{1}, \ldots, y_{n}\right)
$$

if at least one $y_{i}$ is not zero, and if the determinant $\operatorname{det}\left(a_{i j}\right) \neq 0 . \dagger$ In order to describe a method for solving the equations, let us first consider a special set of equations with coefficients $s_{i i}=1$ and $s_{j k}=0$ if $j>k$ :

$$
\begin{aligned}
x_{1}+s_{12} x_{2}+s_{13} x_{3}+s_{14} x_{4} & =y_{1} \\
x_{2}+s_{23} x_{3}+s_{24} x_{4} & =y_{2} \\
x_{3}+s_{34} x_{4} & =y_{3} \\
x_{4} & =y_{4}
\end{aligned}
$$

$\dagger$ See, for example, E. A. Guillemin, "The Mathematics of Circuit Analysis," pp. 13-18, John Wiley \& Sons, Inc., New York, 1951.

These four equations can easily be solved for the unknowns $x_{1}, x_{2}, x_{3}$, and $x_{4}$, for $x_{4}=y_{4}$ is already given, and it follows that

$$
\begin{aligned}
& x_{3}=y_{3}-s_{34} x_{4} \\
& x_{2}=y_{2}-s_{24} x_{4}-s_{23} x_{3} \\
& x_{1}=y_{1}-s_{14} x_{4}-s_{13} x_{3}-s_{12} x_{2}
\end{aligned}
$$

Hence it becomes clear that, if we can somehow manipulate Eqs. (1), (2), . . , ( $n$ ) so that the diagonal coefficients become 1 and the coefficients below the diagonal become zero, then the solutions can be rapidly obtained.

The Method. This process can be accomplished as follows: First divide both sides of Eq. (1) by $a_{11}$. If $a_{11}=0$, then rearrange the order of the equations so that $a_{11} \neq 0$. (This, of course, can always be done. Why?) This results in

$$
\begin{equation*}
1 \cdot x_{1}+\frac{a_{12}}{a_{11}} x_{2}+\cdots+\frac{a_{1 n}}{a_{11}} x_{n}=\frac{y_{1}}{a_{11}} \tag{1}
\end{equation*}
$$

Multiply Eq. (1) ${ }^{1}$ by $a_{21}$, and subtract the result from (2), obtaining

$$
\begin{equation*}
0 \cdot x_{1}+b_{22} x_{2}+\cdots+b_{2 n} x_{n}=y_{2}{ }_{2}^{(1)} \tag{2}
\end{equation*}
$$

where

$$
b_{22}=a_{22}-\frac{a_{21} a_{12}}{a_{11}} \quad \cdots \quad b_{2 n}=a_{2 n}-\frac{a_{21} a_{1 n}}{a_{11}}
$$

and

$$
y_{2}^{(1)}=y_{2}-\frac{a_{21} y_{1}}{a_{11}}
$$

Similarly, multiply (1) ${ }^{1}$ by $a_{31}$, and subtract the result from (3), obtaining

$$
\begin{equation*}
0 \cdot x_{1}+b_{32} x_{2}+\cdots+b_{3 n} x_{n}=y_{3}^{(1)} \tag{3}
\end{equation*}
$$

where

$$
b_{32}=a_{32}-\frac{a_{31} a_{12}}{a_{11}} \quad \cdots \quad b_{3 n}=a_{3 n}-\frac{a_{31} a_{1 n}}{a_{11}}
$$

and

$$
y_{3}{ }^{(1)}=y_{3}-\frac{a_{31} y_{1}}{a_{11}}
$$

Continuing in this, we obtain a new set of Eqs. (1) ${ }^{1}$, (2) ${ }^{1}$, . . . , $(n)^{1}$ such that $b_{11}=1$ and $b_{i 1}=0$ for $i>1$. Of course, it is clear that our new set of equations has the same solution as the original set.

Next we start with (2) ${ }^{1}$ and divide both sides by $b_{22}$. [If necessary, a rearrangement of the order of Eqs. (2) ${ }^{1}$, . ., $(n)^{1}$ can be made to ensure that $b_{22} \neq 0$.] We obtain

$$
\begin{equation*}
1 \cdot x_{2}+\frac{b_{23}}{b_{22}} x_{3}+\cdots+\frac{b_{2 n}}{b_{22}} x_{n}=\frac{y_{2}{ }^{(1)}}{b_{22}} \tag{2}
\end{equation*}
$$

Multiply (2) ${ }^{1}$ by $b_{32}$, and subtract the result from (3) ${ }^{1}$, obtaining

$$
\begin{array}{ll} 
& 0 \cdot x_{2}+c_{33} x_{3}+\cdots+c_{3 n} x_{n}=y_{3}{ }_{3}^{(2)}  \tag{3}\\
\text { where } \quad c_{33}=b_{33}-\frac{b_{32} b_{23}}{b_{22}} \cdots \quad c_{2 n}=b_{3 n}-\frac{b_{32} b_{2 n}}{b_{22}} \\
\text { and } & y_{3}{ }^{(2)}=y_{3}{ }^{(1)}-\frac{b_{32} y^{(1)}}{b^{22}}
\end{array}
$$

Similarly, we obtain

$$
\begin{equation*}
c_{43} x_{3}+\cdots+c_{4 n} x_{n}=y_{4}^{(2)} \tag{4}
\end{equation*}
$$

and the same for $(5)^{2}, \ldots,(n)^{2}$. In this step we have made $c_{33}=1$ and $c_{i 2}=0$ for $i>2$.

Continuing in this way, we finally obtain, for example in the case of $n=4$, the following equations, in the desired form for easy solution:

$$
\begin{aligned}
x_{1}+\frac{a_{12}}{a_{11}} x_{2}+\frac{a_{13}}{a_{11}} x_{3}+\frac{a_{14}}{a_{11}} x_{4} & =\frac{y_{1}}{a_{11}} \\
x_{2}+\frac{b_{23}}{b_{22}} x_{3}+\frac{b_{24}}{b_{22}} x_{4} & =\frac{y_{2}{ }^{(1)}}{b_{22}} \\
x_{3}+\frac{c_{34}}{c_{33}} x_{4} & =\frac{y_{3}{ }^{(2)}}{c_{33}} \\
x_{4} & =\frac{y_{4}{ }^{(3)}}{d_{44}}
\end{aligned}
$$

Example. Let us carry this process through for a specific set of four equations.

$$
\begin{align*}
3 x_{1}+9 x_{2}+6 x_{3}-12 x_{4} & =9  \tag{1}\\
2 x_{1}+8 x_{2}+12 x_{3}-2 x_{4} & =2  \tag{2}\\
3 x_{1}+12 x_{2}+21 x_{3}-9 x_{4} & =15  \tag{3}\\
-x_{1}-x_{2}+8 x_{3}+8 x_{4} & =5 \tag{4}
\end{align*}
$$

Dividing both sides of (1) by 3 , we find

$$
\begin{equation*}
x_{1}+3 x_{2}+2 x_{3}-4 x_{4}=3 \tag{1}
\end{equation*}
$$

Now multiply Eq. (1) ${ }^{1}$ by 2 , and subtract from Eq. (2), obtaining

$$
\begin{equation*}
2 x_{2}+8 x_{3}+6 x_{4}=-4 \tag{2}
\end{equation*}
$$

Similarly, we multiply Eq. (1) ${ }^{1}$ by 3 and subtract from Eq. (3), obtaining

$$
\begin{equation*}
3 x_{2}+15 x_{3}+3 x_{4}=6 \tag{3}
\end{equation*}
$$

And finally (4) ${ }^{1}$ is obtained by multiplying (1) ${ }^{1}$ by -1 and subtracting from (4),

$$
\begin{equation*}
2 x_{2}+10 x_{3}+4 x_{4}=8 \tag{4}
\end{equation*}
$$

Continuing, we form Eqs. (2) ${ }^{2}$, (3) ${ }^{2}$, and (4) ${ }^{2}$,

$$
\begin{align*}
x_{2}+4 x_{3}+3 x_{4} & =-2  \tag{2}\\
3 x_{3}-6 x_{4} & =12  \tag{3}\\
2 x_{3}-2 x_{4} & =12
\end{align*}
$$

$$
(4)^{2}
$$

Finally we have
and

$$
\begin{aligned}
x_{3}-2 x_{4} & =4 \\
2 x_{4} & =4 \\
x_{4} & =2
\end{aligned}
$$

Thus the set of equations from which the solution is obtained is

$$
\begin{array}{rlr}
x_{1}+3 x_{2}+2 x_{3}-4 x_{4} & =3 & (1)^{1} \\
x_{2}+4 x_{3}+3 x_{4} & =-2 & ()^{2} \\
x_{3}-2 x_{4} & =4 & (4)^{3} \\
x_{4} & =2 &
\end{array}
$$

whence

$$
\begin{array}{ll}
x_{4}=2 & =2 \\
x_{3}=4+2 \times 2 & =8 \\
x_{2}=-2-3 \times 2-4 \times 8 & =-40 \\
x_{1}=3+4 \times 2-2 \times 8-3 \times(-40) & =115
\end{array}
$$

Figure 6-1 is the flow diagram for this method of solving simultaneous linear equations.


Fig. 6-1. Flow chart for solving simultaneous linear equations.

## EXERCISES

(a) Solve

$$
\begin{aligned}
& 5 x_{1}-2 x_{2}=3 \\
& 4 x_{1}-5 x_{2}=-18
\end{aligned}
$$

by following in detail the steps of the flow diagram, keeping track of all the tallies.
(b) Solve

$$
\begin{aligned}
0 \cdot x_{1}+4 x_{2}+\quad x_{3}-3 x_{4} & =1 \\
4 x_{1}+0 \cdot x_{2}-2 x_{3}+2 x_{4} & =14 \\
8 x_{1}-7 x_{2}+x_{3}-3 x_{4} & =-12 \\
-5 x_{1}+8 x_{2}+0 \cdot x_{3}-x_{4} & =-2
\end{aligned}
$$

Solution. $\quad x_{1}=8, x_{2}=7, x_{3}=27, x_{4}=18$.
(c) The flow chart of Fig. 6-1 does not account for zero coefficient in the leading term of Eq. ( $j)^{j}$. How can the flow chart be adjusted to account for this?
(d) Using the three-address instructions of Chap. 3, write a code that solves simultaneous linear equations.

## 6-3. Algebraic and Transcendental Equations

Successive Approximations. The method of successive approximations can be used to evaluate the solutions of algebraic and transcendental


Fig. 6-2. Finding solution to $\sin x+2 x-2=0$ by the method of successive approximations.
equations. Although the best method for making the successive approximations in any case depends on the nature of the functions involved, we shall try by means of specific examples to illustrate the general principles that apply. Often a graph of the functions involved in the equations will help in the determination of the best method of approximation.

Consider, for example, the equation

$$
\sin x+2 x-2=0
$$

to be solved for $x$. We can write this as $\sin x=2-2 x$ and graph $y_{T}=\sin x$ and $y_{P}=2-2 x$ (see Fig. 6-2). The desired value of $x$ is the $x$ coordinate of the intersection of the two curves, where $\sin x$ will be equal to $2-2 x$. We know that the value of $x$ must be between 0 and 1 . Hence we try $x_{1}$ such that $0<x_{1}<1$. As can be seen from Fig. 6-2, if $\sin x_{1}>2-2 x_{1}$, then the solution must lie to the left of $x_{1}$, that is, $x<x_{1}$; if $\sin x_{1}<2-2 x_{1}$, then the solution must be to the right of $x_{1}$, that is, $x>x_{1}$. Suppose that we try $x_{1}=0.500$ (radians of course); then $\sin x_{1}=0.479$, and $2-2 x_{1}=1$. Hence $0.500<x<1$, and so we try $x_{2}=0.750$ (that is, half the distance between 0.500 and 1). Then $\sin x_{2}=0.682>2-2 x_{2}=0.5$, whence $0.500<x<0.750$. We let $x_{3}=0.625$ (half the distance between 0.500 and 0.750 ); then

$$
\sin x_{3}=0.585<2-2 x_{3}=0.75
$$

and so we try next 0.687 , etc. In each step we find in which half of the previous interval the solution lies; Fig. 6-3 shows these calculations. The fact that we are halving each time means that we are developing the solution as a binary number. If the solution lies in the right half of an interval in a step, then a unit corresponds to this step in the solution; otherwise a zero corresponds. Hence the solution $x=.10101111$ according to Fig. 6-3, column $y_{P}$.

| (i) | $x_{i}$ | $y_{T}=\sin x$ | $y_{P}=2-2 x$ | $\begin{gathered} y_{T} \\ \text { greater } \end{gathered}$ | $\begin{gathered} y_{P} \\ \text { greater } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (1) | 0.500 | 0.479 | 1 |  | $\checkmark$ |
| (2) | 0.750 | 0.682 | 0.5 | $\checkmark$ |  |
| (3) | 0.625 | 0.585 | 0.75 |  | $\checkmark$ |
| (4) | 0.687 | 0.634 | 0.626 | $\checkmark$ |  |
| (5) | 0.656 | 0.609 | 0.688 |  | $\checkmark$ |
| (6) | 0.672 | 0.621 | 0.656 |  | $\checkmark$ |
| (7) | 0.680 | 0.629 | 0.640 |  | $\checkmark$ |
| (8) | 0.684 | 0.631 | 0.632 |  | $\checkmark$ |

Fig. 6-3. Calculations for solving the equation $\sin x=2-2 x$.
The flow diagram (see Fig. 6-4) is relatively simple: depending on whether $\sin x_{i}<2-2 x_{i}$ or $\sin x_{i}>2-2 x_{i}$, we determine the next trial solution $x_{i+1}$ by adding to or subtracting from the previous trial solution $x_{i}$ one-half of the previously used increment $\Delta x_{i}$. Since each trial determines an additional bit of the solution, the procedure is repeated the same number of times as the number of bits of accuracy desired in the solution.


Fig. 6-4. Flow chart for solving the equation $\sin x=2-2 x$.
Accelerating the Convergence of Iterative Processes. $\dagger$ The problem of solving an equation $F(x)=0$ can be stated in general as that of finding a value (root) of $x$, say $x_{r}$, such that $F\left(x_{r}\right)=0$. The general iteration algorithm involves successive approximations $x_{0}, x_{1}, x_{2}, \ldots$, which are determined as follows:

1. If $F(x)=0$ can be expressed in the form $x=f(x)$, then we let $x_{n+1}=f\left(x_{n}\right)$. For some initial guess $x_{0}$, we find $x_{1}=f\left(x_{0}\right), x_{2}=f\left(x_{1}\right)$, $x_{3}=f\left(x_{2}\right), \ldots$, continuing until, for some $n, x_{n}-x_{n+1}$ is less thar some preassigned small number, the allowable error.
2. If $F(x)=0$ cannot be written in the form of $x=f(x)$, then we let $x_{n+1}=x_{n}+\theta F\left(x_{n}\right)$, where $\theta$ is some suitably chosen nonzero constant, and proceed as in case 1 (see Exercise $h$ ).
$\dagger$ This process was worked out by J. H. Wegstein and P. Henrici; see J. H. Wegstein, Accelerating Convergence of Iterative Processes, Communs. Assoc. Computing Machinery, vol. 1, no. 6, June, 1958.

Let us consider case 1 , for what we shall say also holds for case 2 ; Fig. $6-5$ describes the process. Since $x=f(x)$, the object is to find the intersection of the two curves $y=x$ and $y=f(x)$. From $y=f\left(x_{n}\right)$ we find $y_{n}$; from $y=x$ we find $y_{n}=x_{n+1}$; from $y=f\left(x_{n+1}\right)$ we find $y_{n+1}$; from $y=x$ we find $y_{n+1}=x_{n+2}$; and so forth.


Fig. 6-5. The iterative processes.
Now observe from Fig. 6-5 that, instead of taking $x_{n+1}$ for the substitution into $f(x)$, we would do better to choose a value $x_{n+1}^{*}$ for the substitution, where

$$
x_{n+1}^{*}=q x_{n}+(1-q) x_{n+1}
$$

i.e., some value between $x_{n}$ and $x_{n+1}$. For instance, in the case illustrated in Fig. 6-5, $q$ should be chosen so that

$$
\frac{q}{1-q}=\frac{\overline{B C}}{\overline{A C}}
$$

Of course we do not know the ratio $\overline{B C} / \overline{A C}$, but we can determine it approximately. For $\overline{P C}=\overline{B C}$, and thus

$$
\frac{\overline{B C}}{\overline{A C}}=\frac{\overline{P C}}{\overline{A C}}=-m
$$

where $m$ is some value of $f^{\prime}(x)$ between $A$ and $P$ (applying Rolle's theorem from the calculus). From the definition of the derivative, $m$ can be approximated by

$$
m \cong \frac{f\left(x_{n}\right)-f\left(x_{n-1}\right)}{x_{n}-x_{n-1}}=\frac{x_{n+1}-x_{n}}{x_{n}-x_{n-1}}
$$

Hence we can take

$$
\frac{q}{1-q}=-m \quad \text { or } \quad q=\frac{m}{m-1}
$$

The iterative process can then be described by the flow chart of Fig. 6-6, wherein we must observe carefully when $x_{n}^{*}$ or $x_{n}$ is used.


Fig. 6-6. Accelerating the convergence of the iterative processes.
As an example, consider the equation

$$
x=1 / 2\left(e^{\alpha x}-e^{-\alpha x}\right)
$$

and with $\alpha=-0.5$ let us solve for the root $x=0$, using both the ordinary and the accelerated iterative processes. Starting with $x_{0}=1$, we have Table 6-1 and Fig. 6-7.

Table 6-1. Example of Both the Ordinary and Accelerated Iterative
Processes for the Root $x=0$ of $x=1 / 2\left(e^{-0.5 x}-e^{0.5 x}\right)$

| $n$ | $x_{n}$ by ordinary <br> iterative substitution | $x_{n}$ by accelerating <br> iterative substitution | Corresponding <br> value of $m$ |
| :---: | :---: | :---: | :---: |
| $\mathbf{0}$ | 1.000 | 1.000 |  |
| $\mathbf{1}$ | -0.521 | -0.521 |  |
| 2 | 0.263 | -0.00348 | 0.340 |
| 3 | -0.132 | $-1.32 \times 10^{-5}$ | 0.335 |
| 4 | 0.066 | $-1.65 \times 10^{-11}$ | 0.333 |
| $\mathbf{5}$ | -0.033 |  |  |
| 6 | 0.017 |  |  |
| 7 | -0.008 |  |  |
| 8 | 0.004 |  |  |

The ordinary iterative process may result in four types of behavior. The successive values of $x_{n}$ can (1) oscillate and converge, (2) oscillate and diverge, (3) converge monotonically, or (4) diverge monotonically. The accelerating method just presented will make the nonconverging


Fig. 6-7. Comparison of ordinary and accelerated iterative processes for the $x=0$ root of $x=1 / 2\left(e^{-0.5 x}-e^{0.5 x}\right)$.
types 2 and 4 converge and will accelerate the convergence of types 1 and 3. We have illustrated the situation for type 1. Exercises $e$ to $g$ will illustrate types 2 to 4 .

## EXERCISES

Solve by successive approximations, to within 0.001 (decimal):
(a) $1.5 \cos x+2 x-2=0$.
(b) $\sin x-\tan ^{2} x=0$.
(c) $\frac{1-x^{2}}{x}-\frac{x}{1-x^{2}}=0$.
(Hint: There are four solutions.)
(d) $\frac{1-x^{2}}{x}-\tan ^{2} x=0$.

Consider the equation $x=1 / 2\left(e^{\alpha x}-e^{-\alpha x}\right)=\sinh \alpha x$. Take $x_{0}=1$, and show by direct computation:
(e) If $\alpha=-1.2$, the ordinary iterative process will be of type 2 but the accelerating process will converge.
( $f$ ) If $\alpha=0.5$, the ordinary iterative process will be of type 3 but the accelerating process will make the convergence more rapid.
(g) If $\alpha=1.2$, the ordinary iterative process will be of type 4 but the accelerating process will converge.
(h) Explain why we let $x_{n+1}=x_{n}+\theta F\left(x_{n}\right)$ in case 2 above. (Hint: First let $\theta=1$.)

## 6-4. Function Evaluation : Series and Continued Fractions

Series Approximations. In the previous section we have tacitly assumed that the values of the functions entering into the equations could be somehow obtained by the computer for any given value of $x$. For polynomials no problem arises, since the evaluation of a polynomial is easily coded. On the other hand how were the values for $\sin x$ com-
puted for a particular $x$ ? We shall discuss in this and the next few sections three ways in which such functions may be evaluated by the computer. These are (1) by power-series approximations, (2) by interpolation in a table, (3) by means of "best-fit" polynomial approximations. Of course our primary purpose is to discuss functions that are not themselves polynomials or fractions of polynomials, since the methods apply trivially for polynomials.

Many functions can be easily expanded in power series, and then the functions can be evaluated by means of these series for values of $x$ within the region of convergence of the series. For example,

$$
\sin x=x-\frac{x^{3}}{3!}+\frac{x^{5}}{5!}-\frac{x^{7}}{7!}+\cdots
$$

Then, if $\sin 0.5$ were required, the computer would be coded to compute

$$
0.5-\frac{0.5^{3}}{3!}+\frac{0.5^{5}}{5!}-\frac{0.5^{7}}{7!}+\cdots
$$

If it were desired to know $\sin 0.5$ to within $\pm 0.0001$, then the series would be carried out until some term were less than 0.0001 . For example, $\sin 0.5=0.5-0.02083333+0.00026042-0.00000155$, where we stop. Hence, to the desired accuracy, $\sin 0.5=0.4794$. Another way of interpreting this result is that the polynomial approximation

$$
\sin ^{*} x=x-\frac{x^{3}}{3!}+\frac{x^{5}}{5!}
$$

is sufficiently accurate for our purposes when $x=0.5$. We write $\sin ^{*} x$ instead of $\sin x$ to indicate that this is just an approximation to $\sin x$.

On the other hand, some series do not converge quite so rapidly. For example,

$$
\arctan x=x-\frac{x^{3}}{3}+\frac{x^{5}}{5}-\frac{x^{7}}{7}+\cdots
$$

For $x=0.5$ we find

$$
\arctan * 0.5=0.5-0.041666+0.006250-0.001116
$$

which obviously is not accurate to $\pm 0.0001$.
Often other expansions of a function can be found that might converge more rapidly than the power series; e.g., for $\arctan x$ we have the series

$$
\arctan x=\frac{x}{1+x^{2}}\left[1+\frac{2}{3} \frac{x^{2}}{1+x^{2}}+\frac{2 \cdot 4}{3 \cdot 5} \frac{x^{4}}{\left(1+x^{2}\right)^{2}}+\cdots\right]
$$

Continued-fraction Approximations. There are other expansions of functions that often aid in their evaluation, for example, continued
fractions. For instance,

$$
\arctan x=\frac{x}{1+\frac{x^{2}}{3+\frac{4 x^{2}}{5+\frac{9 x^{2}}{7+\frac{16 x^{2}}{9+\cdots}}}}}
$$

It can be shown $\dagger$ that a continued fraction can be easily evaluated by means of $2 \times 2$ matrices as follows: Given the continued fraction

$$
\frac{p}{q}=a_{1}+\frac{b_{2}}{a_{2}+\frac{b_{3}}{a_{3}+\frac{b_{4}}{a_{4}+\frac{b_{5}}{a_{5}+\cdots}}}}
$$

the $n$th convergent $p_{n} / q_{n}$ is the result obtained when all terms from $n+1$ on are neglected; e.g., the fourth convergent is

$$
\frac{p_{4}}{q_{4}}=a_{1}+\frac{b_{2}}{a_{2}+\frac{b_{3}}{a_{3}+\frac{b_{4}}{a_{4}}}}
$$

The $n$th convergent may be evaluated from the following matrix equation:

$$
\left(\begin{array}{cc}
p_{n} & p_{n-1} \\
q_{n} & q_{n-1}
\end{array}\right)=\left(\begin{array}{cc}
a_{1} & 1 \\
1 & 0
\end{array}\right)\left(\begin{array}{ll}
a_{2} & 1 \\
b_{2} & 0
\end{array}\right)\left(\begin{array}{ll}
a_{3} & 1 \\
b_{3} & 0
\end{array}\right) \cdots\left(\begin{array}{ll}
a_{n} & 1 \\
b_{n} & 0
\end{array}\right)
$$

From this we can find $p_{n}$ and $q_{n}$, and also $p_{n-1}$ and $q_{n-1}$. For example, for $\arctan 0.5$ we have

$$
\begin{aligned}
\left(\begin{array}{ll}
p_{5} & p_{4} \\
q_{5} & q_{4}
\end{array}\right) & =\left(\begin{array}{ll}
0 & 1 \\
1 & 0
\end{array}\right)\left(\begin{array}{ll}
1 & 1 \\
0.5 & 0
\end{array}\right)\left(\begin{array}{ll}
3 & 1 \\
0.25 & 0
\end{array}\right)\left(\begin{array}{ll}
5 & 1 \\
1 & 0
\end{array}\right)\left(\begin{array}{ll}
7 & 1 \\
2.25 & 0
\end{array}\right) \\
& =\left(\begin{array}{rr}
59.3750 & 8.00 \\
128.0625 & 17.25
\end{array}\right)
\end{aligned}
$$

Hence

$$
\frac{p_{5}}{q_{5}}=\frac{59.3750}{128.0625}=0.4636 \quad \text { and } \quad \frac{p_{4}}{q_{4}}=\frac{8.00}{17.25}=0.4637
$$

Thus, $\arctan 0.5=0.4636$ to within $\pm 0.0001$ (since the difference between the fourth and fifth convergents was 0.0001 ). We see that the infinite-fraction expansion of $\arctan x$ converged faster than its powerseries expansion.
$\dagger$ See L. M. Milne-Thomson, "The Calculus of Finite Differences, p. 108, The Macmillan Company, New York, 1951.

There are of course many other kinds of expansions of functionsfor instance, engineers will be familiar with Fourier-series expansions. However, the evaluation of a function by means of an expansion is not always the preferred method. Hence other means are often resorted to, and we shall consider a few of them briefly in the following sections.

## EXERCISES

(a) Of the second series expansion given above for $\arctan x$, how many terms are needed to determine arctan 0.5 to within $\pm 0.001$ ?
(b) Using the continued-fraction expansion of $\arctan x$, compute the value of $\pi$ to seven significant figures. (Hint: $\arctan 1=\pi / 4$.)
(c) Draw a flow chart for evaluating the $n$th convergent of a continued fraction.

## 6-5. Function Evaluation : Interpolation

Polynomial Interpolation. Until now we have been considering functions that are memorized in the computer as subroutines. For instance, if $y=f(x)$, then for a given $x_{1}$ the computer will determine $f\left(x_{1}\right)$ by means of a program, which might be based on some expansion of $f(x)$. On the other hand it is often impossible to write a program for a certain function: e.g., the function might be empirical data, or perhaps the subroutine might require too much time or too much memory space. In these and other instances it is often convenient to record values of $f(x)$ in the computer memory in the form of a function table which gives the $f\left(x_{i}\right)$ corresponding to a set of specific values of $x_{i}$. It appears at first glance that this method has great limitations, since only those values of $f(x)$ which correspond to a relatively few values of $x_{i}$ are in the memory of the computer. However, by means of interpolation, values of $f(x)$ corresponding to an $x$ not listed in the table can be approximated.

Suppose that it is desired to find the value of $f(x)$ for a value of $x$ not listed in the table. It may happen that there are listed in the table some values of $f\left(x_{i}\right)$ for $x_{i}$ near $x$. Then, in order to find the value of $f(x)$, it seems plausible to draw a smooth curve, $y=f^{*}(x)$, through all the points listed in the table and to say that $y=f^{*}(x)$ as read from this curve is an approximation to $y=f(x)$ (see Fig. 6-8). Such a process is called interpolation and is most often accomplished by means of a polynomial approximation.

If $n+1$ points $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right),\left(x_{2}, y_{2}\right), \ldots,\left(x_{n}, y_{n}\right)$ of $f(x)$ are listed in the table, then a unique polynomial of the $n$th degree, $f^{*}(x)$, can be derived that passes through all these $n+1$ distinct points.

For let

$$
y=f^{*}(x)=A_{0}+A_{1} x+A_{2} x^{2}+\cdots+A_{n} x^{n}
$$

If $f^{*}\left(x_{0}\right)=y_{0}, f^{*}\left(x_{1}\right)=y_{1}, \ldots, f^{*}\left(x_{n}\right)=y_{n}$, then these are $n+1$ equations which can be solved for $A_{0}, A_{1}, \ldots, A_{n}$. Once these values have been obtained, we can find for any $x^{\prime} \neq x_{i}$ the value of $f^{*}\left(x^{\prime}\right)$. The more points considered, i.e., the higher the degree of $f^{*}(x)$, the closer
will be the value of $f^{*}\left(x^{\prime}\right)$ to $f\left(x^{\prime}\right)$. Let $f_{0,1}^{*}(x)$ represent the polynomial, of first degree that goes through the points $\left(x_{0}, y_{0}\right)$ and ( $x_{1}, y_{1}$ ); let $f_{0,1,2}^{*}(x)$ represent the polynomial of second degree that goes through the points ( $x_{0}, y_{0}$ ), ( $x_{1}, y_{1}$ ), and ( $x_{2}, y_{2}$ ); etc. Suppose that we want the interpolation $f^{*}\left(x^{\prime}\right)$ to within an accuracy of 0.001 . To obtain this, we would calculate


Fig. 6-8. A third-degree polynomial drawn through the four points ( $-1,-0.785$ ), $(-0.2,-0.197),(+0.2,+0.197),(+1,+0.785)$, as an approximation to arctan $x$, is shown by the solid line. Here $f^{*}(x)=\arctan ^{*} x=0.995 x-0.210 x^{3}$. The dashed line is the actual arctan.
successively $f_{0,1}^{*}\left(x^{\prime}\right), f_{0,1,2}^{*}\left(x^{\prime}\right), f_{0,1,2,3}^{*}\left(x^{\prime}\right)$, etc., until

$$
\left|f_{0,1, \ldots, r-1}^{*}\left(x^{\prime}\right)-f_{0,1, \ldots, r}^{*}\left(x^{\prime}\right)\right|<0.001
$$

and then we would take $f_{0,1, \ldots, r}^{*}\left(x^{\prime}\right)$ as our result.
Usually, the more known points used in an interpolation, the better becomes the accuracy of the interpolation. However, if the additional points are far from the point of interpolation, they may actually make the approximation worse. Similarly, with the same number of given points, the smaller the interval in which they are chosen, the more accurate the polynomial approximation in that interval. To illustrate this latter point, in Fig. 6-9 we have drawn the error curves for two polynomial approximations to $\arctan x$. Each error curve has $x$ as abscissa and the difference between the actual value of $\arctan x$ and its polynomial
approximation as the ordinate. The first approximation is based on the six points $-1,-0.6,-0.2,+0.2,+0.6$, and 1 ; the second approximation, on the six points $0,0.2,0.4,0.6,0.8$, and 1 . Figure 6-9 illustrates the error curves for $0 \leq x \leq 1$. Note that in this interval the maxi-


Fig. 6-9. Comparison of the error curves for the interpolation polynomial of arctan* $x$ based on the six points $-1,-0.6,-0.2,+0.2,+0.6,+1$ (the curve with the big hump) and based on the six points $0,0.2,0.4,0.6,0.8,1$ (the curve that hugs the $x$ axis). These error curves indicate just how much the interpolation polynomials differ from the true value of $\arctan x$.
mum error in the former case is over forty times the maximum error in the latter case.

Obviously the sequence of calculations for a polynomial interpolation would be quite lengthy for each desired value if all the coefficients had to be calculated first, and then $f^{*}\left(x^{\prime}\right)$. The process can be shortened by calculating $f^{*}\left(x^{\prime}\right)$ directly, at essentially the same time as the coefficients are calculated. That is, the coefficients are never explicitly given, but $f^{*}\left(x^{\prime}\right)$ results directly. It should be remembered, however, that the meaning of $f^{*}\left(x^{\prime}\right)$ is the value at $x^{\prime}$ of the approximating polynomial that goes through the specified points.

SEC. 6-5] FUNDAMENTALS OF NUMERICAL ANALYSIS
Aitken's Method. One method for shortening calculations, called Aitken's method, follows. $\dagger$ First note that

$$
f_{0,1}^{*}(x)=\frac{\left|\begin{array}{ll}
y_{0} & x_{0}-x  \tag{a}\\
y_{1} & x_{1}-x
\end{array}\right|}{x_{1}-x_{0}}
$$

where $\left|\begin{array}{ll}y_{0} & x_{0}-x \\ y_{1} & x_{1}-x\end{array}\right|$ is the determinant with value $y_{0}\left(x_{1}-x\right)-y_{1}\left(x_{0}-x\right)$. For
and

$$
\begin{aligned}
& f_{0,1}^{*}\left(x_{0}\right)=\frac{\left|\begin{array}{cc}
y_{0} & 0 \\
y_{1} & x_{1}-x_{0}
\end{array}\right|}{x_{1}-x_{0}}=\frac{y_{0}\left(x_{1}-x_{0}\right)}{x_{1}-x_{0}}=y_{0} \\
& f_{0,1}^{*}\left(x_{1}\right)=\frac{\left|\begin{array}{cc}
y_{0} & x_{0}-x_{1} \\
y_{1} & 0
\end{array}\right|}{x_{1}-x_{0}}=y_{1}
\end{aligned}
$$

Since $f_{0,1}^{*}(x)$ goes through the points $\left(x_{0}, y_{0}\right)$ and $\left(x_{1}, y_{1}\right)$ and is of the first degree, it is the required (unique) polynomial. Hence, for a given number $x^{\prime}$, to find $f_{0,1}^{*}\left(x^{\prime}\right)$ we just calculate Eq. (a) with this number $x^{\prime}$ substituted for the symbol $x$.

The polynomial that goes through $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right)$, and $\left(x_{2}, y_{2}\right)$ is given by

$$
f_{0,1,2}^{*}(x)=\frac{\left|\begin{array}{cc}
f_{0,1}^{*}(x) & x_{1}-x \\
f_{0,2}^{*}(x) & x_{2}-x
\end{array}\right|}{x_{2}-x_{1}}
$$

where $f_{0,2}^{*}(x)$ is the polynomial that goes through ( $x_{0}, y_{0}$ ) and ( $x_{2}, y_{2}$ ).
For $f_{0,1,2,3}^{*}(x)$ we have similarly

$$
f_{0,1,2,3}^{*}(x)=\frac{\left|\begin{array}{ll}
f_{0,1,2}^{*}(x) & x_{2}-x \\
f_{0,1,3}^{*}(x) & x_{3}-x
\end{array}\right|}{x_{3}-x_{2}}
$$

The process can be extended in this way. For example,

$$
f_{0,1,2,3,4,5,6}^{*}(x)=\frac{\left|\begin{array}{ll}
f_{0,1,2,3,4,5}^{*}(x) & x_{5}-x \\
f_{0,1,2,3,4,6}^{*}(x) & x_{6}-x
\end{array}\right|}{x_{6}-x_{5}}
$$

Hence the process can be systematized, with $f^{*}(x)$ being recomputed, including more and more points until the desired accuracy is obtained (assuming that there are enough points in the table). The following scheme can be used for performing the calculations, the terms in each
$\dagger$ See W. E. Milne, "Numerical Calculus," pp. 68-72, Princeton University Press, Princeton, N.J., 1949.
row being determined in order:


## EXERCISES

(a) Show that $f_{0,1,2,3}^{*}(x)$ actually does pass through all the points $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right)$, $\left(x_{2}, y_{2}\right),\left(x_{3}, y_{3}\right)$ and is of degree 3.
(b) Show that

$$
f_{0,1,2}^{*}(x)=\frac{\left|\begin{array}{cc}
f_{0,1}^{*}(x) & x_{0}-x \\
f_{1,2}^{*}(x) & x_{2}-x
\end{array}\right|}{x_{2}-x_{0}}=\frac{\left|\begin{array}{cc}
f_{0,2}^{*}(x) & x_{0}-x \\
f_{1,2}^{*}(x) & x_{1}-x
\end{array}\right|}{x_{1}-x_{0}}
$$

(c) Compute $\arctan 0.9$, where $\arctan x$ is given by a table for values of $x$ differing by 0.4 , as shown:

| $x_{i}$ | $\arctan x_{i}$ |  |  | Solution |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $x_{0}=-1.0$ | -0.7854 | -1.9 |  |  |  |  |  |  |  |  |
| $x_{1}=-0.6$ | -0.5404 | -1.5 | 0.3783 |  |  |  |  |  |  |  |
| $x_{2}=-0.2$ | -0.1974 | -1.1 | 0.6111 | 1.2515 |  |  |  |  |  |  |
| $x_{3}=+0.2$ | +0.1974 | -0.7 | 0.7707 | 1.1141 | 0.8736 |  |  |  |  |  |
| $x_{4}=+0.6$ | +0.5404 | -0.3 | 0.7890 | 0.8917 | 0.7568 | 0.6691 |  |  |  |  |
| $x_{5}=+1.0$ | +0.7854 | +0.1 | 0.7068 | 0.6863 | 0.7334 | 0.7509 | 0.7305 |  |  |  |

(d) Compute arctan 0.75 from the table values given in the previous exercise.

## 6-6. Function Evaluation : Best-fit Polynomial Approximation

Polynomial Approximations. As we have noted in Sec. 6-4, the evaluation of $f(x)$ by means of terms up to the $x^{n}$ term of its power-series expansion can be considered as approximating $f(x)$ by a polynomial of degree $n$, where the coefficients are given by Taylor's formula. Similarly the method of interpolation can also be interpreted as the approximation of $f(x)$ by a polynomial, even though the polynomial may never be explicitly determined by the method given; the coefficients of the interpolation polynomial of degree $n$ are determined from $n+1$ known values of $f(x)$. For $\arctan x$ we have the power-series approximation

$$
\arctan ^{*} x=1.000000 x-0.333333 x^{3}+0.200000 x^{5}
$$

For the interpolation approximation (for the points $-1,-0.6,-0.2$, $+0.2,+0.6$, and 1 given in Sec. 6-5) we have

$$
\arctan ^{*} x=0.999105 x-0.306897 x^{3}+0.093190 x^{5}
$$

SEC. 6-6] FUNDAMENTALS OF NUMERICAL ANALYSIS
In order to show how good these approximations are, in Fig. 6-10 have been drawn the error functions

$$
\epsilon(x)=\text { approximation }- \text { function }=\arctan ^{*} x-\arctan x
$$

for the range $0 \leq x \leq 1$, for both cases.
Best-fit Polynomials. The question immediately arises: Does there exist another fifth-degree polynomial that is a "better fit" to arctan $x$


Fig. 6-10. A comparison, by means of error curves, of three fifth-degree polynomial approximations to $\arctan x$ for $0 \leq x \leq 1$.

1. Power-series approximation:

$$
\arctan * x=1.000000 x-0.333333 x^{3}+0.200000 x^{5}
$$

2. Interpolation approximation on the points $-1,-0.6,-0.2,+0.2,+0.6$, and 1 :

$$
\arctan ^{*} x=0.999105 x-0.306897 x^{3}+0.093190 x^{5}
$$

3. Best-fit approximation:

$$
\arctan ^{*} x=0.995354 x-0.288679 x^{3}+0.079331 x^{5}
$$

for $0 \leq x \leq 1$ ? We say that $f_{1}^{*}(x)$ is a better fit to $f(x)$ than $f_{2}^{*}(x)$ for a given range of $x$ if within that range $\max \left|\epsilon_{1}(x)\right|<\max \left|\epsilon_{2}(x)\right|$. In general the answer to the above question is "yes." For $\arctan x$ the bestfit polynomial for $0 \leq x \leq 1$ is given by

$$
\arctan ^{*} x=0.995354 x-0.288679 x^{3}+0.079331 x^{5}
$$

Figure 6-10 also shows $\epsilon(x)$ for this approximation. How one arrives at such best-fit approximations is beyond the scope of this book. $\dagger$


Fig. 6-11. Error curve for $f(x)=\frac{2}{\sqrt{\pi}} \int_{0}^{x} e^{-t^{2}} d t$.
The advantage of using a best-fit approximation over a Taylor-series approximation or interpolation is easily seen: fewer computations are required to obtain the same accuracy than for a Taylor series; and no tables need be memorized in the computer, as is necessary for interpolation. Hence time and space are saved in the computation. Although we have illustrated a best-fit polynomial that is good to within $\pm 0.0005$, best-fit polynomials can be formed that will give any desired accuracy. For example, a best-fit polynomial for $\arctan x$, for $0 \leq x \leq 1$, which is good to within $\pm 0.000001$, is given by

$$
\begin{array}{rl}
\arctan ^{*} x & =0.99997726 x-0.3326 \\
& -0.11643287 \\
& 3287 \\
x^{7}+0.0526 & 5332
\end{array} x^{9}-0.0117{ }^{9}-0120 x^{11}
$$

Best-fit approximations need not be of the forms shown for $\arctan x$ but should be of some relatively simple algebraic form. For example,
$\dagger$ For such a discussion see Cecil Hastings, Jr., "Approximations for Digital Com. puters," Princeton University Press, Princeton, N.J., 1955.
for $0 \leq x \leq \infty$, a best-fit approximation for

$$
f(x)=\frac{2}{\sqrt{\pi}} \int_{0}^{x} e^{-t^{2}} d t
$$

is given by

$$
f^{*}(x)=1-\frac{1}{\left(1-a_{1} x+a_{2} x^{2}+a_{3} x^{3}+a_{4} x^{4}\right)^{4}}
$$

where $a_{1}=0.278393, a_{2}=0.230389, a_{3}=0.000972$, and $a_{4}=0.078108$. In this case $\epsilon(x)$ is given in Fig. 6-11, plotted against $\sqrt{x}$. This $f^{*}(x)$ is easily coded for a computer.

## EXERCISES

$(a, b)$. Write a code to evaluate each of the best-fit approximations to the $\arctan x$ given in this section.

## 6-7. Integration

By Definition. In this section we shall see how a computer can integrate. In his previous studies the student has been taught to integrate by means of the manipulation of abstract symbols. However, a little reflection will show that it is really numbers being handled, these numbers being represented for convenience by symbols. Of course a computer cannot directly manipulate symbols in the ordinary sense, but it can handle numbers. As we shall see, the simplest method of handling numbers to obtain an integral is to follow the very definition of the meaning of integration.

Recall now the definition of integration (see Fig. 6-12). The integral of $f(x)$ from $x=0$ to $x=p$, written $\int_{0}^{p} f(x) d x$, is the area between the


Fig. 6-12. Numerical integration. curve $y=f(x)$ and the $x$ axis, bounded by $x=0$ and $x=p$. It is found by considering the rectangles formed by partitioning the $x$ axis between 0 and $p$ into $n$ intervals each of the same length $h$, where $h=(p-0) / n$. If there are $n$ intervals each of length $h$, the area of the $i$ th rectangle will be $h y_{i}$ and the sum of the areas of all the rectangles will be

$$
A=\sum_{i=1}^{n} h y_{i}
$$

In another partition that has more intervals the length of each will be less. Hence, as the number of intervals becomes infinite, the length of each approaches 0 . The integral $\int_{0}^{p} y d x$ is defined as the limit of the sum of the areas of the rectangles as the number of intervals increases and the length of each approaches zero,

$$
\int_{0}^{p} y d x=\lim _{\substack{n \rightarrow \infty \\ h \rightarrow 0}} \sum_{i=1}^{n} h y_{i}
$$

To integrate on a computer, we could just form $\sum_{i=1}^{n} h y_{i}$. Then we might take a smaller interval, say $h / 2$, and form $\sum_{i=1}^{2 n}(h / 2) y_{i}$. If

$$
\left|\sum_{i=1}^{2 n} \frac{h}{2} y_{i}-\sum_{i=1}^{n} h y_{i}\right|
$$

is less than the allowable error desired for this integration, then the integration is completed. If not, we could try intervals of $h / 4$, and so on. This process naturally assumes that we have a subroutine to evaluate $y_{1}=f\left(x_{i}\right)$ for each $x_{i}$ under consideration.


Fig. 6-13. Trapezoidal approximation to integration.


Fig. 6-14. Parabolic approximation to integration.

By the Trapezoid Rule. Although the above method is a good way for evaluating an integral, there are methods that may require less computation. Suppose that we considered the trapezoids formed by adding little triangles to the rectangles, as shown in Fig. 6-13. Here the area of the trapezoid is $h\left[y_{0}+1 / 2\left(y_{1}-y_{0}\right)\right]=(h / 2)\left(y_{0}+y_{1}\right)$. For $n$ trape-
zoids we have $A=(h / 2)\left(y_{0}+2 y_{1}+2 y_{2}+\cdots+y_{n}\right)$. Certainly this will be a better initial approximation to the area under the curve than was $A=h\left(y_{0}+y_{1}+\cdots+y_{n}\right)$. Hence, using this method, we shall not need to go to as small intervals to obtain the desired accuracy as we did using the previous, cruder method. The method given in this paragraph is called the trapezoid rule.

By Polynomial Approximations. An even better initial approximation can be obtained by considering three points at a time instead of two. Suppose that we consider the area under the parabola $y^{*}=a+b x+c x^{2}$ that passes through three points, as shown in Fig. 6-14. Then

$$
\begin{aligned}
A_{0,2} & \left.=\int_{0}^{2 h}\left(a+b x+c x^{2}\right) d x=a x+\frac{b x^{2}}{2}+\frac{c x^{3}}{3}\right]_{0}^{2 h} \\
& =2 h \cdot a+2 h^{2} \cdot b+8 / 3 h^{3} \cdot c
\end{aligned}
$$

To determine the coefficients $a, b$, and $c$, we note that
If $x=0$,

$$
\begin{aligned}
& a+0 \cdot b+0 \cdot c=y_{0} \\
& a+h \cdot b+h^{2} \cdot c=y_{1} \\
& a+2 h \cdot b+4 h^{2} \cdot c=y_{2}
\end{aligned}
$$

If $x=h$,
If $x=2 h$,
These, when solved for $a, b$, and $c$, yield

$$
a=y_{0} \quad b=\frac{-y_{2}+4 y_{1}-3 y_{0}}{2 h} \quad c=\frac{y_{2}-2 y_{1}+y_{0}}{2 h^{2}}
$$

whence

$$
A_{0,2}=\frac{h}{3}\left(y_{0}+4 y_{1}+y_{2}\right)
$$

Similarly $A_{2,4}=(h / 3)\left(y_{2}+4 y_{3}+y_{4}\right)$, and so forth, whence, if $n$ is even, we have

$$
A=\frac{h}{3}\left(y_{0}+4 y_{1}+2 y_{2}+4 y_{3}+2 y_{4}+4 y_{5}+\cdots+4 y_{n-1}+y_{n}\right)
$$

This is known as Simpson's rule. $\dagger$
Similarly we could try to make even better initial approximations to the area under the curve. Once the method of approximation is decided upon, more accurate results can be obtained only by increasing $n$, the number of intervals-as can be seen from the original definition of the integral.

We have been assuming until now that the function $y(x)$ can be evaluated at any point $x$ by a subroutine. Suppose, on the other hand, that the function $f(x)$ were given by a table of points, spaced at equal intervals $x_{i}$. Then the above procedures would of course still hold. But these methods will evaluate integrals only between points that are given in the table, and not to other points. However, one might choose simply to integrate the approximating polynomial (determined as in the

[^3]previous sections) and then to evaluate this function between any two points, whether they are or are not given in the table.

## EXERCISES

The following table gives the values of $\arctan x$ for equally spaced points:

| $x_{i}$ | $\arctan x_{i}$ |
| :--- | :--- |
| $x_{0}=0$ | 0.00000 |
| $x_{1}=0.2$ | 0.19739 |
| $x_{2}=0.4$ | 0.38051 |
| $x_{3}=0.6$ | 0.54042 |
| $x_{4}=0.8$ | 0.67474 |
| $x_{5}=1.0$ | 0.78534 |

(a) Evaluate $\int_{0}^{0.8} \arctan x d x$ by the rectangular rule, first for partition at $x_{0}, x_{2}$, and $x_{4}$, and then for partition at $x_{0}, x_{1}, x_{2}, x_{3}$, and $x_{4}$; compare the results.
(b) Evaluate $\int_{0}^{0.8} \arctan x d x$ by the trapezoidal rule, first for partition at $x_{0}, x_{2}$, and $x_{4}$, and then for partition at $x_{0}, x_{1}, x_{2}, x_{3}$, and $x_{4}$; compare the results.
(c) Evaluate $\int_{0}^{0.8} \arctan x d x$ by Simpson's rule, first for partition at $x_{0}, x_{2}$, and $x_{4}$, and then for partition at $x_{0}, x_{1}, x_{2}, x_{3}$, and $x_{4}$; compare the results.
(d) Integrate each of the three polynomial approximations for the $\arctan x$ given in the previous section; evaluate each of these integrals from 0 to 0.8 , and compare the results of each with the results of Exercises $a$ to $c$.
(e) Observing that (the indefinite integral)

$$
\int \arctan x d x=x \arctan x-1 / 2 \ln \left(1+x^{2}\right)
$$

find $\int_{0}^{0.8} \arctan x d x$; compare this result with those of Exercises $a$ to $d$.
$(f)$ Write a code for evaluating Simpson's rule, assuming that $f(x)$ is evaluated by a subroutine.

## 6-8. Differentiation

By Definition. The derivative of $y=f(x)$ with respect to $x$, taken at $x=x_{0}$, is defined by

$$
\left(\frac{d y}{d x}\right)_{x=x_{0}}=\lim _{\Delta x \rightarrow 0} \frac{f\left(x_{0}+\Delta x\right)-f\left(x_{0}\right)}{\Delta x}
$$

and represents the slope of the tangent drawn to the curve $y=f(x)$ at $x_{0}$. Hence, if $f(x)$ is given at $x=x_{0}$ and $x=x_{1}$, an approximation of the derivative might be

$$
\frac{f\left(x_{1}\right)-f\left(x_{0}\right)}{x_{1}-x_{0}}
$$

Unfortunately it is not always feasible with computers to take $x_{1}$ successively closer to $x_{0}$ and evaluate the fraction each time, for $x_{1}-x_{0}$
becomes very small, as does $f\left(x_{1}\right)-f\left(x_{0}\right)$, and often for a very small $x_{1}-x_{0}$ the loss of significant figures throws the calculation far off.
By Polynomial Approximation. Suppose that $f(x)$ is given at $x_{0}=0$, $x_{1}=h$, and $x_{2}=2 h$. Analogous to the process described for integration, we might determine as an approximation the derivative of the parabola


Fig. 6-15. Approximating the derivative from an oscillating polynomial.
that goes through these three points. Let $y=a+b x+c x^{2}$, where $a, b$, and $c$ are as in Sec. 6-7. Hence

$$
\frac{d y}{d x}=b+2 c x=\frac{-y_{2}+4 y_{1}-3 y_{0}}{2 h}+\frac{y_{2}-2 y_{1}+y_{0}}{h^{2}} x
$$

Then for the derivatives taken at $x=x_{0}, x=x_{1}$, and $x=x_{2}$, respectively, we have

$$
\begin{aligned}
& \left(\frac{d y}{d x}\right)_{\substack{x=0 \\
y=y_{0}}}=\frac{1}{2 h}\left(-3 y_{0}+4 y_{1}-y_{2}\right) \\
& \left(\frac{d y}{d x}\right)_{\substack{x=h \\
y=y_{1}}}=\frac{1}{2 h}\left(-y_{0}+y_{2}\right) \\
& \left(\frac{d y}{d x}\right)_{\substack{x=2 h \\
y=y_{2}}}=\frac{1}{2 h}\left(y_{0}-4 y_{1}+3 y_{2}\right)
\end{aligned}
$$

The formulas are equally valid for any three points $\left(x_{0}, y_{0}\right)$, $\left(x_{1}, y_{1}\right)$, and ( $x_{2}, y_{2}$ ) equally spaced on the $x$ axis, since translating the curve so that $x_{0}=0$ does not affect its slope. $\dagger$ If the function is given by means of a table, then these rules can be used for evaluating derivatives at points given in the table.
Of course there are always the approximating polynomials of $f(x)$, which
$\dagger$ See, for example, ibid., p. 96.
can easily be differentiated, the resulting derivative being evaluated at the requisite points.

However, numerical differentiation at best is often quite inaccurate. For these methods must be based on approximating polynomials that depend on values of the function at a few specific points. There is no practical way for the computer to tell how the approximating polynomial oscillates around the given function. Hence the slope of the polynomial at a point may be entirely different from the slope of the function, even though the curves lie very close, or even touch (see Fig. 6-15). On the other hand the value of the area under the curve is seldom so sensitive to these oscillations.

## EXERCISES

Use the table of values of $\arctan x$ as given for the Exercises of Sec. 6-7.
(a) Determine the derivative of $\arctan x$ at $x=0.6$, using first $\Delta x$ between the two points at $x=0.4$ and $x=0.6$, and then between the points at $x=0.6$ and $x=0.8$.
(b) Determine the derivative of $\arctan x$ at $x=0.6$ by using the three points first at $x_{0}=0.6, x_{1}=0.8$, and $x_{2}=1.0$, then at $x_{0}=0.4, x_{1}=0.6$, and $x_{2}=0.8$, and finally at $x_{0}=0.2, x_{1}=0.4$, and $x_{2}=0.6$.
(c) Differentiate each of the three approximating polynomials for arctan $x$ given in Sec. 6-6, and in each case evaluate the derivative at $x=0.6$.
(d) Using the form

$$
\frac{d}{d x} \arctan x=\frac{1}{1+x^{2}}
$$

evaluate the derivative of $\arctan x$ at $x=0.6$, and compare this with the approximations of (a), (b), and (c).

## 6-9. Undetermined Coefficients

The Method. As was shown in the previous two sections, formulas for the integral or derivative of a function can be obtained by integrating or differentiating the polynomial approximation functions that pass through some given points. However, in these sections formulas were specifically derived only where three points were fitted. Formulas based on more points can be derived by the method of undetermined coefficients, $\dagger$ which follows. We shall develop the method by means of illustrations.

Suppose that we wish to rederive the formula of Sec. 6-7, Simpson's rule, and find an approximation of $\int_{x_{0}}^{x_{2}} y d x$ based on the polynomial $y=f^{*}(x)$ of the second degree passing through the three points $\left(x_{0}, y_{0}\right)$, $\left(x_{1}, y_{1}\right),\left(x_{2}, y_{2}\right)$ with equally spaced abscissas. Since the value of an integral does not change if it is translated along the $x$ axis, it will prove helpful to take advantage of symmetry, by letting the $x$ coordinates of these points be $x_{0}=-h, x_{1}=0, x_{2}=+h$. Now let

$$
A_{0} y_{0}+A_{1} y_{1}+A_{2} y_{2}=\int_{x_{0}}^{x_{2}} y d x
$$

$\dagger$ See ibid., p. 104.
where $A_{0}, A_{1}$, and $A_{2}$ are the as yet undetermined coefficients. This formula must be exact (i.e., not an approximation) for $y=f(x)$, when $f(x)$ is any polynomial of degree 2 or less, because there is a uniquely determined polynomial of degree not more than $n$ that passes through $n+1$ points. Hence this formula must be true for the functions $y=1, y=x$, and $y=x^{2}$. Substituting these three functions successively in the equation, we find

$$
\begin{aligned}
A_{0}+A_{1}+A_{2} & =2 h \\
-h A_{0}+0 \cdot A_{1}+h A_{2} & =0 \\
h^{2} A_{0}+0 \cdot A_{1}+h^{2} A_{2} & =2 / 3 h^{3}
\end{aligned}
$$

Solving for $A_{0}, A_{1}$, and $A_{2}$, we find

Hence

$$
\begin{gathered}
A_{0}=A_{2}=1 / 3 h \quad \text { and } \quad A_{1}=4 / 3 h \\
\int_{x_{0}}^{x_{2}} y d x=\frac{h}{3}\left(y_{0}+4 y_{1}+y_{2}\right)
\end{gathered}
$$

as desired.
Suppose that we now desire to find a formula for $(d y / d x)_{x=x_{1}}$ based on four points with equally spaced abscissas, $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right),\left(x_{2}, y_{2}\right)$, and $\left(x_{3}, y_{3}\right)$. Let $x_{0}=-h, x_{1}=0, x_{2}=h, x_{3}=2 h$,
and

$$
B_{0} y_{0}+B_{1} y_{1}+B_{2} y_{2}+B_{3} y_{3}=\left(\frac{d y}{d x}\right)_{x=x_{1}}
$$

where $B_{0}, B_{1}, B_{2}$, and $B_{3}$ are the undetermined coefficients. This formula must be exact when $y$ is any polynomial of degree not more than 3 , and hence for the polynomials $y=1, y=x, y=x^{2}$, and $y=x^{3}$. Substituting these successively into the equation, we find

$$
\begin{aligned}
B_{0}+B_{1}+B_{2}+B_{3} & =0 \\
-h B_{0}+0 \cdot B_{1}+h B_{2}+2 h B_{3} & =1 \\
h^{2} B_{0}+0 \cdot B_{1}+h^{2} B_{2}+4 h^{2} B_{3} & =0 \\
-h^{3} B_{0}+0 \cdot B_{1}+h^{3} B_{2}+8 h^{3} B_{3} & =0
\end{aligned}
$$

These, when solved for $B_{0}, B_{1}, B_{2}$, and $B_{3}$, give

$$
B_{0}=-1 / 3 h \quad B_{1}=-1 / 2 h \quad B_{2}=\frac{1}{h} \quad \text { and } \quad B_{3}=-1 / 6 h
$$

whence $\quad\left(\frac{d y}{d x}\right)_{x=x_{1}}=1 / 6 h\left(-2 y_{0}-3 y_{1}+6 y_{2}-y_{3}\right)$

## EXERCISES

(a) Show that, if $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right),\left(x_{2}, y_{2}\right)$, and $\left(x_{3}, y_{3}\right)$ are four points with equally spaced abscissas, then

$$
\int_{x_{1}}^{x_{2}} y d x=\frac{h}{24}\left(-y_{0}+13 y_{1}+13 y_{2}-y_{3}\right)
$$

(Hint: Let $x_{0}=-3 / 2 h, x_{1}=-h / 2, x_{2}=h / 2$, and $x_{3}=3 / 2 h$; let the three functions be $y=1, y=x, y=x^{2}$, and $y=x^{3}$.)
(b) If five points with equally spaced abscissas are given, $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right),\left(x_{2}, y_{2}\right)$, $\left(x_{3}, y_{3}\right)$, and $\left(x_{4}, y_{4}\right)$, then find $\int_{x_{1}}^{x_{3}} y d x$.
(c) Derive the formulas given in Sec. 6-8 by the method of undetermined coefficients.
(d) If four points with equally spaced abscissas, $\left(x_{0}, y_{0}\right),\left(x_{1}, y_{1}\right),\left(x_{2}, y_{2}\right)$, and $\left(x_{3}, y_{3}\right)$, are given, find formulas for

$$
\left(\frac{d y}{d x}\right)_{x=x_{0}} \quad\left(\frac{d y}{d x}\right)_{x-x_{1}} \quad\left(\frac{d y}{d x}\right)_{x=x_{2}} \quad\left(\frac{d y}{d x}\right)_{x=x_{2}}
$$

(e) Find the formula for $\int_{x_{0}}^{x_{1}} y d x$ in terms of the two points $\left(x_{0}, y_{0}\right)$ and ( $x_{1}, y_{1}$ ), and the derivatives at these points,

$$
y_{0}^{\prime}=\left(\frac{d y}{d x}\right)_{x-x_{0}} \quad \text { and } \quad y_{1}^{\prime}=\left(\frac{d y}{d x}\right)_{x-x_{1}}
$$

(Hint: Let $x_{0}=0, x_{1}=h$; let

$$
\int_{x_{0}}^{x_{1}} y d x=A_{0} y_{0}+A_{1} y_{1}+B_{0} y_{0}^{\prime}+B_{1} y_{1}^{\prime}
$$

where $A_{0}, A_{1}, B_{0}$, and $B_{1}$ are undetermined coefficients. Now, when the functions $y=1, y=x, y=x^{2}$, and $y=x^{3}$ are substituted successively into the equation, there result four simultaneous equations that determine $A_{0}, A_{1}, B_{0}$, and $B_{1}$.)

## 6-10. Differential Equations

Meaning of Solution. A differential equation describes how a system goes from a known point to the next infinitesimally close point. For example, the well-known equation $d v / d t=F / m$ describes the relationship of the velocity $v$ of the mass $m$ to the time $t$, when a force $F$ is applied. Given a point $\left(t_{0}, v_{0}\right)$, the equation says that at an infinitesimally short time later, say at $t_{1}$, the velocity will be $v_{1}=(F / m)\left(t_{1}-t_{0}\right)+v_{0}$. Such equations arise because in nature relationships between physical quantities often reduce to linear functions at the infinitesimal level.

Consider, for example, a differential equation of the first order in the form

$$
\frac{d y}{d x}=f(x, y)
$$

The solution is to be determined as a function of $x$ only, that is, $y=g(x)$. Of course $y=g(x)$ can be represented as a curve, and the differential equation tells us how to draw this curve. One point on the curve, say ( $x_{0}, y_{0}$ ), must be known or given. Then the differential equation says that

$$
\left(\frac{d y}{d x}\right)_{x=x_{0}}=f\left(x_{0}, y_{0}\right)
$$

and hence we know the slope at ( $x_{0}, y_{0}$ ). A linear approximation to the next point might be obtained (see Fig. 6-16) by continuing along the tangent line, i.e., by choosing an $x_{1}$ and determining $y_{1}$ from

$$
y_{1}=\left(\frac{d y}{d x}\right)_{x=x_{0}}\left(x_{1}-x_{0}\right)+y_{0}
$$

Using ( $x_{1}, y_{1}$ ), we find that $(d y / d x)_{x=x_{1}}=f\left(x_{1}, y_{1}\right)$ and then, choosing an $x_{2}$, determine $y_{2}$ from

$$
y_{2}=\left(\frac{d y}{d x}\right)_{x=x_{1}}\left(x_{2}-x_{1}\right)+y_{1}
$$

and in this manner $\left(x_{3}, y_{3}\right), \ldots$ are determined and the function $y=g(x)$


Fig. 6-16. Linear approximation from point to point along a curve.


Frg. 6-17. Polynomial approximation from point to point along a curve.
is approximated. Of course this is just an approximation, even if we make $x_{1}-x_{0}, x_{2}-x_{1}, x_{3}-x_{2}, \ldots$ small, for the differential equation taken literally implies that $x_{1}-x_{0}, x_{2}-x_{1}, \ldots$ should be infinitesimal. What we are essentially saying by this method is that a straight line through ( $x_{0}, y_{0}$ ) is a good approximation to $g(x)$ near ( $x_{0}, y_{0}$ ) and therefore the next point ( $x_{1}, y_{1}$ ) ought to lie very close to it.

By Polynomial Approximation. Consider again a first-order differential equation $d y / d x=f(x, y)$. A better approximation to $y=g(x)$ might be obtained if we started with two points, $\left(x_{0}, y_{0}\right)$ and $\left(x_{1}, y_{1}\right)$. Then we could use a parabola as the approximating curve of $g(x)$ near $\left(x_{0}, y_{0}\right)$ and $\left(x_{1}, y_{1}\right)$, to determine $\left(x_{2}, y_{2}\right)$ (see Fig. 6-17). Take, for example, the second formula for the parabolic approximation of Sec. 6-8,

From this

$$
\left(\frac{d y}{d x}\right)_{x=x_{1}}=\frac{1}{2 h}\left(-y_{0}+y_{2}\right)
$$

$$
y_{2}=2 h\left(\frac{d y}{d x}\right)_{x=x_{1}}+y_{0}
$$

Hence if we take $x_{1}=x_{0}+h, x_{2}=x_{0}+2 h$, etc., and if we know ( $x_{0}, y_{0}$ ) and ( $x_{1}, y_{1}$ ), then we can determine ( $\left.d y / d x\right)_{x=x_{1}}=f\left(x_{1}, y_{1}\right)$, and from this $y_{2}$. Our equation from Sec. 6-8 can be written in general as

$$
y_{n+1}=2 h\left(\frac{d y}{d x}\right)_{x=x_{n}}+y_{n-1}
$$

Thence we find $y_{3}$ for $x_{3}=x_{0}+3 h$, using $(d y / d x)_{x=2}=f\left(x_{2}, y_{2}\right)$, and so forth. This process is clear, provided that initially we know ( $x_{1}, y_{1}$ ) as well as $\left(x_{0}, y_{0}\right)$. Given ( $x_{0}, y_{0}$ ), we can find ( $\left.x_{1}, y_{1}\right)$ by forming a Taylorseries expansion around ( $x_{0}, y_{0}$ ). Since we already know $d y / d x=f(x, y)$, then

$$
\frac{d^{2} y}{d x^{2}}=\frac{d}{d x} f(x, y) \quad \frac{d^{3} y}{d x^{3}}=\frac{d^{2}}{d x^{2}} f(x, y) \quad \text { etc. }
$$

for the coefficients, and hence ( $x_{1}, y_{1}$ ) is easily found,

$$
\begin{aligned}
y_{1}=y_{0}+\left(x_{1}-x_{0}\right)\left(\frac{d y}{d x}\right)_{x=x_{0}}+\frac{\left(x_{1}-x_{0}\right)^{2}}{2!} & \left(\frac{d^{2} y}{d x^{2}}\right)_{x=x_{0}} \\
& +\frac{\left(x_{1}-x_{0}\right)^{3}}{3!}\left(\frac{d^{3} y}{d x^{3}}\right)_{x=x_{0}}+\cdots
\end{aligned}
$$

where the first few terms are usually sufficient.
Similarly higher-degree approximation polynomials can be used to estimate successive points. For example, a cubic might be used that is based on

$$
\left(x_{0}, y_{0}\right) \quad\left(x_{1}, y_{1}\right) \quad\left(\frac{d y}{d x}\right)_{x=x_{0}} \quad \text { and } \quad\left(\frac{d y}{d x}\right)_{x=x_{1}}
$$

Such formulas can be derived by means of the method of undetermined coefficients.

Example. As an example, consider the differential equation

$$
\frac{d y}{d x}=1+y^{2}
$$

Suppose that, at $x_{0}=0, y_{0}=0$. Choose $x_{1}=0.1, x_{2}=0.2, x_{3}=0.3$, etc. Then, by our first, linear method,

$$
\begin{gathered}
y_{1}=\left(\frac{d y}{d x}\right)_{x=x_{0}}\left(x_{1}-x_{0}\right)+y_{0}=\left(1+y_{0}^{2}\right)\left(x_{1}-x_{0}\right)+y_{0} \\
\quad=(1+0)(0.1-0)+0=0.1 \\
y_{2}=\left(\frac{d y}{d x}\right)_{x=x_{1}}\left(x_{2}-x_{1}\right)+y_{1}=\left(1+y_{1}^{2}\right)\left(x_{2}-x_{1}\right)+y_{1} \\
\quad=1.01 \times 0.1+0.1=0.201 \\
y_{3}=\left(\frac{d y}{d x}\right)_{x=x_{2}}\left(x_{3}-x_{2}\right)+y_{2}=\left(1+y_{2}^{2}\right)\left(x_{3}-x_{2}\right)+y_{2}=0.3050
\end{gathered}
$$

and so forth.

Next consider the quadratic method. We must first find $y_{1}$ for $x_{1}=0.1$. Taking the first three terms of the Taylor expansion,

$$
\begin{aligned}
y_{1} & =y_{0}+\left(x_{1}-x_{0}\right)\left(1+y_{0}^{2}\right)+\frac{\left(x_{1}-x_{0}\right)^{2}}{2!} 2 y_{0}\left(1+y_{0}^{2}\right) \\
& \quad+\frac{\left(x_{1}-x_{0}\right)^{3}}{3!}\left[2\left(1+y_{0}^{2}\right)^{2}+4 y_{0}^{2}\left(1+y_{0}^{2}\right)\right] \\
& =0+0.1+0+0.0003 \\
& =0.1003
\end{aligned}
$$

Then

$$
\begin{aligned}
y_{2}=0.2\left(\frac{d y}{d x}\right)_{x=x_{1}}+y_{0}=0.2 \times\left(1+y_{1}{ }^{2}\right)+y_{0}= & 0.2 \times 1.0101+0 \\
& =0.2020 \\
y_{3}=0.2\left(\frac{d y}{d x}\right)_{x=x_{2}}+y_{1}= & 0.2 \times\left(1+y_{2}{ }^{2}\right)+y_{1}=0.2 \times 1.0408
\end{aligned}
$$

$$
+0.1003=0.3085
$$

and so forth. The exact solution to $d y / d x=1+y^{2}$ is $y=\tan x$. With greater accuracy, we have $y_{0}=\tan 0=0, y_{1}=\tan 0.1=0.1021$, $y_{2}=\tan 0.2=0.2035$, and $y_{3}=\tan 0.3=0.312$.
Since in the numerical solution of a differential equation each point depends on previous points, errors are cumulative. Hence the only way to get a better solution is to take the interval $h$ smaller for a particular method of approximation.

## EXERCISES

(a) Solve $d y / d x=1+y^{2}$ for $h=0.01$ and $h=0.001$ by both methods, and compare with a table of $\tan x$.
(b) Solve $d y / d x=\sqrt{1-y^{2}}$ by both methods, with intervals $h=0.1$ and 0.01 , where $x_{0}=0, y_{0}=0$. Compare the solutions with a table of $\sin x$.

## 6-11. Accuracy and Error

Sources of Error. We can distinguish among three contributions to the error of a numerical computation:

1. First is the error due to the approximate nature of the numerical analysis of the computations. As we have seen in previous sections, frequently the value of a function or the solution to an equation can theoretically be obtained only by performing an infinite sequence of iterations. Of course the infinite process cannot be completed, and so we must stop with some iteration in the sequence, accepting this as an adequate approximation to the desired results. The resulting error is called a truncated error and often can be made as small as we please. The problem here then is to estimate the accuracy of the result after an iieration to determine whether or not it is as precise as required, i.e., whether or not more iterations should be made.
2. Second is the error due to the approximate nature of experimental data used in the calculation; this is called the experimental error. Here the problem is so to analyze the experimental data as to obtain the best possible estimate of the measurement involved, i.e., to determine the accuracy of the experimentally obtained numbers. The accuracy of such numbers depends on aspects other than mathematical considerations, and therefore from a computational point of view these errors are treated as initial constraints on the problem.
3. Third is the error due to the use of approximate numbers in performing the numerical calculations; such errors are called round-off errors. Any number that we write is necessarily in finite decimal (or binary) form, which is only an approximation to its infinite decimal conception. $\dagger$ For example, $\pi$ might be approximated by 3.1415927 . Numbers can be approximated to any degree of accuracy: e.g., a better approximation to $\pi$ is 3.141592653589793 . Experimental numbers may also be considered to be finite approximations of some (unknown) infinite decimal. Here of course we cannot get any better approximation than those determined by methods associated with the above-discussed second source of error. Thus the problem here is to perform the four arithmetic operations in a manner that retains the maximum desired accuracy under the circumstances.

Consideration of truncated errors forms a large subject in itself. For the various iterative formulas given in the previous sections, formulas can be obtained for the errors, or for bounds on the errors, after any particular iteration. For example, the remainder formula for a Taylor series is familiar to the student as a measure of the error of approximation of a finite number of terms of a power series. Textbooks on numerical analysis consider these formulas in detail; this subject is, however, beyond the scope of the present brief treatment. Consideration of experimental errors is also beyond the scope of this treatment. (See Sec. 6-12, Additional Topics $b$ and $c$.)

This section then considers the last of these three problems, the roundoff errors. The importance of this subject to numerical calculators cannot be overestimated. During a computation it is not an overstatement to say that consideration of errors that may arise from arithmetic operations should be uppermost in the mind of the user of the computer. The discussions of this section merely form the basis for such error considerations in a particular computation. Very often it is necessary for the user of the computer to determine experimentally the behavior of his numbers during the computations, by having the computer perform series of trial computations. These cxporimontal computations can be used to determine the correct operational procedures.

Significant Figures and Round Numbers. The accuracy of a number is measured in terms of the number of significant figures it contains. Any one of the digits $1,2,3,4,5,6,7,8,9$ is a significant figure; 0 is some-
$\dagger$ Here we consider, for example, the number $0.5000 \cdot \cdots$ to be an infinite decimal.
times but not always a significant figure. To determine when 0 is a significant figure, we distinguish three cases:

1. The zero lies to the left of all other nonzero digits of the number, e.g., as in 0.00123 . Here the zero is used simply to fix the decimal point, and therefore it is not considered to be significant. None of the three zeros in 0.00123 is significant.
2. The zero or zeros lie between nonzero digits, e.g., as in 3,002 . Here the zeros are considered to be significant.
3. The zero lies to the right of all other nonzero digits, e.g., 123,000 . In this case it cannot be determined from the number itself whether or not the zero is significant; it must be determined from the context in which it was written. Often, if the zeros in 123,000 are not significant, we would write $123 \times 10^{3}$, while on the other hand if the first zero were significant we would write $1,230 \times 10^{2}$ to indicate this.

For example, the number of significant figures in each of the following numbers is four: $1,234,9,072,5,006,0.008379,0.01024,6,080 \times 10^{3}$, $7,000 \times 10^{3}$. The leftmost significant figure in a number is called its most significant figure; in our examples the most significant figures are, respectively, $1,9,5,8,1,6$, and 7 . The least significant figure is the rightmost significant figure of a number; in our examples the least significant figures are, respectively, $4,2,6,9,4,0$, and 0 .

A number composed of $n$ significant figures is said to be correct to $n$ significant figures if its value is correct to within $1 / 2$ unit in the least significant position. For example, if 9,072 is correct to four significant figures, then it is understood that the number lies between $9,072.5$ and $9,071.5$ (that is, $9,072 \pm 0.5$ ); if 0.01024 is correct to four significant figures, then it lies between 0.010245 and 0.010235 ; if $6,080 \times 10^{3}$ is correct to four significant figures, it lies between $6,080,500$ and $6,079,500$.
Another term used to describe a number is the number of decimal places of the number, being the number of digits to the right of the decimal point. Thus 0.008379 has six decimal places, and $0.37 \times 10^{-5}$ has seven decimal places.
To be used during a computation, numbers that are infinite decimals must be converted to finite-decimal approximations. Similarly numbers that contain more significant figures than are desirable for a particular computation must be approximated by numbers of less significant figures. The process of reducing the number of significant figures of a number is called rounding. Numbers that are rounded so that they contain $n$ significant figures are formed so that they will be correct to n significant figures; they are then called round numbers. Rounding can be accomplished by means of the following rule: To round a number so that it is correct to $n$ significant figures, retain the $n$ leftmost significant figures, and discard the rest; if the discarded number is greater than $1 / 2$ unit in the least retained significant figure, then add 1 to this last retained figure; if the discarded number is less than $1 / 2$ unit in the least retained significant figure, leave the latter unchanged. The case where the discarded number
is exactly $1 / 2$ unit in the least retained significant figure is often handled thus: If the least significant figure is even, leave it unchanged; if odd, then add 1 to it. By means of this latter rule the errors due to rounding will tend to cancel, since even and odd digits occur on the average with equal frequency. Also, by leaving the rounded number in this case as an even number we increase our chances that the result of a division might be exact. As examples, the following numbers have been rounded to four significant figures:

| Number | Rounded number |
| :---: | :---: |
| $3.141 \mid 5926$ | 3.142 |
| $0.1428 \mid 57142$ | 0.1429 |
| $0.005329 \mid 601$ | 0.005330 |
| $421.2 \mid 4899$ | 421.2 |
| $58.76 \mid 5000$ | 58.76 |
| $93.29 \mid 5000$ | 93.30 |

Relative Accuracy and Absolute Accuracy. The error in a number, as compared with its true value, is stated in various ways. The absolute error of an approximate number $N^{*}$ from its true value $N$ is defined by

$$
\epsilon_{a}=\left|N^{*}-N\right|
$$

The relative error $\epsilon_{r}$ is defined by

$$
\epsilon_{r}=\frac{\left|N^{*}-N\right|}{N^{*}}=\frac{\epsilon_{a}}{N^{*}}
$$

The percentage error $\epsilon_{p}$ is defined by $\epsilon_{r} \times 100$ per cent. The relative- and percentage-error concepts have the advantage that they are independent of the unit of measurement, whereas the absolute error is expressed in terms of the unit used. For example, 3.14 is an approximate value of the infinite decimal $\pi$; the absolute error of this approximation is $|3.14-\pi|<0.002(\pi-3.14=0.00159 \cdots)$; the relative error is $|3.14-\pi| / 3.14<0.002 / 3.14<0.0006$; the percentage error $\epsilon_{p}<0.06$ per cent.

The accuracy of an approximate number can be considered from two points of view. The first, and that most often considered in using digital computers, is the concept of relative accuracy. In this case the accuracy is measured by the relative error and not the absolute error. As will be shown two paragraphs below, the number of significant figures of an approximate number is a measure of the relative error and hence of the relative accuracy of the number. T t is for this reason that significant figures are so important. To see the importance of relative error as an index of the accuracy of a number, consider the measurement of the $0.002-\mathrm{in}$. diameter of a human hair to within $1 / 100,000 \mathrm{in}$., as compared with the measurement of the 240,000 -mile distance from the earth to the moon, to within 2 miles. The relative error of the measurement of the hair is $0.00001 / 0.002=1 / 200$, while the relative error of the measurement of the distance to the moon is $2 / 240,000=1 / 120,000$, while the
absolute errors are 0.00001 and $126,720 \mathrm{in}$., respectively. Clearly the measurement of the distance to the moon is 600 times more accurate than that of the diameter of the human hair, even though the absolute error of the former is over $12 \times 10^{9}$ times that of the latter.

On the other hand the absolute accuracy of a measurement is often important from another point of view. For example, in the tolerance of machined parts it is the absolute error that counts as the measure of accuracy; hence the allowed absolute error is frequently stated explicitly by writing the desired sizes as finite decimals followed by $\pm$ and the tolerance which is the maximum allowable absolute error. In this case it is the number of decimal places that plays the important role.

The relation between the number of significant figures and the relative error inherent in an approximate number is given by the following theorem, in which $\epsilon_{r}$ is the relative error, $K$ is the most significant figure of the number, and $n$ is a positive integer:

If a given number is correct to $n$ significant figures, then

$$
\epsilon_{r} \leq \frac{1}{2 K \times 10^{n-1}}
$$

When the most significant figure is not explicitly known, we can say that the relative error $\epsilon_{r} \leq 1 /\left(2 \times 10^{n-1}\right)$. For any radix $q$ the $10^{n-1}$ in these formulas is replaced by $q^{n-1}$. If $q=2$ (binary), then the inequalities are read $\epsilon_{r} \leq 1 / 2^{n}$.

To see why this theorem is true, note that $N^{*} \geq K \times 10^{p-1}$ (for example, $521 \geq 500=5 \times 10^{2}$ ), where $p$ locates the decimal point with respect to the most significant figure $K . \dagger$ Now since $N^{*}$ represents an approximate number, correct to $n$ significant figures, i.e., with an error of $1 / 2$ unit in the last ( $n$ th) significant figure, then $\epsilon_{a} \leq 1 / 2 \times 10^{p-n}$ and

$$
\epsilon_{r} \leq \frac{1 / 2 \times 10^{p-n}}{N^{*}}=\frac{1}{2 N^{*} \times 10^{n-p}} \leq \frac{1}{2 K \times 10^{n-1}}
$$

If $K$ is not known, then to ensure that the inequality will hold for every $K$ we choose the smallest, namely, 1.

This theorem is of important practical value in using a digital computer having floating-point arithmetic operations. It enables the evaluation of the number of significant figures that must be carried to ensure that the relative error be kept below a given amount; and conversely it enables the evaluation of the relative error for a specified number of significant figures.

Significant Figures in Arithmetic Operations. Since numerical computation as performed by a digital computer reduces to addition, subtraction, multiplication, and division, the problem of retaining significance during these operations becomes fundamental. We shall here give rules of thumb commonly used by mathematicians regarding the control of
$\dagger$ For example, 3,000 would be written $3 \times 10^{3}=3 \times 10^{4-1}$, whence $p=4$. On the other hand, 0.003 would be written $3 \times 10^{-3}=3 \times 10^{-2-1}$, whence $p=-2$.
significance during arithmetic operations. In any particular situation the rules serve merely as a guide; the details of the process usually depend on the particular numbers and errors involved and hence must often be carefully examined. In many situations it is just as bad to overestimate an error resulting from a computation as it is to underestimate one.

Consider addition first. The rule of thumb is that in adding two (positive) numbers there is usually no loss of significant figures; in fact the result sometimes has one more significant figure than either of the operands.

For example, suppose that $52,761.2$ and $71,436.7$ were rounded to 52,761 and 71,437 and added:

| Rounded | Unrounded |
| ---: | ---: |
| 52,761 | $52,761.2$ |
| $+\frac{71,437}{124,198}$ | $+\frac{71,436.7}{124,197.9}$ |

The rounded numbers are both correct to five significant figures, and the result is correct to six, as is seen on comparison with the addition of the unrounded numbers. Here there was no loss of significance, because the rounding errors canceled out, and the added significant figure resulted from the carry. However, consider $12,761.5$ and $11,435.5$ rounded to 12,762 and 11,436 and added:

| Rounded | Unrounded |
| ---: | ---: |
| 12,762 | $12,761.5$ |
| $+\underline{11,436}$ | $+\underline{11,435.5}$ |
| 24,198 | $24,197.0$ |

Here the result is correct only to four significant figures since, as can be seen from the unrounded addition, the rightmost 7 is off by 1 unit. This is of course an exception to our rule, chosen so that the errors in the least significant figures of the operands were maximum and were added together. It is clear that, if one always includes one more significant figure than is necessary, he will be more sure of having at least the required significance in his result.

Subtraction, however, is another story. The rule of thumb is simply a warning that complete loss of significance is possible and that each case must be examined on its own merits. For example, suppose that we are forming the difference of $52,763.5$ and $52,752.5$ as rounded to 52,764 and 52,762 :

| Rounded | Unrounded |
| ---: | ---: |
| 52,764 | $52,763.5$ |
| $-\underline{52,762}$ | $-\underline{52,762.5}$ |
| 00,002 |  |

Although the subtrahend and the minuend were correct to five significant
figures, the difference has no significant figures; i.e., the 2 is off by a full unit. More generally, there is not a complete loss of significance, but very frequently severe loss of significance occurs. There are two remedies that can be tried. The first is to use many more significant figures in the subtrahend and minuend to begin with and hope that enough significance will result for the remainder. The other is to try to transform the expression to something else and thereby avoid the subtraction altogether. For example, if one had to evaluate $1-\cos x$ for small $x$, it might be wiser to write $1-\cos x=2 \sin ^{2}(x / 2)$ and evaluate the latter expression.

For multiplication the rule of thumb is that up to two significant figures can be lost, though not necessarily. This same rule applies to division. Consider, for example, the product of 811.2 and 112.5, each rounded to three significant figures:

| Rounded | Unrounded |
| :---: | :---: |
| 811 | 811.2 |
| $\underline{112}$ | $\underline{112.5}$ |
| $\overline{1622}$ | 16560 |
| 811 | 8112 |
| $\underline{811}$ | $\underline{9112}$ |
| 90832 |  |

The third figure of the product is off by 4 units and therefore is not significant; the second figure from the left is, however, only off by 0.4 unit and therefore is significant. The product is thus correct to two significant figures, while the multiplicand and multiplier were each correct to three.

As an example of the loss of a significant figure during division, consider $1,761.5$ and $1,763.4$, rounded to 1,762 and 1,763 :

| Rounded | Unrounded |
| ---: | ---: |
| 1.0005 |  |
| $1,762$$1,763.0000$ <br> $\frac{1,762}{1.0000}$ | $17,6 1 5 \longdiv { 1 7 , 6 3 4 . 0 0 0 }$ |

Here the rounded dividend and divisor are correct to four significant figures, but the quotient is correct only to three.

One further rule of thumb might be helpful. In digital computers, where it is in general no more difficult to handle numbers with many significant figures, keep as many significant figures as possible during the computations, and beware of loss of significance through subtraction.
Pitfalls. A person using an electronic computer always worries about whether the results he gets are or are not accurate. For usually only the final results of a computation are read out from the computer's memory, and intermediate results are neither retained nor observed. The results
of computer programs are often checked by comparing a few values with some previously hand-computed values. However, the fact that these few isolated results check is no guarantee that all the results computed by the program will be equally correct. Rarely is every difficulty fully anticipated. Automatic programming routines aggravate this situation, increasing the possibility of overlooking pitfalls. Hence, when writing his program the programmer must plan against the loss of too many significant figures in the computation, as well as choose the computational method that can best result in the necessary accuracy. During the running of the program on the computer the programmer must be acutely aware of such pitfalls as overflows, loss of significance, difficulties arising in intermediate forms, and other, unanticipated, singular situations.

For example, consider a pitfall that occurs in evaluating $\sqrt{x}$. If $x=0.00003259$, where $x$ is good to seven decimal places and uncertain in the last (i.e., the 9 ), then to eight decimal places we get

$$
\begin{aligned}
\sqrt{0.00003258} & =0.00570789 \\
\sqrt{0.00003259} & =0.00570877 \\
\sqrt{0.00003260} & =0.00570964
\end{aligned}
$$

Hence $\sqrt{x}$ is good only to five places, is uncertain in the sixth place, and is erroneous in the last two places. However, the computer will carry these last two places, and the error may be magnified in subsequent calculations.

Another example occurs in computing, say, sin 314,159.3. For if we reduce the angle to one whose magnitude is less than $\pi / 2$, we find

$$
\sin 314,159.3=\sin (314,159.3-314,159.27)=\sin 0.03=0.03
$$

If the last figure of the original angle were 2 instead of 3 , we would find $\sin 314,159.2=-0.07$. If 4 , we would find $\sin 314,159.4=+0.13$. Hence, even though the original angle is known to within seven significant figures with an uncertainty of 1 in the last figure, the result is not good to within one decimal place.

The following quotation $\dagger$ summarizes the general attitude that should be maintained in performing numerical computations on a digital computer:

Despite the availability of high speed computers, a successful computation depends on a judicious combination of mathematical analysis and numerical experimentation. In the actual programming of his problem, the numerical analyst should not use subroutines and automatie endes blindly; but should ascertain that the logical decisions made in them will be consistent with the required round-off error and tolerance limits. The possibility of pitfalls will always be present in spite of all efforts to avoid them. It is therefore important that the numerical analyst interpret his answers according to their true meaning. Although the tools of the numerical analysis are all based on rigorous mathematical theorems the application of these theorems requires discretion. In carrying

[^4]out a numerical computation program it is often necessary to use experimental techniques to establish the correct operational procedures.

## EXERCISES

(a) Tell how many significant figures are in each of the following numbers, and round each to be correct to five significant figures:

| 2.7182818 | 1.11001110 (binary) |
| :--- | :--- |
| 7.3890568 | $.00110010 \times 2^{-3}$ (binary) |
| 0.3183099 | $101011.00($ binary $)$ |
| 0.3678794 | $0011001100 \times 2^{3}$ (binary) |
| $484,813,681,110 \times 10^{-6}$ | 1010101010 (binary) |
| $154.1500 \times 10^{3}$ | 11.001100 (binary) |

(b) Calculate the maximum relative error of each of the above numbers, rounded to three significant figures (or bits in the case of binary numbers).
(c) If all the numbers in a computation were kept to five significant figures, what is a bound on the relative error of each number? If these numbers were binary numbers, what is the bound on the relative error?
(d) If it is desired that all numbers involved in a computation have a relative error of less than 1600 , how many significant figures should each number contain?
(e) In a computation involving only binary numbers, if it is desired that all numbers should have a relative error of less than $1 / 600$, how many significant bits should each number contain?

## 6-12. Additional Topics

a. Finite Differences for Polynomials. Consider a polynomial whose values have been computed at equal intervals of $x_{i+1}-x_{i}=h$, that is, $y\left(x_{0}\right), y\left(x_{0}+h\right), y\left(x_{0}+2 h\right)$, $y\left(x_{0}+3 h\right), \ldots$ The differences of successive values of $y$, namely, $y\left[x_{0}+(i+1) h\right]$ $-y\left(x_{0}+h\right)$, are called the first differences of the polynomial. The differences of successive first differences are called second differences, and so forth. An interesting result (see the references below) is that the nth differences of a polynomial of the nth degree are constant when the values of the independent variable are taken at equal intervals. Thus the accuracy of computations based on a polynomial approximation can be checked. For example, consider $y=2 x^{2}-x+1$, as tabulated in Table 6-2. The

Table 6-2. Differences for $y=2 x^{2}-x+1$

| $x$ | $y$ | First differences <br> $\Delta_{1} y$ | Second differences <br> $\Delta_{2} y$ |
| :---: | :---: | :---: | :---: |
| 0 | 1 | 1 |  |
| 1 | 2 | 5 | 4 |
| 2 | 7 | 9 | 4 |
| 3 | 16 | 13 | 4 |
| 4 | 29 | 17 | 4 |
| 5 | 46 |  |  |

constant second differences are 4. Suppose that an error was made in computation and $y(3)$ was evaluated as 10 ; how could this be detected? The study of finite differences has many interesting and important aspects (see the references below, and also C. Jordan, "Calculus of Finite Differences," Chelsea Publishing Company, New York, 1947).
b. General Formula for Measurement Errors. Suppose that $N=f\left(x_{1}, x_{2}, \ldots, x_{n}\right)$ denotes any function of $n$ independent variables $x_{1}, x_{2}, \ldots, x_{n}$ that are subject to the experimental errors $\Delta x_{1}, \Delta x_{2}, \ldots, \Delta x_{n}$. Then a formula that gives the resulting error in the function $N$ is given by

$$
\Delta N=\frac{\partial N}{\partial x_{1}} \Delta x_{1}+\frac{\partial N}{\partial x_{2}} \Delta x_{2}+\cdots+\frac{\partial N}{\partial x_{3}} \Delta x_{3}
$$

(See, for example, the references below.) Suppose that the error of the independent variables is not actually known, but it is known that the probability distribution of the errors is normal (Gaussian). Then we can define the probable error of a single measurement as a value such that half the errors of a series of measurements will be greater, the other half less. If $R, r_{1}, r_{2}, \ldots, r_{n}$ are the probable errors, respectively, of $N, x_{1}, x_{2}, \ldots, x_{n}$, then

$$
R=\sqrt{\left(\frac{\partial N}{\partial x_{1}}\right)^{2} r_{1}^{2}+\left(\frac{\partial N}{\partial x_{2}}\right)^{2} r_{2}^{2}+\cdots+\left(\frac{\partial N}{\partial x_{n}}\right)^{2} r_{n}^{2}}
$$

For further discussions see Scarborough (see the references below), chaps. XIV-XV, and E. Frank, "Electrical Measurement Analysis," chaps. 5-7, McGraw-Hill Book Company, Inc., New York, 1959.
c. Error Formulas for Differentiation and Integration. Milne ("Numerical Calculus," pp. 108-114; see the references below) gives a method for developing the error formula for any differentiation-integration method that may be developed by the method of undetermined coefficients. If $Q(f)$ is the integration or differentiation to be performed on the function $f$ and $P(f)$ is the formula developed by the method of undetermined coefficients for its approximation, then the error $R(f)=Q(f)-P(f)$. $R(f)$ is said to be of degree $n$ when $R\left(x^{m}\right)=0$ for $m \leq n$, but $R\left(x^{n+1}\right) \neq 0$. Also let $(\overline{x-s})^{n}$ be defined by $(\overline{x-s})^{n}=(x-s)^{n}$ if $x>s$ and $\left.\overline{(x-s}\right)^{n}=0$ if $x<s$. In terms of this definition let

$$
G(s)=\frac{1}{n!} R_{x}\left[(\overline{x-s})^{n}\right]
$$

in which $R_{x}\left[(\overline{x-s})^{n}\right]$ means $R\left[(\overline{x-s})^{n}\right]$ regarded as a function of the variable $x$. Then it can be shown that

$$
R(f)=\int_{-\infty}^{\infty} f^{(n+1)}(s) G(s) d s
$$

where $f^{(n+1)}$ is the $(n+1)$ st derivative of $f$ (see Milne for an example). Using this technique, derive error formulas for the integration and differentiation formulas of Secs. 6-7 to 6-9 and their exercises.
d. Runge-Kutta Method. There are formulas for the integration of differential equations other than those which can be derived by the method of undetermined coefficients. One well-known example is the so-called "Runge-Kutta method." This has the advantage that the error is of the order of $h^{5}$ and no special methods are needed to start the solution. Consider $y^{\prime}=f(x, y)$; then the increment for advancing
the dependent variable is given by

$$
\begin{aligned}
\Delta y & =1 / 6\left(k_{1}+2 k_{2}+2 k_{3}+k_{4}\right) \\
k_{1} & =h f\left(x_{0}, y_{0}\right) \\
k_{2} & =h f\left(x_{0}+12 h, y_{0}+1 / 2 k_{1}\right) \\
k_{3} & =h f\left(x_{0}+1 / 2 h, y_{0}+1 / 2 k_{2}\right) \\
k_{4} & =h f\left(x_{0}+h, y_{0}+k_{3}\right)
\end{aligned}
$$

Then $x_{1}=x_{0}+h$, and $y_{1}=y_{0}+\Delta y$, and the process is continued. (For further details see the references below.)
e. Best Fit. Cecil Hastings's book "Approximations for Digital Computers" (see the references below) is an elementary discussion of the method of best-fit approximations written in a quite unique and entertaining style. It also includes an interesting source of best-fit approximations.
f. Monte Carlo Method and References. Computations that involve successive generation of random numbers are often called Monte Carlo calculations. (For definition of random numbers see W. Feller, "Probability Theory and Its Applications," John Wiley \& Sons, Inc., New York, 1950.) Monte Carlo computations usually are associated with computer simulations of real processes, such as military combat, growth of cancer cells, business transactions, mortality studies, etc., where some phase of the simulation involves a probability distribution. For example, if a missile were 80 per cent effective against a certain type of target, then in simulating each missile a random number between 0 and 9 would be chosen; only if it lay between 0 and 7 would a kill be recorded. Similarly the size of a cancer growth is very sensitive to the initial rate of mitosis of the generating cells, which is randomly determined. Monte Carlo processes have also been used in evaluating integrals. To evaluate $\int_{0}^{1} f(x) d x$ on the interval $0 \leq x \leq 1$, we choose $N$ arguments $x$ at random and evaluate $f(x)$ for each; it can be shown that, as $N$ becomes larger, the average of all the $f(x)$ so determined converges to $\int_{0}^{1} f(x) d x$.

The generation of random numbers with a computer is simple. Given a number $R_{i}$, find a new random number $R_{i+1}$ as the minor product of $\rho R_{i}$, where $\rho$ is the largest power of 5 that can fit into a computer word. Start with $R_{0}=\rho$. For $\rho=5^{17}$ the sequence has a period of about $10^{12}$.

## References

Curtiss, J. H.: "Monte Carlo" Methods for the Iteration of Linear Operators, J. Math. and Phys., vol. 32, pp. 209-232, 1953.
Davis, P. J., and P. Rabinowitz: Some Monte Carlo Experiments in Computing Multiple Integrals, Mathematical Tables and Other Aids to Computations, vol. 10, pp. 1-8, 206, 1954.
Kahn, H.: Modification of the Monte Carlo Method, Proc. Seminar Sci. Computations, pp. 20-27, International Business Machines Corporation, New York, 1949.
Metropolis, N., and S. Ulan: The Monte Carlo Method, J. Am. Statist. Assoc., vol. 44, pp. 335-341, 206, 290, 1949.
Meyer, H. A. (ed.): "Symposium on Monte Carlo Methods, University of Florida. 1954," John Wiley \& Sons, Inc., New York, 1956.
Todd, J., et al.: Monte Carlo Method, NBS Appl. Math. Ser., vol. 12, 1951.

## g. Texts on Numerical Analysis

Alt, Franz L.: "Electronic Digital Computers," Academic Press, Inc., New York, 1958.

Engineering Research Associates, Inc., Staff of: "High-speed Computing Devices," McGraw-Hill Book Company, Inc., New York, 1950.
Grabbe, E. M., S. Ramo, and D. E. Wooldridge: "Handbook of Automation, Computation, and Control," vol. 1, John Wiley \& Sons, Inc., New York, 1958.
Hastings, Cecil, Jr.: "Approximations for Digital Computers," Princeton University Press, Princeton, N.J., 1955.
Hildebrand, F. B.: "Introduction to Numerical Analysis," McGraw-Hill Book Company, Inc., New York, 1956.
Householder, A. S.: "Principles of Numerical Analysis," McGraw-Hill Book Company, Inc., New York, 1953.
Lanczos, C.: "Applied Analysis," Prentice-Hall, Inc., Englewood Cliffs, N.J., 1956.
Levy, C., and B. A. Baggott: "Numerical Solutions of Differential Equations," Dover Publications, New York, 1950.
Milne, W. E.: "Numerical Calculus," Princeton University Press, Princeton, N.J., 1949.
: "Numerical Solution of Differential Equations," John Wiley \& Sons, Inc., New York, 1953.
Nielsen, Kaj L.: "Methods in Numerical Analysis," The Macmillan Company, New York, 1956.
Scarborough, J. B.: "Numerical Mathematical Analysis," 2d ed., The Johns Hopkins Press, Baltimore, 1950.

## GHAPTER 7

## SEARCHING, SORTING, ORDERING, AND CODIFYING

## 7-1. Introduction

Ingredients. A great proportion of computer and control applications involve searching, sorting, ordering, and codifying. The generalpurpose computer considered in Part 1 is not by itself best suited for these nonarithmetic operations. To understand what special systemsdesign features are needed for such operations, we must first study the operations themselves.

The ingredients of searching are items and characteristics and associations of characteristics with the items. An item is a package of information; the characteristics associated with this item are attributes that are related to the item. Problems of searching all involve locating an item, or items, associated with a given set of characteristics. For example, each article reference included in a bibliography is an item; the subjects relating to the contents of the article are the characteristics. A bill of sale is an item; the name and address of the buyer may be considered as the characteristics. A research grant is an item; the name of the principal investigator, the amount of the grant, the subject under investigation, the name of the school or organization receiving the grant, etc., are all characteristics. The inventories of particular replacement parts are the items; the serial numbers, costs, acquisition record, etc., are the characteristics, and so forth.

Searching, Sorting, Ordering, and Codifying. Given a set of characteristics, the process of obtaining every item associated with all the given characteristics is called searching. In a bibliographical list of research reports one might search for all articles concerning the application of nuclear theory. The words application, nuclear, and theory are the characteristics, and the search should result in a collection of references, each concerned with the application of nuclear theory. As a specific illustration, consider the item list of article references and the characteristic list of subjects of a sample bibliography given in Fig. 7-1. We have given each item a boldface number and each characteristic an italicized number. The item-characteristic associations are given in Table 7-1, where a unit indicates that the characteristic of the row of the unit is associated with the item of its column. Consider the rows associated with the given characteristics. Form a new row that has a unit corresponding only to those (column) positions where all the given characteristic rows also have units. (This is called logically multiplying these rows; cf. Sec. 4-5.)

## Part I. The Article List (Bibliography Proper)

Article
No.
1.1 Abrahams, A. P.
Autoradiographic
determination of
radioactivity in rocks.
Nucleonics 15:85-86
Mar 1957
1.2 Aravindakshan, C. A simple arrangement for obtaining optical transforms of crystal structures. J. Sci.
Instr. 34:250 Jn 1957

Article
No.
2.1 Nicholls, J. Alphascintillation monitor for hands and clothing. Nucleonics 15: 80, 81, 83, 84 Mar 1957
2.2 Pope, M. I. An automatically recording vacuum balance. J. Sci. Instr. 34:229232 Jn 1957
2.3 Powell, D. A. An apparatus giving thermogravimetric and differential thermal curves simultaneously from one sample. J. Sci. Instr. 34:225-227 Jn 1957
2.4 Seidle, F. G. P., et al.

Modification of the Brookhaven fast chopper. Nuclear Instruments 1:92-93 Mar 1957

Article
No.
3.1 Senior, D. A. The Kerr cell, a high speed electro-shutter, Pt. II. Instr. Pract. 11:471-476 May 1957
3.2 Smith, B. O., and Grimshaw, A. G. A pneumatic level indicator. Instr. Pract. 11:469-470 May 1957
3.3 Stockendal, R., and Bergkvist, K. E. Evaporation device for beta-spectrometer samples. Nuclear Instruments 1:53-54 Jan 1957
1.4 NBS Circular 850. Bibliography on ignition and spark ignition systems. Nov 11956
very fast pulse-height analyzer with independent uptake, sorting, and storage of information. Nuclear Instruments 1:75-79 Mar 1957
3.4 Tove, Per-Arne. Electronic time analyzer applied to the measurement of the half-lives of metastable nuclear states. Nuclear Instruments 1:95-100 Mar 1957

Part II. The Word List (Code Book and Thesaurus)

Word No.

| adaptability | 3.2 | evaluation | 6.1 | Netherlands | 4.2 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| analysis | 4.1 | gas | 2.2 | nuclear | 4.3 |
| application | 5.1 | heat | 2.3 | plan | 6.2 |
| concent | 6.2 | hysteresis | 1.1 | theory | $4.1 /$ |
| counting | 2.1 | implementation | 5.3 | thermal | 2.3 |
| design | 7.1 | instrumentation | 5.3 | use | 5.1 |
| differentiation | B.1 | mass | 1.2 | versatility | S.2 |
| England | 5.2 |  |  |  |  |

Fig. 7-1. Illustrative bibliography example.

Table 7-1. Association of Items with Characteristics

| Characteristic | Item |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1.1 | 1.2 | 1.3 | 1.4 | 2.1 | 2.2 | 2.3 | 2.4 | 3.1 | 3.2 | 3.3 | 3.4 |
| 1.1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1.2 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 2.1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 2.2 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 2.8 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 3.1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
| 3.2 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |
| 4.1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |
| 4.2 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 4.3 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 4.4 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 5.1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |
| 5.2 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 |
| 5.3 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 |
| 6.1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 |
| 6.2 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |
| 7.1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 |

The units of the resulting row correspond to the columns of the desired items. For example, given application (5.1), nuclear (4.3), theory (4.4), we logically multiply rows,
obtaining

| 5.1 | 0000 | 0111 | 0101 |
| :--- | :--- | :--- | :--- |
| 4.9 | 0000 | 1001 | 0011 |
| 4.4 | 0010 | 0001 | 0011 |
|  | 0000 | 0001 | 0001 |

with units in columns 3.4 and 2.4 corresponding to items by Tove and Seidle. However, it is rarely feasible to display a matrix such as in Table 7-1; we have used it simply as an illustration to aid the visualization of the searching methods to be described.
It is difficult to discuss searching without using the terms sorting, ordering, and codifying. It is often helpful for temporary use to substitute a symbolic abbreviation to represent an item or characteristic. For example, the use of boldface and italicized numbers in our illustrative bibliography made the table of associations easier to display. A code is a list of such abbreviations; the making of a code is codifying. $\dagger$ Fre-
$\dagger$ We use the term codifying here in preference to coding to distinguish the process being discussed in this chapter from the programming of a computer.
quently the code is given in the form of a "dictionary," or "thesaurus." In our illustrative bibliography the code for the item (article) list is presented in dictionary form, and the code numbers are listed in numerical order. The characteristic (word) list is in thesaurus form, where the word list is in alphabetical order; here synonyms are given the same code number. Codes are used in searching as follows: First the thesaurus of characteristics is compared with the list of desired characteristics, and the corresponding code numbers are found; next the search is made to find the code numbers of the resulting items; finally the actual items are determined from the dictionary. In computer searching the use of codes in this manner is almost always indicated. Further discussion of codes appears in Sec. 7-7.

By ordering a list is meant the process of arranging the list according to some linear ordering system, such as alphabetically or numerically, so that, if element $Q$ of the list is greater than element $P$, then element $Q$ lies further from the beginning of the list than $P$. By sorting a list is meant the process of separating the list into partitions, i.e., mutually exclusive classes. In sorting items the equivalence relation by means of which the classes, or partitions, are defined is often given in terms of associated characteristics. For example, research grants may be sorted according to the university that received the grant, etc. Searching may be defined as the process of sorting a list of items into two categories, those items which are associated at least with all of certain given characteristics, and those which are not. Frequently the classes, or partitions, of a sort are ordered. For example, collections of research grants sorted by university can be ordered alphabetically by the university's names.

Searching and sorting are both closely associated with ordering. For instance, to sort research grants by university, all that need be done is to order the grants alphabetically by university, and then the result will present all grants from the same university juxtaposed in the list; hence the grants will automatically be sorted as the partitions of the sort are ordered.

Summarizing, to sort a list of elements, some equivalence relation must be defined that tells when two elements are in the same equivalence class or not. To order a list linearly, an ordering relation must be defined. Sorting can often be accomplished by means of ordering, when the ordering relation is so chosen that the identities of some type of characteristic represent the desired equivalence relation. As we shall see in the next section, searching is often carried out by sorting ordered lists.

## 7-2. Methods of Searching

The First Two Methods. For concreteness we assume in what follows that the items and characteristics are listed on magnetic tape. Based on this assumption, we shall describe three methods for searching with a computer, using our illustrative bibliography as an example. Each of the searching techniques is, as will be shown, intimately associated with the
listing arrangement of items and characteristics on the magnetic tape; this is because the associations are indicated by means of the item-characteristic arrangement on the tape.

First, consider the case where all characteristics associated with each item of the item list appear under that item (see Figs. 7-2a and 7-3a). Given a set of desired characteristics, the computer reads an item and its associated characteristics from the magnetic tape into the high-speed memory and compares to determine whether or not the given characteristics are included in the characteristics associated with the item; if


Fig. 7-2. Methods of listing on magnetic tape.
so, the item would be suitably recorded. This process is accomplished for each item and its associated characteristics on the tape, one item at a time successively. In this way, after a single pass through the tape, every item associated with all the given characteristics is retrieved. The advantage of this system is that the items need not be ordered on the tape, since every item is searched. The disadvantage is that every section of the magnetic tape must be searched in detail, consuming much time in the computer.

Second, consider the case where the characteristic list is recorded on the tape and under each characteristic is a list of items associated with that characteristic (see Figs. $7-2 b$ and $7-3 b$ ). The characteristics must appear in some order on the tape-e.g., alphabetically or numerically.

Given a set of characteristics, the computer would first order them and then would go through the magnetic tape looking for the first, or smallest, characteristic; having found this, it would read the characteristic and its associated items into the high-speed memory and record all items associated with it. Continuing the search on the tape, the computer would look for the second, or next smallest, characteristic. Having found that, the computer would see which items associated with the second characteristic were also associated with the first and record them. Then the computer would look for the third characteristic and record only those items associated with it which were also associated with both the first


Fig. 7-3. Sample segments in the lists for each of three methods.
two characteristics, and so on. The computer need not examine the whole tape in detail, but only those sections associated with each of the given characteristics; however, both the list of characteristics and the set of given characteristics must be preordered.

Note that, in terms of our association matrix of Table 7-1, the first and second methods described above correspond, resnectively, to renording the successive columns of the matrix and the successive rows of the matrix on the magnetic tape.

The Tabledex Method. Finally consider a third method for recording the items and characteristics on the magnetic tape. The method involves the recording of successive tables on the magnetic tape and is therefore called the Tabledex method. There is one table for each characteristic. A table is formed as follows: All items associated with this characteristic
are listed in the table; adjacent to each item are sublisted all those characteristics greater in order than the characteristic of the table which are associated with that item (see Figs. 7-2c and 7-3c). For example, in Fig. 7-3c, consider the Tabledex table headed 4.4. Observe from Table 7-1 that the characteristic 4.4 is associated with items $1.3,2.4,3.3$, and 3.4. Now observe that item 2.4 is associated with 2.1, 4.2, 4.3, 4.4, 5.1, 5.3 , and 6.2 , but only 5.1, 5.3, and 6.2 appear in the sublist, for only these are greater than 4.4, the number of the table (see Fig. 7-3c). Similarly the sublists for $3.4,3.3$, and 1.3 were formed for this table. (Note that these sublists are ordered in the table on their first characteristics.)

The tables are listed in the order of their associated characteristic, and the items and the sublist of characteristics for each item are also listed in the proper order. Given a set of characteristics, the computer first puts them in the proper order, then searches the tape for the table associated with the lowest ordered characteristic, reading this into the high-speed memory, and finally searches the sublists, recording those items associated with a sublist containing all the other given characteristics. For example, if the three given characteristics are 7.1, 5.1, and 5.2 , these would first be written in order as $5.1,5.2$, and 7.1 ; then the table for 5.1 would be searched; and finally, if a sublist were found to contain both 5.2 and 7.1 , its item would be recorded. As can be seen in Fig. $7-3 c$, the items whose sublists contained 5.2 and 7.1 are 2.3, 2.2, and 3.2 ; hence these are all items each of which is associated with all the given characteristics.

Using the Tabledex method, only the single section of the tape that contains the appropriate table need be searched in detail.

Population vs. Substantive Ordering of the Lists. The reader may have wondered how we arrived at the code number for the characteristics and items given in Fig. 7-1. The choice of numbering is related to the concepts of population-based ordering and substantive-based ordering. Substantive ordering refers to an ordering arrangement based on some attribute of the individual terms in the list. Thus an alphabetical ordering of items by author is a substantive-based ordering, an ordering of characteristics by research-field classification is substantive-based, etc. In Fig. 7-1 the item-list code numbers were assigned substantively to the articles, in alphabetical order; in addition the number of an item locates its column and line, e.g., item 2.3 is in column 2, line 3.

Population-based ordering is quite different: it refers to an ordering based on the quantities of items or characteristics in the associations. For example, population-based code numbers for each characteristic might be assigned as the number of items associated with it. To distinguish among characteristics that have the same number of associated items, a decimal number can be appended. The characteristics of our example are numbered in this way. Thus in Fig. $7-1$ it is seen that analysis, Netherlands, nuclear, and theory each have four associated items; hence their population-based numbers are 4.1, 4.2, 4.3, and 4.4, respectively. Ordering the characteristics by population-based code numbers can save
searching time. In the second method given above, it is most efficient to begin searching in the section of the smallest given characteristic when population-based numbers are used. (Why?) Similarly, in the Tabledex method when population-based numbers are used, tables that include many items have short sublists, and tables that have long sublists include few items. (Why?)

Programming a Computer for Searching. The writing of codes for the techniques discussed in this section is in general reasonably straightforward. However, consideration of some factors concerning the use of magnetic tapes might prove helpful.


Fig. 7-4. Flow chart to record common numbers on two ordered lists.
Recall from Chap. 4 that magnetic-tape read-in, read-out, and tapemoving instructions usually specify the number of blocks to be read in, read out, or moved. Hence only multiples of blocks can be handled. Therefore, in recording a list on a section of magnetic tape the list is usually padded at the end with words of all zeros so that the entire list will make up an integral number of blocks. The first word of the first block of the list is often used as a labeling word: it contains information about the contents of the list, and, most important for our discussion, it tells how many blocks long the list is. The magnetic tape will then consist of a sequence of such lists, each labeled with the number of blocks in its length as the first word of the list.

There are two advantages to labeling the lists: (1) The computer will at first observe only one label word of a list. If this list is not the one
desired, the computer can then move the magnetic tape by the number of blocks indicated in the label, past this list to the next list; the label of the next list will be observed, and so forth. In this way the computer may jump over parts of the magnetic tape not of interest during the particular search. (2) When a list is of interest, then each word of the list must be examined; this is usually accomplished by some kind of iteration or loop. The tally of this loop can be set according to the length of the list to be examined, as given in the label word. For example, in the second method for searching given above, each characteristic is followed by a list of its associated items. Hence the first, or label, word of each item list will denote the characteristic and its length, say in the $\alpha$ and $\beta$ address positions for a two-address system. Then the computer will look for the first of the given (ordered) characteristics by jumping over lists until the appropriate list label is obtained.

When the appropriate section of tape is found, the problem basically reduces to the comparison of two ordered lists for common members. Suppose that we have two ordered lists of numbers, with $K$ numbers in the first list, indexed by $k(k=1,2, \ldots, K)$, and $J$ numbers in the second list, indexed by $j(j=1,2, \ldots, J)$. A flow diagram of a code to record every number that appears in both lists is shown in Fig. 7-4. If the number in the $j$ list is greater than the number being compared with it in the $k$ list, then the code moves along the $k$ list until a common number is obtained, or until a number in the $k$ list is reached that is greater than the one in the $j$ list. Then the code moves along the $j$ list in a similar way, until the $k$ number is equaled or exceeded. This process depends basically on the fact that the $j$ and $k$ lists are ordered.

## EXERCISES

(a) By means of the information given in Table 7-1 complete the lists and tables partially shown in Fig. 7-3a and $b$.
(b) Using the information given in Fig. 7-1 and Table 7-1, compile Tabledex tables using as the characteristics the words themselves, in alphabetical order.
(c) Using each of the three lists completed in (a) and (b), search for all items associated with each of the following sets of given characteristics: evaluation, concept, design; and differentiation, application, England, gas.
(d) Assign population-based numbers to the items of Fig. 7-1, and compile the lists of the first searching method from the information of Table 7-1.
(e) Draw a flow chart for each of the searching methods given in this section.

## 7-3. Manual Searching Methods

For each of the three searching methods given above there is an analogous manual searching method. Besides being of considerable importance in themselves, these manual methods can serve as a concrete visualization of the more abstract operations that take place in a computer.

Marginal-punch Cards. The first method given above corresponds to the use of marginal-punch cards, where each card represents an item and a
marginal position on a card represents a characteristic. Different cards represent different items, but the same respective marginal position represents the same characteristic on each card. The association of characteristics with an item is made on its card by punching a notch in the mar-


Fig. 7-5. Marginal-punch cards. ginal position of those characteristics which correspond to the particular item of the card. One type of card commonly used has holes corresponding to each marginal position. To sort a deck of the cards according to a particular characteristic, a needle is placed through the holes in the cards corresponding to this characteristic; then, when the needle is lifted, those cards which have been punched in this position will fall, the other cards will be lifted by the needle, and the deck is thereby separated into two parts (see Fig. 7-5). A search is performed by repeating this process successively on the dropped cards (which have the desired characteristic) until those cards punched in at least all the desired characteristic positions are obtained. Note that the initial deck of cards need not be kept in any particular order whatsoever.

Peek-a-boo Cards. The second method given above corresponds to the use of the so-called "Peek-a-boo cards." Here each card corresponds to a characteristic; the surface of a card is laid off in an


Fig. 7-6. Peek-a-boo cards.
$X, Y$ coordinate system with each particular pair of coordinates representing an item. Different cards represent different characteristics, but the same respective $X, Y$ coordinates represent the same item on each card. The association of characteristics with items is made by punching a hole at the $X, Y$ coordinate positions that represent each item associated with the characteristic of the card. A search is made by
first selecting from a deck of cards those cards which correspond to the given desired characteristics. The selected cards are placed together to form a pack; if an item is associated with all the given characteristics, then there will be a hole passing completely through the pack at the coordinate point corresponding to that item (see Fig. 7-6). Note that the initial deck of cards must be kept in some definite order so that the cards can be easily selected for a particular search, and note that the pack of selected cards must be carefully aligned.

Programming a Computer to Generate a Manual Tabledex Collection. The third method given above corresponds to the manual use of the Tabledex tables themselves. Here the tables are printed in conventional bound-book form. The use of a collection of tables is directly analogous to their use on magnetic tapes. For example, suppose that we have a collection of tables corresponding to our bibliography illustrated above and that we desire to find all articles on the application of nuclear theory. From the alphabetical word list the code numbers are found: application 5.1, nuclear 4.3, theory 4.4. These are placed in numerical order: 4.3, 4.4, and 5.1. One then turns in the collection of tables to Table 4.3, which would appear as shown:

Table 4.9

|  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| $\checkmark$ | $\mathbf{2 . 4}$ | 4.4 | 5.1 | 5.3 |
| $\checkmark$ | 6.2 |  |  |  |
|  | $\mathbf{3 . 4}$ | 4.4 | 5.1 |  |
|  | $\mathbf{3 . 3}$ | 4.4 | 5.3 | 6.1 |
|  | $\mathbf{2 . 1}$ | 6.2 | 7.1 |  |
|  |  |  |  |  |

The first two rows of Table 4.3 contain both 4.4 and 5.1 and are checked. Hence articles 2.4 and 3.4 by Seidle and by Tove are associated with the given words. The advantage of the manual use of Tabledex lies in its being in bound-book form, without the necessity for the manipulation of cards.

A computer can be programmed to automatically compile and print a Tabledex collection for manual use. The method used to compile the Tabledex collection is of particular interest as an application of the techniques of this chapter. First the characteristics of each articlecharacteristic association are ordered in themselves. For example, we would have the article-characteristic association: item 2.4, characteristics 2.1, 4.2, 4.3, 4.4, 5.1, 5.3, and 6.2 (see Table 7-1). Second, from each such article-characteristic association, a list of all possible rows of the tables can be generated. For example, from the associations just illustrated the following seven rows can be generated:

| $\mathbf{2 . 4}$ | 2.1 | 4.2 | 4.3 | 4.4 | 5.1 | 5.3 | 6.2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{2 . 4}$ | 4.2 | 4.3 | 4.4 | 5.1 | 5.3 | 6.2 |  |
| $\mathbf{2 . 4}$ | 4.3 | 4.4 | 5.1 | 5.3 | 6.2 |  |  |
| $\mathbf{2 . 4}$ | 4.4 | 5.1 | 5.3 | 6.2 |  |  |  |
| $\mathbf{2 . 4}$ | 5.1 | 5.3 | 6.2 |  |  |  |  |
| $\mathbf{2 . 4}$ | 5.3 | 6.2 |  |  |  |  |  |
| $\mathbf{2 . 4}$ | 6.2 |  |  |  |  |  |  |

Third, the list of all such rows generated from every article-characteristic association is then sorted by ordering on the first (leftmost) characteristic code number. After the ordering, all rows with the same first characteristic appear adjacent. For example, the following rows appear adjacent:

| 2.4 | 4.3 | 4.4 | 5.1 | 5.3 | 6.2 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 3.4 | 4.3 | 4.4 | 5.1 |  |  |
| 3.3 | 4.3 | 4.4 | 5.3 | 6.1 |  |
| 2.1 | 4.3 | 6.2 | 7.1 |  |  |

When the number 4.3 has been removed, the adjacent rows are just Table 4.3. Thus from this ordered list of rows the tables can be printed out by the computer.

## 7-4. Searching with Relaxed Conditions

The Problem of Relaxed Conditions. It frequently happens that no item is associated with all the characteristics given. In such a case it is usually advisable to search with relaxed conditions.

For example, suppose that there are given 10 equally important characteristics and that no item is associated with all of them. Then the natural question to ask is: Are there any items associated with all but one of the characteristics, i.e., with any 9 of the characteristics? If not, then are there any items associated with all except 2 of the characteristics, i.e., with any 8 of the 10 , and so forth? We shall describe a procedure for accomplishing this important kind of search which does not involve trying all possible combinations of 9 of the 10 characteristics, then all possible combinations of 8 of the 10 , etc. This procedure can be extended to include a second type of relaxed-condition problem which may arise as follows: Suppose that 3 of the 10 given characteristics are most important and that it is desired to find all items associated with these 3 characteristics and also any 6 , or any 5 , etc., of the remaining 7 characteristics. The procedure can be easily generalized to include almost all relaxed-condition situations that occur in searching.

The idea of a simple sort can be used to compare searching techniques. A simple sort is a separation of a collection of items into two parts by means of a single characteristic $C$, that is, into a part whose items are each associated with $C$ and a part whose items are not. A simple sort is analogous to the manual separation of a deck of marginal-punch cards into two parts by means of a single needle.

To see the advantage of the searching technique to be described over the straightforward method of trying all possible combinations of leaving out one of the characteristics at a time, then two at a time, then three at a time, . . ., then $K=n-r$ at a time, note that the total number of simple sorts required for the straightforward method is

$$
\sum_{k=0}^{K} \frac{n!}{(n-k-1)!}
$$

However, the number of simple sorts required by the method to be pre-
sented is simply

$$
\frac{(K+1)(n-K)}{2}
$$

Searching for Items Associated with Any r Out of $n$ Characteristics. The method of procedure is illustrated by Fig. 7-7. Suppose that there are four given characteristics, represented by $C_{1}, C_{2}, C_{3}$, and $C_{4}$. We would first sort the collection of items for those associated with $C_{1}$. Next we would sort those which have $C_{1}$ for those which also have $C_{2}$. Then those having both $C_{1}$ and $C_{2}$ would be sorted for those also having $C_{3}$, and so forth, until we find all items that have $C_{1}, C_{2}, C_{3}$, and $C_{4}$. In Fig. 7-7 we indicate the collection of items that are associated with at least $C_{1}$ by $C_{1}$, those associated with at least $C_{1}$ and $C_{2}$ by $C_{1} \cdot C_{2}$, etc. The collection of items that do not have $C_{1}$ is indicated by $\tilde{C}_{1}$, etc. Then $C_{1} \cdot C_{2} \cdot \bar{C}_{3}$ would represent the collection of items that at least have $C_{1}$ and $C_{2}$ and not $C_{3}$. Thus the results of each successive sort of the first pass through the collection of items are indicated by the first row of Fig. 7-7. Here, in the first sort, the collection of items is divided into two parts, the part $C_{1}$ and the part $\bar{C}_{1}$. Then the collection with $C_{1}$ is sorted for $C_{2}$, resulting in a part $C_{1} \cdot C_{2}$ and a part $C_{1} \cdot \bar{C}_{2}$, and so forth. After the first pass there will result five collections $\bar{C}_{1}, C_{1} \cdot \bar{C}_{2}, C_{1} \cdot C_{2} \cdot \bar{C}_{3}$, $C_{1} \cdot C_{2} \cdot C_{3} \cdot \bar{C}_{4}$, and $C_{1} \cdot C_{2} \cdot C_{3} \cdot C_{4}$; all but the last of these will be used if another pass is necessary.

If the collection $C_{1} \cdot C_{2} \cdot C_{3} \cdot C_{4}$ is empty, i.e., if no items are associated with all of $C_{1} \cdot C_{2} \cdot C_{3} \cdot C_{4}$, we proceed to the second pass (the second row of Fig. 7-7). This time we start by first sorting $\bar{C}_{1}$ for $C_{2}$, obtaining $\bar{C}_{1} \cdot C_{2}$ and $\bar{C}_{1} \cdot \bar{C}_{2}$. We put the collections $\bar{C}_{1} \cdot C_{2}$ and $C_{1} \cdot \bar{C}_{2}$ together; these are sorted for $C_{3}$, and two collections are obtained, one with $\bar{C}_{1} \cdot C_{2} \cdot \bar{C}_{3}$ and $C_{1} \cdot \bar{C}_{2} \cdot \bar{C}_{3}$, the other with $\bar{C}_{1} \cdot C_{2} \cdot C_{3}$ and $C_{1} \cdot \bar{C}_{2} \cdot C_{3}$. This latter collection is put with $C_{1} \cdot C_{2} \cdot \bar{C}_{3}$ and these sorted for $C_{4}$ to obtain two collections, one with $\bar{C}_{1} \cdot C_{2} \cdot C_{3} \cdot \bar{C}_{4}, C_{1} \cdot \bar{C}_{2} \cdot C_{3} \cdot \bar{C}_{4}$, and $C_{1} \cdot C_{2} \cdot \bar{C}_{3} \cdot \bar{C}_{4}$, the other with $\bar{C}_{1} \cdot C_{2} \cdot C_{3} \cdot C_{4}, C_{1} \cdot \bar{C}_{2} \cdot C_{3} \cdot C_{4}$, and $C_{1} \cdot C_{2} \cdot \bar{C}_{3} \cdot C_{4}$. This latter collection and collection $C_{1} \cdot C_{2} \cdot C_{3} \cdot \bar{C}_{4}$ form the collection of all items having all except one of the given characteristics. If this collection is empty, then we proceed to a third pass, as shown in the third row of Fig. 7-7, to find the collection of items with all except two of the characteristics, and so forth.

Searching with Permanent Conditions. Suppose that there were seven characteristics given, $C_{1}, C_{2}, \ldots, C_{7}$, and that no item of the collection under consideration were associated with all these seven characteristics. The next step would be to relax the conditions, but suppose that we must have items associated with $C_{5}, C_{6}$, and $C_{7}$, and with as many of the others as possible. The characteristic combination $C_{5} \cdot C_{6} \cdot C_{7}$ is called a permanent condition. The searching technique would be first to sort the collection to obtain all items associated with $C_{5} \cdot C_{6} \cdot C_{7}$. Then we would sort these on $C_{1}, C_{2}, C_{3}$, and $C_{4}$, as described above, to obtain all items each associated with $C_{5} \cdot C_{6} \cdot C_{7}$ and three, or two, or one, of $C_{1}, C_{2}, C_{3}, C_{4}$,

As another illustration of a permanent condition, suppose that we desired to obtain all items associated with one or more of $C_{5}, C_{6}$, and $C_{7}$, and with as many of $C_{1}, C_{2}, C_{3}$, and $C_{4}$ as possible. In such a case we would first sort for $C_{5}$, sort the remaining items for $C_{6}$, and then sort those still remaining for $C_{7}$. These three sets would be put together to form the collection of items having one or more of $C_{5}, C_{6}$, and $C_{7}$. We would next sort this collection on $C_{1}, C_{2}, C_{3}$, and $C_{4}$, as described above, to obtain all items each of which is associated with $C_{5}, C_{6}$, and/or $C_{7}$, and three, or two, or one, of $C_{1}, C_{2}, C_{3}$, and $C_{4}$. In either of these examples, if no items were to have the permanent conditions, no further sorting could be accomplished.

Searching with Preferential Conditions. Suppose that there were nine characteristics given, $C_{1}, C_{2}, \ldots, C_{9}$, and that no item of the collection were associated with all nine given characteristics. However, suppose that a preference were associated with the characteristics so that, say, $C_{1}, C_{2}$, and $C_{3}$ have the most preference, $C_{4}, C_{5}$, and $C_{6}$ have the next preference, and $C_{7}, C_{8}$, and $C_{9}$ have the least preference. The searching procedure would first try for all of $C_{1}, C_{2}$, and $C_{3}$, or at least two of $C_{1}, C_{2}$, and $C_{3}$, or at least one, etc., as described above. Having chosen the items associated with the greatest number of the most preferred characteristics, these would be considered a permanent condition and would be sorted for all of $C_{4}, C_{5}$, and $C_{6}$, or at least two of $C_{4}, C_{5}$, and $C_{6}$, or at least one, etc. From the items having the most preferred characteristics we would now have chosen the items with the most characteristics of the next preference. Considering these as representing a permanent condition, we would try next for the items with the most characteristics of the least preference, that is, $C_{7}, C_{8}$, and $C_{9}$.

Note that the process of this section would be the natural one to follow in the problems of the previous paragraph when no items satisfy the desired permanent condition. The initial permanent condition would then be stated in terms of preferential conditions, and the process of this section would be used to obtain an approximation to the initial permanent condition.

Relaxing Sets of Conditions. Suppose that it is desired to search for all items associated with at least one of $C_{1}, C_{2}$, and $C_{3}$, and with at least one of $C_{4}, C_{5}$, and $C_{6}$, and with at least one of $C_{7}, C_{8}$, and $C_{9}$, and with at least one of $C_{10}, C_{11}, C_{12}$. Suppose that no such item exists; then the problem is to find all items that have at least one characteristic from at least three of the four sets of characteristics, or from at least two of the four sets, and so forth. Here we wish to relax sets of conditions. In order to facilitate the discussion, let us represent condition $C_{1}, C_{2}$, and/or $C_{3}$ by $C^{1}$, condition $C_{4}, C_{5}$, and/or $C_{6}$ by $C^{2}$, condition $C_{7}, C_{8}$, and/or $C_{9}$ by $C^{3}$, and condition $C_{10}, C_{11}$, and/or $C_{12}$ by $C^{4}$. Then the searching technique becomes as described and illustrated above, with superscripts replacing subscripts, and with the single sorts replaced by the combinations of sorts necessary to determine the $C^{i}$.


Fig. 7-7. Analysis of method of searching for all items each of which is associated with all, all except one, all except two, etc., of the given characteristics $C_{1}, E_{2}, C_{3}$, and $C_{4}$.

## EXERCISES

(a) Punch a hole in each corner of sixteen $3 \times 5$ cards. Then write the names of the authors (see Fig. 7-1) on these cards, one name on each card. Mark off eight equally spaced positions on one 5 -in. edge, nine positions on the other 5 -in. edge of each card. Assign one word for each position, the same on each of the 16 cards. Next notch the edge of each card corresponding to the positions of words characteristic of this author's article (see Table 7-1). The cards can now be searched by placing a knitting needle under the deck of cards at the position of the desired word (see Fig. 7-8); the notched cards will drop, and the unnotched ones can be separated by putting another knitting needle through a corner hole of the raised cards. By appropriately separating collections of these cards as in Fig. 7-7, find all items associated with at least six, at least five, at least four, and at least three of the following seven given characteristics: differentiation, application, England, evaluation, design, gas, and concept.


Fig. 7-8. Use of knitting needles to search marginal-punch cards.
(b) Using the cards made in (a), find all items that are associated with design and England and as many of the following as possible: differentiation, application, evaluation, gas, and concept.
(c) Using the cards made in (a), find all items that are associated with either evaluation or design or both and as many of the following as possible: differentiation, application, England, gas, and concept.
(d) How can the process of searching for all except one, except two, etc., be accomplished by means of the Tabledex tables? (Hint: A succession of tables must be used: one table for the first pass, two tables for the second pass, three tables for the third pass, etc.)
(e) Draw a flow chart for a search for items associated with all the given characteristics except one, except two, etc. First assume the data to be given as in Fig. 7-2b. Then assume the data to be given in terms of the Tabledex tables, as in Fig. 7-2c.

## 7-5. Sorting and Ordering

As discussed in Sec. 7-1, sorting can always be accomplished by ordering; in this section we shall turn our attention to ordering. Sorting and
ordering are essentially the same process, except that ordering carries the process all the way, while sorting carries the process only part of the way. In our discussion of ordering we shall refer to the ordering of a given list of numbers in order to be concrete, but it is clear that the methods apply for any linear ordering rule.

Minimum- or Maximum-in-pass. The first of the five methods of ordering to be presented is called the minimum-in-pass method. The description will be given in terms of the use of magnetic tape, but the principles involved are perfectly general. In this method, on the first pass over the tape the minimum number is recorded as follows: The first number is recorded in a temporary cell and is compared successively with the other numbers until a smaller number appears. The first number replaces this smaller number on the tape as this number is placed in the temporary cell. The successive comparisons are continued until another smaller number appears; again the two numbers are interchanged, and so forth. At the end of the first pass it is clear that the smallest number appears in the temporary cell. This is placed as the first number on the tape, and the second pass is started with the second number on the tape, proceeding as before. At the end of this pass the second smallest number appears in the temporary cell and is placed as the second number on the tape, and so forth. The $i$ th pass starts with the $i$ th item, determines the $i$ th smallest number, and puts it in the $i$ th position on the tape. For $N$ numbers this method requires $N-1$ passes through the tape; however, if the tape can be positioned, starting each pass with the next number in turn effectively reduces the number of passes by half, to approximately $N / 2$.

It is obvious that the maximum instead of minimum number could have been recorded on each pass (maximum-in-pass) and placed at the end of the remaining list; this method would again require about $N / 2$ passes. If both the minimum and a maximum are recorded in each pass, the latter being placed on the tape at the end of the pass, the former at the beginning of the next pass, the number of passes is again halved, to approximately $N / 4$. Depending on the size of the high-speed memory, the least two, or least three, or least $m$ numbers, and the greatest two, or greatest three, or greatest $n$ numbers could be found on each pass (and ordered within the high-speed memory), further reducing the number of passes required.

If more than one tape is available, the minimum-in-pass method can be accomplished in parallel. The original list to be ordered is divided into sublists (say $n_{1}$ in number). A new list is made from the minima which are removed from each of the $n_{1}$ sublists. This new list is divided into $n_{2}$ sublists, and a third list is made from the minima which are removed from each of the $n_{2}$ sublists. As many new lists as desired can be made, and the first number of the ordered list will be the minimum of the last such list. As a number is removed from a list, it is replaced by the minimum from the sublist from which it was originally taken (until the sublist is exhausted). Table 7-2 illustrates the process applied to an original list of 12 numbers, divided into $n_{1}=4$ sublists. The minima
from these are divided into $n_{2}=2$ sublists; their minima are then divided into $n_{3}=1$ sublist, whose minimum goes into the final ordered list, labeled $n_{4}$.

Transposition. The second method orders a list by transposition. The process is to transpose adjacent numbers on the list if the order of their characteristics is inverted. It starts by comparing the first two numbers and continues on overlapping pairs through the list. Pass after pass is made until no transpositions are required on an entire pass; then the list is in order. For example, consider Table 7-3 (where the caret represents comparison, the $t$ transposition). Here three passes were necessary to order the numbers. The fourth pass will result in no

Table 7-2. Minimum-in-pass Ordering Using Multiple Sublists

further transpositions, indicating that the list is in order. A variation on this method is to order successive overlapping sets of three or more (say $r$ ) numbers; a single tape may still be used in this process, and the number of passes required is approximately divided by $r-1$. Table 7-4 illustrates the procedure for overlapping sets of three numbers.

Ordering by Radix Coefficients. The third method is probably the most obvious of all the methods when a clearly defined radix occurs; in the present discussion we shall consider decimal numbers (i.e., radix ten). The method consists in sorting the numbers by the most significant figure, putting the sorts in order. The numbers within each sort are ordered on the second most significant figure; then within each of these subsorts the

Sec. 7-5] Searching, sorting, ordering, and codifying
numbers are ordered on the third most significant figure; and so forth. For an example, see Table 7-5. This method has the disadvantage that after the first pass the computer must work on subregions of the tape, which can present difficulties. For sorting punch cards, for example, this means that individual sorts must be made on successively smaller and smaller pieces of the original deck; such handling becomes increasingly inconvenient.

Table 7-3. Ordering by Transposition $\dagger$

| $\begin{aligned} & \text { 1st } \\ & \text { pass } \end{aligned}$ |  |
| :---: | :---: |
| $\begin{gathered} 2 \mathrm{~d} \\ \text { pass } \end{gathered}$ |  |
| 3d pass |  |

$\dagger$ Successive overlapping pairs are scanned.
The fourth method, which is essentially the inverse of the third, eliminates this difficulty. Here the first sort is made on the least significant figure. Then the entire tape is sorted on the second least significant figure, and so forth. For an example, see Table 7-6. However, both these methods offer the difficulty that simultaneously used multiple tape units are indicated. Of course the subsorts might be made by one of the first two methods, whence the entire sorting procedure becomes a mixture of methods.

Table 7-4. Ordering by Transposition within Overlapping Sets of Three Numbers


Sec. 7-5] searching, sorting, ordering, and codifying
Suppose that for the fourth method ten bins, or magnetic-tape units, in addition to the unit holding the original list, were not available for the separation by least significant decimal digit. For example, suppose that only 5 units were available, 1 of which contains the original list. Then

Table 7-5. Ordering by the Third Method

| Original list | Sort by most significant figure | Sort by 2d most significant figure | Sort by 3d most significant figure |
| :---: | :---: | :---: | :---: |
| 345 | 256 | 256 | 255 |
| 344 | 265 | 255 | 256 |
| 537 | 255 | 265 | 264 |
| 256 | 264 | 264 | 265 |
| 554 | 345 | 337 | 337 |
| 447 | 344 | 345 | 344 |
| 337 | 337 | 344 | 345 |
| 265 | 347 | 347 | 347 |
| 255 | 447 | 447 | 446 |
| 466 | 466 | 446 | 447 |
| 446 | 446 | 466 | 464 |
| 464 | 464 | 464 | 466 |
| 347 | 537 | 537 | 336 |
| 264 | 554 | 536 | 337 |
| 536 | 536 | 544 | 544 |
| 544 | 544 | 554 | 554 |

we could convert the least significant decimal digit of each number to two radix- 4 digits and in two passes order the list by the least significant decimal digit. Similarly two passes would be required for the next least significant decimal digit, and so forth.

Table 7-6. Ordering by the Fourth Method

| Original <br> list | Sort by <br> least <br> significant <br> figure | Sort by <br> 2d least <br> significant <br> figure | Sort by <br> 3d least <br> significant <br> figure |
| :---: | :---: | :---: | :---: |
| 345 | 344 | 536 | 255 |
| 344 | 554 | 537 | 256 |
| 537 | 464 | 337 | 264 |
| 256 | 264 | 344 | 265 |
| 554 | 544 | 544 | 337 |
| 447 | 345 | 345 | 344 |
| 337 | 265 | 446 | 345 |
| 265 | 255 | 447 | 347 |
| 255 | 256 | 347 | 446 |
| 466 | 466 | 554 | 447 |
| 446 | 446 | 255 | 464 |
| 464 | 536 | 256 | 466 |
| 347 | 537 | 464 | 536 |
| 264 | 447 | 264 | 537 |
| 536 | 337 | 265 | 544 |
| 544 | 347 | 466 | 554 |

## EXERCISES

(a) Draw a flow chart for coding each of the above four ordering methods.
(b) After shuffling a deck of playing cards, order them by each of the four methods without regard to suit (i.e., the four Queens, for example, will appear adjacent, after the Jacks and before the Kings, but not ordered by suit among themselves).
(c) Suppose that one were ordering alphabetically by the fourth method, using a computer with 10 tape units. What radix could be used, and how would the tape units be utilized?

## 7-6. Ordering by Merging

Merging. The fifth method is based on the simple idea of the merging of two ordered lists. For example, consider these two ordered lists of numbers:

| 265 |  | 255 |
| :--- | :--- | :--- |
| 337 |  | 264 |
| 446 | and | 464 |
| 466 |  | 536 |
|  |  | 544 |

Forming a single ordered list containing all the numbers is accomplished by successively comparing the first numbers on each list and removing the smaller number to a third list. Thus, since $255<265,255$ becomes the first number of the new list; now 264 becomes the first number of the
second list, and since $264<265,264$ becomes the second number of the new list; next, since $265<464,265$ becomes the third number of the new list; and so forth. In this manner the two ordered lists are merged to form a single new ordered list, namely,

255
264
265
337
446
464
466
536
544
In more mathematical notation, if the two ordered lists are $a_{1}<a_{2}<$ $\cdots<a_{I}$ and $b_{1}<b_{2}<\cdots<b_{J}$, then the merged list, namely, $C_{1}<C_{2}<\cdots<C_{(I+J)}$, is formed as indicated in the flow diagram of Fig. 7-9.

The initial step of the general ordering by merging process is to separate the given list into two lists in a manner that preserves any ordering that might have originally appeared among adjacent numbers. The first number of the given list is used to start the first of two generated lists.


Fig. 7-9. Flow chart for merging two ordered lists.
Then successive numbers of the given list are added to this new list so long as they appear in the proper order. The first number encountered that appears out of order is used to start the second generated list. All successive numbers that are in the proper order are placed successively in this second list. When a number out of order again appears, it is placed in the first list, with those following numbers which are in the proper order, and so forth. Thus in forming the two new lists we switch output lists whenever a number appears out of order, so that any order within a string of adjacent numbers in the given list will be retained in one of the
two lists. For the example below, strings of numbers in the original list that appear in the proper order are included in braces; these are alternately placed in the two generated lists.

| Original list | New list | New list |
| :---: | :---: | :---: |
| \{345 | \{345 | $\{344$ |
| \{344 | $\{256$ | $\{537$ |
| \{537 | \{554 | \{447 |
| $\{256$ | \{337 | \{265 |
| \{554 | \{255 | \{446 |
| \{447 | 466 | 464 |
| \{337 | \{347 | ${ }^{264}$ |
| \{265 |  | 536 |
| \{255 |  | 544 |
| 466 |  |  |
| $\{446$ |  |  |
| 464 |  |  |
| \{347 |  |  |
| 264 |  |  |
| \{ 536 |  |  |
| 544 |  |  |

When this initial step is finished, the ordering proceeds as follows: Each of the two lists contains sublists that are ordered, and each sublist of one can be paired with a sublist of the other, except perhaps the last sublist of one of the lists (see the horizontal lines below). The pairs of ordered sublists are then merged. The merged results are again placed alternately $\dagger$ in two new lists as shown below:

|  |  |  | New list | New list |
| :--- | :--- | :---: | :---: | :---: |
| 345 |  | merge | 344 | 344 |
|  |  | 537 | 345 | 256 |
| 256 |  | merge | 447 | 537 |
| 554 |  | 265 | 447 |  |
| 337 |  | 265 | 337 | 254 |
|  | merge | 446 | 446 | 264 |
|  |  | 464 | 464 | 466 |
| 255 |  | 264 |  | 536 |
| 466 | merge | 536 | 347 | 544 |
|  |  | 544 |  |  |
| 347 |  |  |  |  |

The process is repeated, forming each time two lists of increasingly longer ordered sublists, until all the numbers appear in one ordered list.
$\dagger$ The alternation of the merged sublists in the new lists ensures the maximum number of pairings of sublists for the next merge; if the total number of sublists is known, the same result would be obtained by putting the first half on one tape, the second half on the other.

Sec. 7-6] searching, sorting, ordering, and codifying

| Second merge <br> results | Third merge <br> results | Ordered list |  |
| :---: | :---: | :---: | :---: |
| 256 | 255 | 255 | 347 |
| 344 | 264 | 256 | 255 |
| 345 | 265 | 264 | 256 |
| 447 | 337 | 265 | 264 |
| 537 | 446 | 337 | 265 |
| 554 | 464 | 344 | 337 |
|  | 463 | 345 | 344 |
|  | 536 | 446 | 345 |
|  | 544 | 447 | 347 |
| 347 |  | 464 | 446 |
|  |  | 466 | 447 |
|  |  | 536 | 464 |
|  |  | 537 | 466 |
|  |  | 544 | 536 |
|  |  | 554 | 537 |
|  |  |  | 544 |
|  |  |  | 554 |

Often four magnetic tape units are used in this ordering process. Two of the tape units hold the old lists, and the other two record the results of the merging. Then, when both old lists have been exhausted, the newly formed lists become the old lists and the pairs of tape units exchange functions. In merging two sublists, the end of a sublist is sensed when $a_{i}>a_{i+1}$; when both sublists are exhausted, i.e., when both $a_{i}>a_{i+1}$ and $b_{j}>b_{j+1}$, then the merge starts on the next pair of sublists, the results being put on the other receiving tape unit. Figure 7-10 gives a flow chart for this process.

Variations on Merging. The technique of ordering by merging two ordered lists is easily extended to ordering by merging more than two


Fig. 7-10. Flow chart for ordering by merging.
ordered lists. The initial separation of a list to be ordered can involve more than two new lists, and then the merging of ordered sublists would be accomplished successively with one sublist from each. If the initial step formed $m$ new lists and the merging of sublists from these formed $n$ new lists, then $m+n$ magnetic tapes would be involved. Below we illustrate the case for three initial new lists (i.e., $m=n=3$ ):

| Original list | Initial step |  |  | First merge results |  |  | Ordered list, second merge result |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \{345 | \{ 345 | $\{344$ | $\{256$ | 256 | 255 | 264 | 255 |
| \{344 | \{447 | $\{537$ | $\{554$ | 344 | 265 | 536 | 256 |
| 1537 | \{255 | (337 | $\{265$ | 345 | 337 | 544 | 264 |
| \{256 | \{466 | 446 | \{347 | 447 | 347 |  | 265 |
| \{554 |  | 464 |  | 537 | 446 |  | 337 |
| \{447 | (264 |  |  | 554 | 464 |  | 344 |
| \{337 | \{336 |  |  |  | 466 |  | 345 |
| \{265 | 544 |  |  |  |  |  | 347 |
| \{ 255 |  |  |  |  |  |  | 446 |
| $\{466$ |  |  |  |  |  |  | 447 |
| \{446 |  |  |  |  |  |  | 464 |
| \{464 |  |  |  |  |  |  | 466 |
| (347 |  |  |  |  |  |  | 536 |
| (264 |  |  |  |  |  |  | 537 |
| \{336 |  |  |  |  |  |  | 544 |
| 544 |  |  |  |  |  |  | 554 |

Another variation takes further advantage of any intrinsic ordering in the original list. Here a tape is not closed off as a smaller item occurs, but rather is held open to receive any larger item later in the list. Each new item is compared with the final items on each tape, in order of largest to smallest, and is put on that tape whose last item is as large as possible without exceeding the new item. If the new item is smaller than all the final items, it is placed on the tape with the largest item to start a new sublist. Using this technique to sort the above list of numbers, merging from two lists, gives the following (with the sublists indicated):

| Initial step |  | First merge results |  | Second merge results |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \{345 | \{344 | (344 | (256 | 256 | 255 |
| $\{537$ | $\{554$ | \{345 | 337 | 337 | 264 |
| $\{256$ | \{337 | \{537 | \{447 | 344 | 265 |
| \{447 | (255 | 554 | 464 | 345 | 347 |
| $\{265$ | $\{446$ | (255 | 466 | 447 | 446 |
| $\{466$ | 464 | 265 | $\{264$ | 464 | 536 |
| (347 | \{264 | \{446 | $\{347$ | 466 | 544 |
| $\{536$ |  | 536 |  | 537 |  |
| 544 |  | 544 |  | 554 |  |

The third merge, instead of the fourth required above for two-tape merging, will give the ordered list. Note how changing tapes for the italicized numbers allows the lengthening of the sublists.

Comparison of Ordering Methods. The number of passes, i.e., the number of times one must look through all the numbers of the original list, is very large for the first two methods as compared with the merge method. The straight minimum-in-pass method requires $N / 2$ (or $N / 4$ or perhaps less depending on the equipment) passes for $N$ numbers. The merge sort using $2 T$ magnetic tape units requires no more than $K+1$ passes, where $K$ is the smallest integer such that $T^{R} \geq N$. The merge sort has the additional feature that full advantage is taken of any ordered sublists that may appear in the original list, and if the numbers are randomly distributed, there ought to be about $N / 2$ ordered sublists. In such a case $1+K^{\prime}$ passes are required, where $K^{\prime}$ is the smallest integer such that $T^{R^{\prime}} \geq N / 2$. For the transposition method there can be as many as $n(n+1) / 2$ passes, but here again any ordered sublists that may appear in the original list can reduce this number of passes. The variation of the transposition method is of course more efficient. Ordering by the radix-coefficient methods can compete with the merge sort when all numbers from 1 to $N$ are in the list, with practically no ordered sublists. But if the numbers have more than $K$ digits, where $K$ is the smallest integer such that $R^{K}>N$, where $R$ is the radix being used, then the merge sort would require fewer passes. Since the radix-coefficient methods do not take advantage of any ordering that might already exist in the list, the merge sort can be still more advantageous. However, if only a single tape is available, only the minimum-in-pass or transposition can be done.

Of course the number of passes required for ordering a list is not necessarily the only criterion applied in deciding on a method for ordering. The nature of the equipment available, e.g., how many magnetic-tape units, or bins, are available and whether these can or cannot be used concurrently, how complex operations can be performed, etc., often limit the types of methods that can be used. The number of items or numbers to be sorted, the number of times such a process must be repeated, etc., all enter into the choice of the ordering system. In general a combination of ordering techniques can be used to take advantage of particular situations that may occur at the different levels of the ordering process. However, if we were asked to choose which system is of greatest importance, we would say the merge ordering method and its variations have the most advantages.

## EXERCISES

(a) Draw a flow chart for coding a merge sort using four tapes, passing the numbers from two tapes to the other two.
(b) Draw a flow chart for coding a merge sort, passing the numbers from $m$ tapes to $n$ tapes, where $m$ and $n$ can be specified arbitrarily.
(c) What is the maximum number of passes required to put a deck of 52 cards in some order by suit as well as by denomination, merging from two bins to two bins? From three bins to one bin (counting the pass required to redistribute the cards into the three bins after each merge)? From four bins to four bins? From five bins to three bins? Considering these results, discuss the most efficient way to utilize a fixed number of tape units in a merge sort.

## 7-7. Codifying : Error Correction and Superimposition

Encoding, Decoding, and Codifications. By codifying $\dagger$ is meant the process of relating to an item or characteristic a set of symbols, called a codification. As we have seen (cf. Sec. 7-1), codifying is intimately associated with searching, sorting, and ordering. Codifying is used for three purposes: First just for convenience in handling the information in a shorter form rather than in raw form; second for making the information compatible with a particular mechanical or electronic processing device being used; and third to facilitate the particular method of searching, sorting, or ordering being used.

In general, codifying involves two processes, called encoding and decoding. Encoding is the process of generating the codification related to a given item or characteristic; decoding, conversely, is determining the items or characteristics related to a given codification. The processes of encoding and decoding are accomplished by means of either a code book or a relation scheme. For example, a telephone book is an encoding code book that gives the codification (i.e., the telephone number) related to an item (i.e., a person); the decoding is accomplished after dialing, by means of a scheme built into the telephone company's electrical dialing equipment. Another example is the biological codification of the genes, where the encoding is the evolutionary process and the decoding is the ontogenetic process that results in, say, an individual animal.

The codification of items or characteristics can be either substantive or nonsubstantive in character. A substantive codification is one in which the symbols have meaning in themselves. A substantive codification of names, for example, might comprise simply the first four consonants of the last names with the initials. A word in a dictionary is a substantive codification of its meaning. The genes, of course, represent an outstanding example of substantive codification.

For a nonsubstantive codification consider the example of the codification of research reports by accession numbers, or the codifying of an item in a bibliography by the page and line number on which it is found. Nonsubstantive codifications are frequently merely addresses that tell the locations of the related items or characteristics. An exception to this is the population-based (nonsubstantive) codification considered in Sec. 7-2, in which the symbol for a characteristic is the number of items associated with that characteristic.

The relationships between encoding, decoding, and information processing are summarized in Fig. 7-11. For example, consider our illus-
$\dagger$ See footnote on p. 217.
trative bibliography discussed above. Here the encoding was the relating of population-based numbers to the given characteristics (i.e., the given retrieval words) by means of a code book. The processing was searching, where, for instance, the Tabledex method might be used, which resulted in a collection of numbers related to the associated items (i.e., the page and line numbers of desired article references). Finally the decoding process was accomplished by locating the items at their address (i.e., the entries are retrieved from their page and line numbers). The information processing here consisted in transforming a set of characteristic codifications into a set of item codifications.


Fig. 7-11. Relation between encoding, decoding, and information processing.
Efficiency of Codifications. To determine how many symbol positions are required in an unambiguous codification using $K$ different symbols, we consider each symbol as a number in the base (radix) $K$ and use enough symbol positions to count the number of items in the base $K$. That is, with $N$ items (or characteristics) and $K$ symbols, the number of symbol positions in a codification must be no smaller than the smallest integer $n$ such that $K^{n} \geq N$ (or $n \geq \log _{K} N$ ) if the codification relating to an item is to be unique in the list. For example, for 600 items and a binary codification (that is, $K=2$ ), we have $\dagger$

$$
n \geq \log _{2} 600=\frac{2.7782}{0.3}=9.261
$$

or $n=10$. If the number of positions is greater than $n$, that is, if more positions are being used than are necessary, the codification is called redundant. If fewer than the required $n$ positions are used, the codification is called irredundant and the code for an item is not unique in the list. A codification that is neither redundant nor irredundant is called efficient.

For example, an English word can be considered as a codification of an idea using the 26 alphabetical symbols. Suppose that we have a dictionary all the words of which are no longer than 10 letters. We can make all the words the same length by introducing a 27 th letter, say $\alpha$, and filling up with $\alpha$ 's all positions to the left of a word to make 10 positions altogether, if necessary. It is then possible to have more than $145 \times 10^{12}$ different words in our dictionary. However; a desk dictionary has only approximately 100,000 , or $10^{5}$, words, and so a dictionary is redundant. Then again, that's to be expected.

In the next paragraphs we shall consider a use for purposely redundant
$\dagger$ Recall that $\log _{K} N=\log _{10} N / \log _{10} K$. For $K=2, \log _{2} N=\log _{10} N / \log _{10} 2$, where $\log _{10} 2 \approx 0.3$.
codification; that discussion will be followed by consideration of a use for purposely irredundant codifications.

Self-correcting Redundant Codification. Frequently situations arise where errors may be introduced into a codification during storage or transmission. If errors cannot be tolerated, a redundant code can be devised with the extra positions of the redundancy used to correct such errors as may occur. However, the self-correcting scheme that makes use of redundant positions must also be able to correct errors that may occur in these extra redundant positions as well. The process can be outlined as follows: First from the given information-carrying codification there is generated the redundant codification. This redundant codification is stored or transmitted, etc., during which time some errors can


Fig. 7-12. The self-correcting redundant-codification process.
enter into the codification. Finally, when the information is to be used, there is generated from the redundant codification (which may contain some errors) the correct information-carrying codification in spite of any errors in the redundant codification (see Fig. 7-12). In what follows we shall confine ourselves to binary codification.

Let us first illustrate a self-correcting technique that will correct a single error. The first step is the formation of the redundant codification. Suppose that the information-carrying part of the codification has 4 bits, $I_{0}, I_{1}, I_{2}, I_{3}$-say, for example, 1101. We form an array as shown in Fig. 7-13 (with the top row all units and the columns otherwise having all possible combinations of zeros and units). The information-
Information-carrying

$\quad$ codification | $I_{0}=1$ | 0123 | 4567 |
| :--- | :--- | :--- |
| $I_{1}=1$ | 1111 | 1111 |
| $I_{2}=0$ | 0101 | 0101 |
| $I_{2}=1$ | 0011 | 0011 |
| $I_{3}=0000$ | 1111 |  |
| Redundant codification | 1010 | 0101 |

Frg. 7-13. Work for forming redundant codification for single-bit self-correction.
carrying codification is set down beside the array as a column. The desired redundant codification is formed bit by bit by comparing this column successively with each column of the array, counting the number of units in common (i.e., logically multiplying the columns and counting the number of units in common; see Sec. 4-5 and Part 3). If the number of units is even, a zero is placed under that column of the array; if odd;
a unit. For example, for the sixth bit, under column 6 we have

$$
\begin{array}{r}
\left(\begin{array}{l}
1 \\
1 \\
0 \\
1
\end{array}\right) \cdot\left(\begin{array}{l}
1 \\
0 \\
1 \\
1
\end{array}\right)=\left(\begin{array}{l}
1 \\
0 \\
0 \\
1
\end{array}\right) \\
\therefore r_{6}=0
\end{array}
$$

for the seventh bit

$$
\begin{array}{r}
\left(\begin{array}{l}
1 \\
1 \\
0 \\
1
\end{array}\right) \cdot\left(\begin{array}{l}
1 \\
1 \\
1 \\
1
\end{array}\right)=\left(\begin{array}{l}
1 \\
1 \\
0 \\
1
\end{array}\right) \\
\therefore r_{7}=1
\end{array}
$$

and so forth.
Suppose that this redundant codification 10100101 is stored, and during the storage the third bit $r_{3}$ becomes changed. Then the incorrect code is 10110101 . Of course we assume that we know nothing about the error in the codification except that there may be at most a single error. The problem remains to determine the correct bits $I_{0}, I_{1}, I_{2}$, and $I_{3}$ of the original information-carrying codification. The correct value of the bits $I_{1}, I_{2}, I_{3}$, and $I_{0}$ will each be derived, in this order, in spite of the error in the code. First note that, if $I_{1}=0$, then because of the


Fig. 7-14. Work for finding $I_{1}, I_{2}$, and $I_{3}$.
method of formation we would clearly have $r_{0}=r_{1}, r_{2}=r_{3}, r_{4}=r_{5}$, and $r_{6}=r_{7}$; that is, adjacent pairs of bits would be the same. If $I_{1}=1$, then none of these adjacent pairs would be the same. A single error can affect only a single pair of positions; hence, to find $I_{1}$, we simply check to see whether we have more "same" pairs, or more "different" pairs. More same pairs means $I_{1}=0$; more different pairs means $I_{1}=1$. Similarly $I_{2}$ is determined from pairs $\left(r_{0}, r_{2}\right),\left(r_{1}, r_{3}\right),\left(r_{4}, r_{6}\right)$, and ( $r_{5}, r_{7}$ ) and $I_{3}$ from pairs $\left(r_{0}, r_{4}\right),\left(r_{1}, r_{5}\right),\left(r_{2}, r_{6}\right)$, and ( $r_{3}, r_{7}$ ) (see Fig. 7-14 for the work). To find $I_{0}$, consider an array composed of the rows of the original array corresponding to the $I_{1}, I_{2}$, or $I_{3}$ which are found to be units and the redundant-code row. Under each column at this array place a zero if the number of units in the column is even, a unit if odd. If the number so formed is mostly zeros, $I_{0}=0$; if mostly units, $I_{0}=1$.

Incidentally this new number clearly shows the position of the single error (see Fig. 7-15).

As another illustration, consider a 5-bit information-carrying codification and an extension of the above scheme to correct as many as 3 erroneous bits in the redundant codification. Let the original 5 bits be $I_{0}=0$, $I_{1}=0, I_{2}=1, I_{3}=1$, and $I_{4}=0$. Figure 7-16a represents the work required to generate the redundant codification which is to be transmitted or stored; the work proceeds just as in the example above. Suppose

|  | 0123 | 4567 |
| ---: | ---: | ---: |
| $I_{1}=1$ | 0101 | 0101 |
| $I_{3}=1$ | 0000 | 1111 |
| Incorrect redundant codification | 1011 | 0101 |
| New number | 1110 | 1111 | more units; $\therefore I_{0}=1$

that erroneous codification shown in Fig. 7-16 results from the storage, then the work required to determine the correct 5 information-carrying codification bits appears in Fig. 7-16b.


Note that errors occurred in positions 3,6, and 12 .
Fig. 7-16. Scheme illustrating three-error correcting process.

Observe that in the first example we used 8 bits to codify 4 informa-tion-carrying bits, or a redundancy of 4 bits; in the second example we used 16 bits to codify 5 bits, or a redundancy of 11 bits. In the first case we are trying to recognize 9 different possibilities, i.e., no error, or a single error in one of eight positions. This clearly takes 4 bits, the redundancy used. For the second case we are trying to recognize 697 different possibilities, i.e., no error, a single error in one of 16 positions, a double error that can occur in $\binom{16}{2}=120$ different ways, or a triple error that can occur in $\binom{16}{3}=560$ different ways. $\dagger$ To distinguish among 697 possibilities, we clearly need 10 bits; so the 11-bit redundancy of the second example is one more than the minimum required. However, note that the 0th column of the array could have been omitted, and the scheme would work just as well. This would give us our minimum 10-bit redundancy.

Superimposed Irredundant Codification. As we have seen, a binary codification that will distinguish uniquely between $N$ characteristics requires at least $\log _{2} N$ bit positions. Thus, if 4,500 characteristics are in the list, 13 bits are required. It frequently happens that, although $N$ characteristics could occur, fewer than $N$ of these actually appear in a particular situation. However, it is in general not known beforehand how many will appear. In such cases, particularly when a substantive codification for the characteristics is used, at least $\log _{2} N$ bit positions are used for the codification anyway, to take account of all eventualities. Thus, even though not all 4,500 characteristics will occur, 13 bits might still be reserved for the codification.

Furthermore, suppose that we are dealing with items each of which is associated with $X$ of these characteristics; then, according to our above discussion, at least $X \log _{2} N$ bit positions must be used to identify an item. For example, if $X=3$ and $N=4,500$, then $3 \times 13=39$ bit positions would be necessary. Thus, in principle, $N^{x}$ items can be distinguished this way; but as we observed above, we are here considering situations where they do not all actually appear. Evidently we are being wasteful of bit positions because fewer than $N^{x}$ items require fewer than $X \log _{2} N$ bit positions for a codification. The problem therefore arises: How can we use fewer than $X \log _{2} N$ bits for our codification, say, $H<X \log _{2} N$, and yet maintain our ability to distinguish among all $N$ characteristics? The answer is found in the concept of superimposed codification.

By the superimposed codification corresponding to $X$ characteristics we mean the result of forming the logical sum (see Sec. 4-5 and Part 3) of the individual codifications for these $X$ characteristics. That is, if the units represent, for example, notches on the edge of a card, two
$\dagger$ Recall that the number of ways of taking $X$ objects $Y$ at a time is given by the binomial coefficient $\binom{X}{Y}=\frac{X!}{Y!(X-Y)!}$.
notches in the same position are equivalent to a single notch. Thus, if three characteristics have the following codes:

| Characteristic | Position |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 23 |  | 4 | 5 | 6 | 78 |  | 9 | 011 | 12 |  | 131 |  | 15 | 1617 |  | 181920 |  |  |  |
| 1st. | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 |
| 2d. | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 |  |  | 0 | , | 1 | 0 | 0 | 0 | 0 | 0 |  | 0 |
| 3d. | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |  | 0 |

then the corresponding superimposed codification is

$$
\begin{array}{llllllllllllllllllll}
0 & 0 & 1 & 1 & 0 & 0 & 1 & 0 & 1 & 1 & 1 & 0 & 0 & 1 & 0 & 1 & 0 & 0 & 1 & 0
\end{array}
$$

We shall illustrate by means of an example how superimposed codification can be made to satisfy the above criterion of using fewer than $X \log _{2} N$ bits and yet maintain the ability to distinguish among all $N$ characteristics. Suppose as above that $N=4,500$. Let us codify the characteristics as follows: Use 20 positions, and let each codification contain precisely 4 units. This codification will allow us to code each


Fig. 7-17. Example of superimposed codification.
characteristic uniquely, because 20 positions can be taken four at a time in $\binom{20}{4}=\frac{20!}{4!(20-4)!}=4,845$ different ways, and $4,845>4,500$. Finally, suppose that each item is associated with three characteristics; that is, $X=3$. Then let the codification of the item be the superimposed codifications of its associated three characteristics. Note that the codification for an item now comprises only 20 positions, rather than the 39 thought necessary above, saving about half the positions.

The advantages of this technique can most readily be visualized in terms of the marginal punched cards described above, where each card represents an item, and where the marginal positions are the bit positions with a punch representing a unit, no punch a zero (see Fig. 7-17). Suppose that an item is associated with the three characteristics whose
codifications appear above and that the 20 marginal positions of the item card are punched with the superimposed codification. Then, if all items associated with the first characteristic are being searched for, the sorting needles are placed in positions $3,7,9$, and 11 , and clearly the proper item cards will drop. Similarly for the second or third characteristic. However, we must evidently pay a price for this convenience and saving in item-codification positions. For suppose that the code for some other characteristic is

| $\stackrel{3}{3}$ | ${ }^{10}$ | ${ }^{11}$ | ${ }^{19}$ |
| :---: | :---: | :---: | :---: |
| 00100 | 00001 | ${ }^{10} 000$ | 00010 |

Our item card (see Fig. 7-17) is not associated with this characteristic but nonetheless will drop in the search for items associated with this characteristic. The reason for this is that our codifications overlapped, allowing for more than three combinations of 4 units. In fact, in our illustrative example, nine punches appear, allowing for

$$
\binom{9}{4}=\frac{9!}{4!(9-4)!}=126
$$

such possibilities, and hence $126-3=123$ possible false combinations. However, the situation is not so bad as it seems, for remember that we supposed that not all the $\binom{20}{4}=4,845$ possible characteristics actually appear, and hence not all the false combinations will ever be sensed.

The subject of superimposed codification therefore resolves itself into the problem of determining the probability $p$ that an item (card) not associated with a particular characteristic will be selected (dropped) during the search for that characteristic. We shall refer to $p$ as the probability that an item (card) will be a false drop. The formulas given below for this probability $p$ are based on the assumption that the codes for the characteristics are randomly chosen and that the associations of items with characteristics are also randomly chosen.

Let $H=$ number of positions in superimposed codification
$Y=$ number of units in a characteristic codification
$X=$ number of characteristics associated with an item

Then

$$
p=\frac{\left[\binom{H}{Y}-1\right]^{X}-\sum_{i=0}^{i=Y-1} E_{Y-i}}{\binom{H}{Y}^{X}}
$$

where

$$
\left.\begin{array}{rl}
E_{Y} & =\binom{Y}{0}\binom{H-Y}{Y}^{X} \\
E_{Y-1} & =\binom{Y}{1}(H-Y+1 \\
Y
\end{array}\right)^{X}-\binom{Y}{1} E_{Y} .
$$

$$
\left.\begin{array}{rl}
E_{Y-2}= & \binom{Y}{2}\binom{H-Y+2}{Y}^{X}-\binom{Y}{2} E_{Y}-\binom{Y-1}{1} E_{Y-1} \\
E_{Y-3}= & \binom{Y}{3}(H-Y+3 \\
Y
\end{array}\right)^{X}-\binom{Y}{3} E_{Y}-\binom{Y-1}{2} E_{Y-1} \quad-\binom{Y-2}{1} E_{Y-2} .
$$

and so forth.
For our example above, $\dagger H=20, Y=4, X=3$; hence

$$
\begin{aligned}
p=\frac{\left[\binom{20}{4}-1\right]^{3}-\left(E_{1}+E_{2}+E_{3}+E_{4}\right)}{} & \binom{20}{4}^{3} \\
& =\frac{0.1131692 \times 10^{12}-0.10890324 \times 10^{12}}{0.11323941 \times 10^{12}}=0.0377
\end{aligned}
$$

From probability theory we know that, if there are $M$ items, then the expected number of false drops will be $M p$. For our example, if $M=200$, we would expect $200 \times 0.0377=7.54$ false-drop cards during the search on a particular characteristic. To find the probability $P(m)$ of obtaining $m$ false drops, we use the formula from probability theory,

$$
P(m)=\binom{M}{m} p^{m}(1-p)^{M-m}
$$

In Fig. 7-18 we have graphed some of these values for our example.
So far we have been considering false drops when searching on one characteristic only. Now we shall discuss the situation that arises when more than one characteristic is used in the search. Let $n$ be the number of characteristics entering the search. The codifications of these particular characteristics may overlap. Let us suppose that their logical sum has precisely $h$ units (punches). Then

$$
p=\frac{\sum_{j=0}^{j=n-1} F_{n-j}-\sum_{i=0}^{i=h-1} E_{h-i}}{\binom{H}{Y}^{X}}
$$

$\dagger$ For numerical calculations some helpful results are $\binom{U}{0}=1,\binom{U}{1}=U$, $\binom{U}{V}=\frac{U(U-1) \cdots(U-V+1)}{1 \times 2 \times \cdots \times V}, 0!=1,1!=1$.


Fig. 7-18. Probability of obtaining exactly $m$ false drops for $H=20, Y=4, X=3$, and $M=200$. (Here $h=4$.)
where

$$
\begin{aligned}
F_{n} & =\binom{n}{0}\left[\binom{H}{Y}-n\right]^{x} \\
F_{n-1} & =\binom{n}{1}\left[\binom{H}{Y}-n+1\right]^{x}-\binom{n}{1} F_{n} \\
F_{n-2} & =\binom{n}{2}\left[\binom{H}{Y}-n+2\right]^{x}-\binom{n}{2} F_{n}-\binom{n-1}{1} F_{n-1} \\
F_{n-3} & =\binom{n}{3}\left[\binom{H}{Y}-n+3\right]^{X}-\binom{n}{3} F_{n}-\binom{n-1}{2} F_{n-1}-\binom{n-2}{1} F_{n-2}^{\prime}
\end{aligned}
$$

and so forth, and

$$
\begin{aligned}
E_{h} & =\binom{h}{0}\binom{H-h}{Y}^{X} \\
E_{h-1} & \left.=\binom{h}{1}\binom{H-h}{Y}-1\right)^{X}-\binom{h}{1} E_{h} \\
E_{h-2} & =\binom{h}{2}\binom{H-h+2}{Y}^{X}-\binom{h}{2} E_{h}-\binom{h-1}{1} E_{h-1} \\
E_{h-3} & =\binom{h}{3}\binom{H-h+3}{Y}^{X}-\binom{h}{3} E_{h}-\binom{h-1}{2} E_{h-1}-\binom{h-2}{1} E_{h-2}
\end{aligned}
$$

and so forth.
Observe that, if $\binom{H}{Y} \gg n$, then $\sum_{j=0}^{j=n-1} F_{n-j} \approx\binom{H}{Y}^{X}$. This is the case for our example of $H=20, Y=4$, and $X=3$. Let us suppose that we
are searching on three characteristics with the codifications given above (see Fig. 7-17); then $h=9$. Thus we have

$$
p=\frac{\binom{20}{4}^{3}-\sum_{i=0}^{i=8} E_{9-i}}{\binom{20}{4}^{3}}=\frac{(0.113732-0.113716) \times 10^{12}}{0.113732 \times 10^{12}}=0.00014
$$

It is interesting to compare $P(m)$ when searching on a single characteristic with $P(m)$ when searching on three characteristics that overlap to present the nine units of our illustration (see Exercise $j$ ). Observe that $h$ can range from 4 to 12 ; some values of $p$ for various values of $h$ are

| $h$ | 4 | 6 | 9 | 12 |
| :---: | :---: | :---: | :---: | :---: |
| $p$ | 0.0377 | 0.0061 | 0.00014 | 0.0000003 |

Note that, as long as $\binom{H}{Y} \gg n$, then the value of $h$ is all-important and $p$ is effectively independent of $n$. However, if, for example, $H=6$, $Y=2, X=3$, then an $n$ of 1,2 , or 3 can no longer be neglected.

## EXERCISES

(a) How many codifications can be made of no more than 10 positions with 26 symbols? If $K=26$, what is the most efficient number of positions to use for codifying 100,000 words?
(b) Given the information code 10101, find the redundant codification, as in Fig. 7-16.
(c) If a redundant codification was received as 0100100000010011 , what was the information code sent and in what positions did errors occur? Suppose that 0100100000010001 was received; in what positions are the errors?
(d) Suppose that there were 6 bits in an information code; if the scheme given above were used, how many errors could be detected and how many bits would there be in the redundant codification?
(e) For $H=4, Y=2$, and $X=2$, find $p$ by means of the above formulas for $n=1, h=2$; for $n=2, h=2$; for $n=2, h=3$; and for $n=2, h=4$. Check your result by making an enumeration of the $\binom{H}{Y}^{X}=\binom{4}{2}^{2}=36$ equally probable conditions.
(f) Compute $p$ for $H=6, Y=2, X=3$ when searching on a single characteristic.
(g) Compute $p$ for $H=6, Y=2, X=3$ when searching on three characteristics (that is, $n=3$ ) that overlap so that $h=5$.
( $h$ ) Compare the results of Exercises $f$ and $g$ by graphing $P(m)$ for $M=50$ in both cases.
(i) Find the expected number of false drops for $H=100, Y=6, X=4$ when $h=15$.
(j) Graph $P(m)$ for a search on three characteristics that overlap to present 9 units (i.e., $h=9$, whence $p=0.00014$-see above). Compare the results with Fig. 7-18.

## 7-8. Additional Topics

a. Equivalence Relation and Linear Ordering. To a mathematician the term relation means a rule that can be applied to two objects of a set to determine whether or not they are related in a fashion defined by the rule. A relation is usually symbolized, and if the relation holds for elements $a$ and $b$ of a set, then we write " $a$ symbol $b$," read " $a$ is in relation to $b$." An equivalence relation, symbolized by $\cong$, is a relation defined for a set such that, if $a, b$, and $c$ are any elements of the set, then (1) $a \cong a$ (an element is in relation to itself, called the reflexive property), (2) if $a \cong b$, then $b \cong a$ (if $a$ is in relation to $b$, then $b$ is in relation to $a$, called the symmetric property), (3) if $a \cong b$ and $b \cong c$, then $a \cong c$ (called the transitive property). Can you give some examples of relations that are equivalence relations (i.e., that are reflexive, symmetric, and transitive)? For a particular set and equivalence relation the subset of objects that are all equivalent to each other is called an equivalence class. As an example, consider the set of all integers and the relation: Two integers are in relation to each other if their difference is divisible by 3 . Show that this relation is an equivalence relation and that there are three equivalence classes: . . $-2,1,4,7, \ldots ;$ $-1,2,5,8, \ldots$; and $\ldots 0,3,6,9$,

The most important property of an equivalence relation is that each object of a set is included in one and only one of the equivalence classes generated by an equivalence relation. Why is this property important in considering searching, sorting, ordering, and codifying? (See R. L. Wilder, "Introduction to the Foundations of Mathematics," John Wiley \& Sons, Inc., New York, 1952; or G. Birkhoff and S. MacLane, "A Survey of Modern Algebra," The Macmillan Company, New York, 1941.)

Another important relation is called the linear-ordering relation, denoted by $\geq$ and defined as follows: (1) for any two objects $a$ and $b$ of the set, either $a \geq b$ or $b \geq a$; (2) if $a \geq b$ and $b \geq c$, then $a \geq c$; (3) if $a \geq b$ and $b \geq a$, then $a$ and $b$ are identical (written $a=b$ ). A relation is called a partial ordering if (1) does not hold. Can you give examples of linear- and partial-ordering relations? In this chapter methods were given for ordering objects according to a linear-ordering relation. What could "ordering objects according to a partial-ordering relation" mean? How could this be accomplished?

## b. References on Sorting and Ordering

Bell, D. A.: The Principles of Sorting, Computer J., vol. 1, no. 2, pp. 71, July, 1958.
Davies, D. W.: Sorting of Data on an Electronic Computer, Proc. IEE, vol. 103B suppl., p. 87.
Friend, E. H.: Sorting on Electronic Computer Systems, J. Assoc. Computing Machinery, vol. 3, p. 134, July, 1956.
Hosken, J. E.: Evaluation of Sorting Methods, Proc. Eastern Joint Computer Conf., 1955, p. 35.
Isaac, E. J., and R. C. Singleton: Sorting by Address Calculation, J. Assoc. Computing Machinery, vol. 3, p. 169, July, 1956.
Shannon, C. E.: A Mathematical Theory of Communication, Bell System Tech. J., vol. 27, pp. 379-423, 623-656, 1948.
c. References on Information Retrieval

Bracken, R. H., and H. A. Tillitt: Information Searching with a 701 Calculator, JAssoc. Computing Machinery, vol. 4, p. 131, 1957.
Dennis, Bernard K.: Rapid Retrieval of Information, Computers and Automation, October, 1958, p. 8.
Digital Computer Newsletter, vol. 10, no. 4, p. 4, October, 1958.

Fairthorne, R. A.: Automatic Retrieval of Recorded Information, Computer J., vol. 1, no. 1, p. 36, April, 1958.
Ledley, R. S.: TABLEDEX, A New Coordinate Indexing Method for Bound Book Form Bibliographies, Proc. Intern. Conf. Sci. Inform., Area V, 1958, Washington, D.C.

Luhn, H. P.: A Statistical Approach to Mechanized Encoding and Searching of Literary Information, IBM J. Research Develop., vol. 1, p. 309, 1957.
Mooers, C.: Putting Probability to Work in Coding Punched Cards, Zatocoding, Zator Tech. Bull. 3, 1947, Zator Company, Boston, Mass.; also Zatocoding and Development in Information Retrieval, Aslib. Proc., vol. 8, no. 1, pp. 3-22, February, 1956.

National Science Foundation Booklet, "Non-conventional Technical Information Systems in Current Use."
National Science Foundation Booklet, "Current Research and Development in Information Retrieval."
Office of Research and Development, U.S. Patent Office: "Patent Office Research and Development Reports," U.S. Department of Commerce.
Proc. Intern. Conf. Sci. Inform., Area V, 1958, p. 317.
Ray, L. C., and R. A. Kirsch: Finding Chemical Records by Digital Computers, Science, vol. 126, p. 814, 1957.
Shera, J. H., A. Hert, and J. W. Perry: "Information Systems in Documentation," Interscience Publishers, Inc., New York.
Waldo, W. H., and M. DeBacker:Printing Chemical Structures Electronically;Encoded Compounds Searched Generally with IBM 702, Proc. Intern. Conf. Sci. Inform., Area IV, 1958.
Wildhack, W. A., and J. Stern: "The Peek-a-boo System in the Field of Instrumentation," p. 209, Interscience Publishers, Inc., New York.
d. References on Error-detecting and -correcting Codes. The method given in this chapter for constructing error-correcting codes is essentially that of Irving S. Reed (see A Class of Multiple-error-correcting Codes and the Decoding Scheme, IRE Trans. on Inform. Theory, vol. IT-4, pp. 34-49, September, 1954). The initial theory was first stated in a well-known paper of R. W. Hamming (see Error Detecting and Error Correcting Codes, Bell System Tech. J., vol. 29, pp. 147-160, April, 1950). Many other papers have recently appeared in this field, and we list some of these below. It would be well to consider these papers after Part 3 of the text has been mastered.
Brown, A: B., and S. T. Myers: Evaluation of Some Error Correction Methods Applicable to Digital Data Transmission, IRE Conv. Record, vol. 6, pt. 4, pp. 37-55, 1958.
Elias, P.: Error Free Coding, IRE Trans. on Inform. Theory, vol. IT-4, pp. 29-38, September, 1954.
Golay, M.: Binary Coding, IRE Trans. on Inform. Theory, vol. IT-4, pp. 23-28, September, 1954.
Huffman, D.: A Linear Circuit Viewpoint on Error Correcting Codes, 1RE Trans. on Inform. Theory, vol. IT-2, pp. 20-28, September, 1956.
Peterson, W.: An Experimental Study of a Binary Code, Communs. and Electronics, July, 1958, pp. 388-392.
Sacks, G.: Multiple Error Correction by Means of Parity Checks, IRE Trans. on Inform. Theory, vol. IT-4, pp. 145-147, December, 1958.
Shannon, C. E.: General Treatment of the Problem of Coding, IRE Trans. on Inform. Theory, vol. IT-1, pp. 102-104, February, 1953.

Sec. 7-8] Searching, sorting, ordering, and codifying 255

Shapiro, H. S., and D. L. Slotnik: On the Mathematical Theory of Error-correcting Codes, IBM J. Research, January, 1958, pp. 25-34.
Slepian, D.: A Class of Binary Signaling Alphabets, Bell System Tech. J., January, 1956, pp. 203-234.
Ulrich, W.: Non-binary Error Correction Codes, Bell System Tech. J., November, 1957, pp. 1341-1388.
e. Irredundant Coding. To our knowledge Mooers [see the references in (c)] first discussed irredundant coding. Formulas that differ from those given in this chapter are found in C. S. Wise, Mathematical Analysis of Coding Systems, in R. S. Carey and J. W. Perry (eds.), "Punched Cards," chap. 20, Reinhold Publishing Corporation, New York, 1951. The formulas given by Wise are not precise. (Why?) Prove the formulas given in this chapter of our text by means of an exact analysis of the problem.

## CHAPTER 8

## SPECIAL-PURPOSE DIGITAL-COMPUTER SYSTEMS DESIGN

## 8-1. Introduction

Design for a Purpose. In previous chapters we have seen several examples of digital-computer systems design. Chapters 2 to 4 were primarily concerned with the systems design of a general-purpose digital computer; here some of the fundamental ideas of computer engineering were introduced. The general-purpose computer might be classified basically as a "scientific" computer well adapted to the processes of numerical analysis considered in Chap. 6. It appeared from Chap. 7, however, that the processes of searching, sorting, ordering, etc., made extensive use of the data-handling components of a computer and that perhaps special features could be designed into the computer that might considerably enhance its effectiveness. Similarly other types of computational problems that occur frequently may indicate still further special computational facilities. Some of these were mentioned in the illustrations given in Chap. 1.

In the present chapter we shall consider some of these special-purpose systems designs. Our intention is to free the student from the rigors of the general-purpose-computer systems design, which heretofore has held our attention. Our method is to use specially selected examples of systems designs ranging from those which differ radically from the generalpurpose computer to those built upon the extended general-purpose concept. It is our hope that such examples of computers-having no instruction systems at all, having temporary specialized memories, no arithmetic functions, great deviations from the conventional instruction format, and multiple code-handling capabilities-will present a broad view of the infinite possibilities that exist in digital-computer systems design.

This does not imply that there are no guiding signs to computer systems design. Quite the contrary, the unique features in a computer design should be determined solely by the intended purpose of the computer. Thus, in analyzing or describing a variety of different systems designs, we shall pay close attention to the purpose which indicated each such design.

Outline. We shall consider first the digital differential analyzer. This computer has no instruction system but rather consists of a collection of
computer units that are wired together as required by each particular problem. Next we shall consider a logical-control computer, using the control of a chemical factory as an example. Here a special "externalcontrol" instruction is introduced to facilitate the logical computations. A special design for a searching computer will then be considered. This special-purpose computer can be incorporated in a general-purpose computer as well. Business and logistics problems illustrate the need for special features enabling the handling of large arrays of numbers. Here a radically different instruction format is illustrated. Finally we consider the multiple-general-purpose computer, which is essentially an interlocked collection of computers, used in such a manner as will take greatest advantage of the special-purpose components of which it is comprised. In our illustration this multiple-purpose computer will be comprised of the computer components discussed in the previous sections.

## 8-2. The Digital Differential Analyzer

Purpose. Frequently it is necessary to compute the value of some function point by point. For example, in the automatic-milling-machine application described in Chap. 1, the computer attached to the milling machine must guide the tool from point to point along a predetermined path that was given only grossly at the input, e.g., a linear interpolation between two points or a circle of a certain radius. Similarly in many other control operations rapid calculations of $\sin \theta$ and $\cos \theta$ may be necessary, as in accurately sweeping an area with an antenna or in computing some functions. Not infrequently the familiar analog techniques cannot produce a sufficient number of significant figures for the accuracy required. In such cases one can use a digital differential analyzer as a small, relatively simple and inexpensive special-purpose digital computer.

The Concept of the Digital Differential Analyzer. The digital differential analyzer computes successive values of a function by means of successive differential additions. Consider the problem of computing a table of values for a function $y=f(x)$. If we start with a given $y\left(x_{0}\right)$, then $y\left(x_{1}\right)=y\left(x_{0}\right)+\left(y\left(x_{1}\right)-y\left(x_{0}\right)\right)=y\left(x_{0}\right)+(\Delta y)_{x_{0}}$. Similarly we write $y\left(x_{2}\right)=y\left(x_{1}\right)+(\Delta y)_{x_{1}}$, and so forth. In other words,

$$
y\left(x_{i+1}\right)=y\left(x_{i}\right)+(\Delta y)_{x_{i}}
$$

Now suppose that $y=e^{x}$. Then $d y=e^{x} d x=y d x$; or approximately

$$
(\Delta y)_{x_{i}}=y\left(x_{i}\right)\left(x_{i+1}-x_{i}\right)=y\left(x_{i}\right) \Delta x
$$

Thus we can compute successive approximate values of $e^{x}$ by

$$
y\left(x_{i+1}\right)=y\left(x_{i}\right)+y\left(x_{i}\right) \Delta x
$$

The smaller we make $\Delta x$, the more accurate our results will be. However, there is an obstacle here. Remember that multiplication produces a double-length result, so that, if $\Delta x$ is small enough, the major part of $y\left(x_{i}\right) \Delta x$ will be zero. Thus errors will result when the minor product, which contains the significant figures of $y\left(x_{i}\right) \Delta x$, is dropped. It would
therefore be better to work with the double-length extension of $y\left(x_{i}\right)$. However, this is not particularly desirable for what is supposed to be a small special-purpose computer.

The use of a double-length accumulator can be avoided; to find out how, let us examine our procedure more carefully. As we have noted, each time we form $y\left(x_{i}\right) \Delta x$ the major product is zero; but certainly the major part of $y\left(x_{i}\right)$ must change eventually. This must occur during the addition $y\left(x_{i}\right)+y\left(x_{i}\right) \Delta x$ and will be the result of a carry from the minor part into the major part. In other words, as we accumulate in the minor part, we eventually propagate a carry, or overflow, from the minor part into the major part of $y\left(x_{i}\right)$. If we are working in binary, the carry can only be a 1 and the major part of $y\left(x_{i}\right)$ can change at most by 1 during any iteration. Hence we do not need a double-length accumulator at all-we need a single-length accumulator that simply accumulates successive minor parts of $y\left(x_{i}\right) \Delta x_{i}$ and a counter that holds the major part of $y\left(x_{i}\right)$ and adds 1 to the major part of $y\left(x_{i}\right)$ each time there is an overflow from the minor accumulator. We call the accumulated minor parts the residual.

True multiplication is not essential in finding $y\left(x_{i}\right) \Delta x$, for we can always take $\Delta x=1 / 2^{q}$, and we need only shift $y\left(x_{i}\right)$ by $q$ positions to the right to form $y\left(x_{i}\right) \Delta x$. But since we do not have a major part to our accumulator, we can always choose $\Delta x$ so that the shifting of $y\left(x_{i}\right)$ need not have to occur actually (although of course it occurs virtually).

To illustrate these points, consider a 4-bit binary word and let $\Delta x=.0001$ (see Fig. 8-1). In Fig. 8-1 $a$ we have illustrated the accumulator that is to hold the residual and the counter that is to hold the major part of the function value $y$. The circle represents the component wherein $y$ is virtually but not actually shifted; this is simply a gate that at the proper time passes $y$ to be accumulated with the previous residual to form the new residual. The dash-dot lines represent the "true" juxtaposition of the double-length value of $y$. For our illustration, start with $x_{0}=0$, and $y_{0}=e^{0}=1$ preloaded into the counter. Then $y\left(x_{0}\right)=01.00$ and $y\left(x_{0}\right) \Delta x=00.000100$, where 0100 is the residual. Since

$$
y\left(x_{1}\right)=y\left(x_{0}\right)+y\left(x_{0}\right) \Delta x=01.000100
$$

the 01.00 remains unchanged in the counter and 0100 is put into the accumulator (see Fig. 8-1b). With $y\left(x_{1}\right) \cdot \Delta x=00.000100$ again, we have $0100+0100=1000$ as the residual, and 01.00 remaining still unchanged in the counter as $y\left(x_{2}\right)$. Then $y\left(x_{3}\right) \Delta x=00.000100$, whence $1000+0100=1100$ is the new residual and 01.00 remains unchanged as $y\left(x_{4}\right)$ in the counter. Next $y\left(x_{4}\right) \cdot \Delta x=00.000100$, whence $1100+0100=$ carry $1+0000$; now the counter is increased by 1 , putting 01.01 in the counter as $y\left(x_{5}\right)$ and leaving 0000 as the new residual. We continue with $y\left(x_{5}\right) \Delta x=00.000101$, and so forth. The result of each step and the graph of the function so calculated are shown in Fig. 8-1b.

Computing Units. The combination of accumulator, gate, and counter is called a computing unit of a digital differential analyzer. Many units


Fig. 8-1. Concept of the digital differential analyzer.
can be connected together to compute various functions. The contents of the accumulator, the residual, is denoted by $R$; the contents of the counter, the functional value, is denoted by $y$; the overflow, or carry, from the accumulator that steps the counter, i.e., the differential value that is to be added to some functional value, is denoted by $\Delta y$ (see Fig. 8-2). The gate may cause either addition or subtraction of the contents of the counter (virtually but not actually shifted) to the accumulator.


Fig. 8-2. Computing unit of digital differential analyzer.

As an example of how units can be combined, consider now the problem of computing $\sin x$ and $\cos x$. Let

$$
y_{1}=\cos x \quad \text { and } \quad y_{2}=\sin x
$$

Then the differential equations are
and

$$
d y_{1}=-\sin x d x=-y_{2} d x
$$

$$
d y_{2}=\cos x d x=y_{1} d x
$$

Thus we have

$$
y_{1}\left(x_{i+1}\right)=y_{1}\left(x_{i}\right)+\Delta y_{1} \quad \Delta y_{1}=-y_{2} \Delta x
$$

and

$$
y_{2}\left(x_{i+1}\right)=y_{2}\left(x_{i}\right)+\Delta y_{2} \quad \Delta y_{2}=y_{1} \Delta x
$$

Hence the arrangement shown in Fig. 8-3 will compute $y_{1}$ and $y_{2}$.
Programming. There are three steps to programming a problem: First, the proper differential equations must be worked out so that $\Delta y_{j}$ appears in the form $y_{i} \Delta x$. Second, the connections between units must be diagramed. And finally the scaling must be worked out. Consider


Fig. 8-3. Combinations of computing units of digital differential analyzer.
this latter step first. Note that, since the counter can be increased only by 1 at a time, then during any iteration $y$ can increase only by 1 . In other words, the graph of the function cannot be steeper than $45^{\circ}$. Thus in our example of Fig. 8-1 we could not compute $e^{x}$ for any greater values of $x$. However, the slope of any function can be adjusted by scaling so that it does not exceed $45^{\circ}$ within the range of computation.

Consider as another example the problem of computing the product $y_{3}=y_{1} y_{2}$. Since $d y_{3}=y_{1} d y_{2}+y_{2} d y_{1}$, we have
and

$$
\begin{aligned}
& y_{3}\left(x_{i+1}\right)=y_{3}\left(x_{i}\right)+\Delta y_{3} \quad \Delta y_{3}=y_{1} \Delta y_{2}+y_{2} \Delta y_{1} \\
& y_{2}\left(x_{i+1}\right)=y_{2}\left(x_{i}\right)+\Delta y_{2} \\
& y_{1}\left(x_{i+1}\right)=y_{1}\left(x_{i}\right)+\Delta y_{1}
\end{aligned}
$$

Hence the configuration of Fig. $8-4$ will compute $y_{3}=y_{1} y_{2}$. Note that the counter for $y_{3}$ has two inputs and that these must be electronically arranged so that they do not step the counter at precisely the same time.


FIG. 8-4. Computing $y_{3}=y_{1} y_{2}$.
Note also that not all of the computing unit for $y_{3}$ is used. Another feature of this arrangement is that the inputs to the gates are not a single $\Delta x$, but rather $\Delta y_{1}$ and $\Delta y_{2}$ themselves.
Next consider the computation of $y=x^{2}$. Here $d y=2 x d x$ and $y\left(x_{i+1}\right)=y\left(x_{i}\right)+\Delta y, \Delta y=2 x_{i} \Delta x$; Fig. 8-5 shows the arrangement. Here


Fig. 8-5. Computing $y=x^{2}$.
note that one of the counters is loaded with the constant 2 and never changes.

Finally consider the computation of $y=1 / x$, that is, division. Here $d y=\left(-1 / x^{2}\right) d x$; letting $w=-1 / x^{2}$, we find $d y=w d x$ and

$$
d w=\frac{2}{x^{3}} d x=-\frac{2}{x}\left(-\frac{1}{x^{2}} d x\right)=-2 y d y
$$

Thus

$$
y\left(x_{i+1}\right)=y\left(x_{i}\right)+\Delta y \quad \Delta y=w \Delta x
$$

and

$$
w\left(x_{i+1}\right)=w\left(x_{i}\right)+\Delta w \quad \Delta w=-2 y \Delta y
$$

The arrangement of units for this computation is left as an exercise

Advantages. The digital differential analyzer does not require an instruction system or a stored program, for the "programming" is accomplished simply by appropriately wiring units together. Thus no control unit is necessary, and the computer is very inexpensive. Of course it is correspondingly quite limited in its capabilities.

The accumulator and the counter require storage, and for this a drum is frequently used. For example, each band around the drum might be divided into two words of storage, one for the accumulator and the other for the counter, of a single computing unit. The inputs and outputs from the heads of each band would be brought to a plugboard console. Here the gate and counter inputs and the accumulator (overflow) outputs for each of the units could be appropriately connected by "jumpers."

## EXERCISES

(a) Compute $\sin x$ and $\cos x$, and graph the results as they would be computed by a digital differential analyzer (see, for example, Fig. 8-1). If the word length were 4 bits, how would the problem be scaled?
(b) Draw the arrangement of units to compute $y=1 / x$.
(c) Draw the arrangement of units to compute $y=\ln x$. [Hint: $d y=(1 / x) d x$. Let $w=1 / x$; then $d y=w d x$, and $d w=\left(-1 / x^{2}\right) d x=-w d y$.]
(d) Draw the arrangement of units to compute $y=x^{n} . \quad$ (Hint: $d y=n x^{n-1} d x=$ $\left.x^{n}[(n / x) d x]=x^{n} d(n \ln x)=y d(n \ln x).\right\}$
(e) Draw the arrangement of units to solve the following simultaneous differential equations:

$$
\frac{d y_{1}}{d x}=\lambda_{12} y_{2}+\lambda_{13} y_{3} \quad \frac{d y_{2}}{d x}=\lambda_{21} y_{1}+\lambda_{23} y_{3} \quad \frac{d y_{3}}{d x}=\lambda_{31} y_{1}+\lambda_{32} y_{2}
$$

( $f$ ) How can a digital differential analyzer be used in conjunction with machine-tool control (see Chap. 1)?

## 8-3. Real-time Logical Systems Control: A Real-time Control Computer

An Example. Very often the primary function of an on-line digital control system (i.e., a system connected to a dynamic process) is to make sequences of logical decisions that depend on the state of certain variables associated with the world external to the computer. Here we shall consider the special-purpose systems design of a real-time logical-control computer and show how it might be applied in a specific example of controlling a chemical factory. By discussing first the specific application, the reasons for the various aspects of the control computer will be better appreciated. Although the example is concerned with the control of a chemical factory performing a specific chemical process, the situation is conceptually similar in almost all such real-time control problems as may occur in other types of automatic factory control, in tactical gunnery control, or in distributing tracking data to command centers according to predetermined strategies. The example also contains a feedback loop by which the results of the input digital disposition influ-
ence the outside world, which in turn again influences the input to the computer.
Figure 1-10 on page 12 shows the flow chart of a chemical factory manufacturing $\mathrm{Al}_{2} \mathrm{O}_{3}$. Briefly, clay is mixed with water and a detergent to make a wash containing the raw material. A certain amount of this wash is tapped off into an evaporation tank, where it is concentrated by evaporation. Then in another tank HCl gas is mixed with the wash until it is saturated. The wash is centrifuged and a precipitate of $\mathrm{AlCl}_{3} \cdot 6 \mathrm{H}_{2} \mathrm{O}$ is obtained. The precipitate is decomposed, by heating, into gaseous HCl , which is reused, and into solid $\mathrm{Al}_{2} \mathrm{O}_{3}$, the desired end product. It is of course understood that, even though this problem is based on an

actual process, it has here been grossly oversimplified and actually stylized. It is not meant to be examined from a chemical-engineering point of view, since many details of both the necessary conditions and desired results are but casually indicated.

The state of the chemical factory is given by 16 signals, listed in Table 8 -1. The computer periodically senses these signals, generating from them 12 control signals that direct the future state of the factory. The future state of the factory results in changes of the input signals, whence new control signals are generated by the computer, and so forth. Table $8-2$ gives the relation between the sensed-signal conditions and the necessary control signals to be generated. A symbolic notational form for each statement is also given, where $\cdot$ means and and - means not (i.e., no signal).

Programming Logical Control. The computer will have one subroutine for each set of the control signals to be generated. Hence a jump table is required to initiate the proper subroutine for a given state of the sensed signals. However, we need an input to the jump table that tells which

Table 8-2. Control Signals

| Sensed-signal conditions | Symbolic representation | Corresponding signals to be generated |
| :---: | :---: | :---: |
| 1. Level is at $L(1)$, and concentration test is bad, and time for testing is due | $L(1) \cdot \bar{C} \cdot T(C)$ | Throw away solution by opening valve 3 , and add clay, detergent, and water in tank 1 by opening hatch 1 , valves 1 and 2 |
| 2. Level is at $L(1)$, and concentration test is good, and time for testing is due, and tank 2 is empty | $L(1) \cdot C \cdot T(C) \cdot E(2)$ | Tap off certain amount of fluid into tank 2 by means of valve 4 |
| 3. Level $L(1)$ has not been reached, and valve 4 is not open | $\bar{L}(1) \cdot \bar{V}(4)$ | Add detergent, water to tank 1 by opening valves 1 and 2 |
| 4. Valve 4 is not open, and level is $L(2)$, and tank 3 is empty | $\bar{V}(4) \cdot L(2) \cdot E(3)$ | Transfer fluid to tank 3 by opening valve 5 |
| 5. Temperature is $T(1)$, and tank 3 is full, and valve 7 is off | $T(1) \cdot F(3) \cdot \bar{V}(7)$ | Cut rate of HCl flow to slow by closing valve 6 |
| 6. Temperature is $T(2)$, and tank 3 is full, and valve 7 is off | $T(2) \cdot F(3) \cdot \bar{V}(7)$ | Increase rate of HCl flow to fast by opening valve 6 |
| 7. Saturation test is good, and valve 7 is closed, and centrifuge is empty | $S \cdot \bar{V}(7) \cdot E(C)$ | Close flow of HCl by means of valve 6, transfer fluid to centrifuge by valve 7 , and start centrifuge |
| 8. Centrifuge finished. | $C(F)$ | Put precipitate in furnace by opening hatch 2 , throw away wash by opening valve 8 |
| 9. Pressure of HCl high | $P$ | Lower heat of furnace |
| 10. Weight is enough | W | Take out resultant $\mathrm{Al}_{2} \mathrm{O}_{3}$ by opening hatch 3 |

jump instruction to use, and we shall first describe how this input may be accomplished.

At any instant the bits in the signal-sensing word (Fig. 1-10) tell which signals are on and which are off. For instance, the word might be as in Table 8-3; in the table under each bit of the word is shown the state of the corresponding signal. We can similarly use a word for each of the significant sensed-signal conditions of Table 8-2, so that the conditions can

Table 8-3. Example of Signal-Sensing Word

be matched with the state of the sensed signals at any time. For example, the first condition, $L(1) \cdot \overline{\mathrm{C}} \cdot \mathrm{T}(\mathrm{C}) \cdots$, would be represented by 101 . . . . But what about the rest of the bits? Condition L(1). $\overline{\mathbf{C}} \cdot \mathbf{T}(\mathrm{C})$ does not mention the rest of the signals because for that condition they make no difference. They are to be ignored. Thus we need another


Fig. 8-6. Flow chart of real-time operating program.
word that tells what positions are to be considered and what positions are to be ignored. This second word will have units corresponding to bits that are to be considered and zeros corresponding to bits to be ignored. For example, $\mathrm{L}(1) \cdot \overline{\mathbf{C}} \cdot \mathrm{T}(\mathbf{C})$ is denoted by the following two words:

| 1st word: | $101 x$ | $x x x x$ | $x x x x$ | $x x x x$ |
| :--- | :--- | :--- | :--- | :--- |
| 2d word: | 1110 | 0000 | 0000 | 0000 |

where the $x$ means that it makes no difference whether the bit is zero or unit. Similarly the fourth condition, $\bar{V}(4) \cdot L(2) \cdot E(3)$, is denoted by

| 1st word: | $x x x 0$ | $1 x x x$ | $x x 1 x$ | $x x x x$ |
| :--- | :--- | :--- | :--- | :--- |
| 2d word: | 0001 | 1000 | 0010 | 0000 |

There would then be two words representing each of the 10 conditions of Table 8-2.

Figure 8-6 is a flow chart of a real-time operating program that will compare each of the conditions with the sensed-signal word until a favorable comparison is obtained; then, depending on which condition compared favorably, a jump will be made to the proper signal-generating subroutine. After completing the subroutine, a new sensed-signal word will be called into the high-speed memory, and the process will start over. If no condition compared favorably, the program would call in a new sensed-signal word and repeat the comparisons, and so forth.


Fig. 8-7. Real-time logical-control computer.
Systems Design of a Special-purpose Logical-control Computer. When hundreds of signals must be sensed, as would occur in a more realistic case, it may be more efficient to have the two extractions and comparison made in one step by a special computer instruction, which we shall call an external-control instruction. Such an instruction would have three inputs: the sensed-signal word and the first and second condition words. If the comparison is unfavorable, the instruction would automatically increase a relative counter. This instruction would repeat itself as the next instruction. The addresses of the two condition words are taken relative to this counter so that they are automatically modified appropriately for the next condition when the external-control instruction repeats itself. If the comparison is favorable, the next instruction is taken from the address of the external-control instruction plus the counter reading; i.e., the external-control instruction would be followed by the
jump table. The method by which the comparisons are repeated is left as an exercise (see Exercise a).

For a permanent installation the subroutines generating the control signals can be wired in. Hence the real-time logical-control computer need contain little more than the external-control instruction, an instruction to clear the relative counter, a comparison instruction, a jump instruction, and an add instruction (see Fig. 8-7).

Since the program will not often be changed, it can be inserted into the computer by means of the control panel; therefore no input-output equipment is necessary except the signal-sensing word and the wired control-signal generator. The memory of such a special-purpose computer need be only a little larger than necessary to accommodate the condition words. The speed of the memory need only be fast compared with the feedback reaction time of the system it is controlling. For the chemical factory here described this need not be particularly fast; for a tracking system it must be very high-speed.

## EXERCISES

(a) How would the external-control instruction break the loop when no comparison is successful? (Hint: A dummy comparison would automatically compare favorably. How would this dummy comparison be arranged, i.e., what would be the first and second words of the dummy condition?)
(b) Suppose that the input word to a real-time logical-control computer has the following inputs (see Fig. 8-8): tank 1 full, L(1); tank 2 full, L(2); valve 1 open, V(1);


Fig. 8-8. Simple system controlled by real-time logical-control computer.
valve 2 open, $\mathrm{V}(2)$; valve 3 open, $\mathrm{V}(3)$. For the output or control-signal word let $O(1)$ mean open valve $1 ; O(2)$, open valve $2 ; O(3)$, open valve (3); $C(1)$, close valve 1 ; $\mathrm{C}(2)$, close valve 2 ; and $\mathrm{C}(3)$, close valve 3 . Define an appropriate instruction, including an external-control instruction, for the logical-control computer as discussed above, and code the process of filling the two tanks, one at a time.
(c) Code the problem used in (b) without the use of an external-control instruction.

## 8-4. Systems Design for Special-purpose Information-retrieval Computer

An Example. The occasion may frequently arise where a specialpurpose searching, sorting, and ordering computer becomes feasible. As a specific example of the use of such a computer, which will indicate the motivation for its systems design, consider a cost-accounting system in a factory. Each workman in the factory is given a job; he procures supplies and parts; he spends time using the supplies and assembling the parts to produce some final object; then he may be given another job (which may be a repetition of the first), etc. The executives and accountants of the factory would like to know how many objects of each type have been completed, how many supplies and how many parts were used during a particular period of time, how many hours a particular workman spent on a particular job, how many man-hours altogether were spent in making a certain number of these objects, and so forth. The description given here of a cost-accounting system is necessarily oversimplified, but the basic principles and concepts are the same.
Suppose that each procurement of supplies and parts, each object completed, the time consumed in each job, etc., were recorded by part number, workman's name, job number, date, and so forth, at the time the action was taken or the job completed; suppose that all this information for 1 week could be compiled on a single magnetic tape. The problem then reduces to searching, sorting, and ordering the items on the tape to answer the above questions. In general a computer that can perform these operations need be capable only of comparing, counting, and accumulating. Whether or not such a special-purpose computer is feasible depends on its cost and on the time it takes to process the necessary number of data.

A Small Retrieval Computer. Let us suppose that any item can be recorded in 50 characters or less (a character being 6 bits). Then the computer will first read a set of 50 characters into the temporary storage, a nonending loop of tape (see Fig. 8-9). Selected characters will be appropriately compared with characters from the previously loaded argument storage, a second loop of tape. Depending on the outcome of this comparison, the computer may then add into a partial sum in the accumulator some number represented by certain of the 50 characters, or may increase the count of the counter, and so forth. Actually several sets of 50 bits may be recorded in the temporary storage unit. When writing back onto the magnetic tape, the computer can transpose sets if it is ordering the information, or can insert new information, and so forth. In summary, successive items from the magnetic tape are stored temporarily in the computer; here information is extracted from them, or they are otherwise processed; then they are replaced on the magnetic tape, perhaps in some transposed order. The processing is done in conjunction with information preloaded on the argument storage unit.

The number of instructions to be written into a program will be limited to the number of instructions that can be executed from the time


Fig. 8-9. Small retrieval computer.
an item is read from the tape until it is put back again. The instruction system can be very simple. Suppose that the instructions were punched on cards and the cards for one program put into slots in the control unit, where the holes on the cards can be sensed. The arguments on the argument-storage-unit tape loop, which are fixed during any program, can also be addressed. The instruction format could be as shown in Fig. 8-10. Each instruction is concerned with selected characters, as recorded on the cards, of the current item in the temporary storage unit. An instruction may involve two of the arguments of the argument storage unit if, for example, a search for characteristics less than $\alpha$ but greater than $\beta$ is desired. A two-way exit, $\gamma$ or $\delta$ depending on the outcome of the comparisons, is allowed for flex-


Fig. 8-10. Instruction format. ibility in coding. Consider as an illustration the computation of the number of hours in a week that workman 1224 required to make part 2746 and the number of parts he completed in that week. Suppose that 40 was the code for an item recording a finished job. The instructions would compare the properly selected characters of each item with 1224 , and 2746 , and 40 . When an "equal" comparison was made, the computer would add 1 to the counter and add
the number of hours recorded on this item to the accumulator. If an equal comparison was not made, the computer would just replace the item on the tape. By this means the total number of man-hours worked in making a particular object during any specified time period can be determined in one pass through the tape. Similarly the number of manhours that were worked by a certain person, or in a certain shop, etc., or the number of a certain part that were consumed, or the amount of a certain material that was used, in any shop or by any person, in making a particular object, during a specified time, can be determined in a single pass, and so forth. Suppose that the magnetic tape runs at a rate of $100,000 \mathrm{bits} / \mathrm{sec}$, i.e., about 17,000 characters $/ \mathrm{sec}$ ( 6 bits $=1$ character), or $350 \mathrm{items} / \mathrm{sec}$ ( 50 characters $=1 \mathrm{item}$ ), or $21,000 \mathrm{items} / \mathrm{min}$. Suppose also that there are 500 workmen in the factory, each generating an average of $5 \mathrm{items} /$ day, or a total of $2,500 \mathrm{items} /$ day, or $50,000 \mathrm{items} /$ month ( 20 working days $=1$ month). One pass through the tape containing 1 month's items would take approximately 2 min and 22 sec . Comparison with more conventional bookkeeping methods is hardly


Fig. 8-11. Special-purpose computer attached to general-purpose computer.
necessary. On the other hand, if we were to run a standard payroll calculation on the man-hours worked for each of the 500 men, it would take $(500 \mathrm{men})(2 \min 22 \mathrm{sec})=20 \mathrm{hr}$. Also we have not mentioned the input and output equipment problem, which in the case of payroll, for instance, is a subject in itself.

Integration with a General-purpose Computer. In order to increase the working speed of this type of computer, we can enlarge the argument storage unit and include more accumulators and counters to accommodate more than one comparison, so that in one pass several pieces of information can be accumulated; or we can run several tapes in parallel, and so forth. The time per information pass can thus be decreased by a factor of 10 or 100 , that is, to within 20 , or even 2 , sec. This would increase the complexity and hence the cost of the computer. Finally we can attach our special-purpose searching, sorting, and ordering computer to a gen-eral-purpose computer, enabling more complicated processing to be accomplished as well as more automatic operation (see Fig. 8-11). In such a case the tapes can be searched at the same time as the generalpurpose computer computes other things. The fixed card memory of the special-purpose computer will be replaced by a part of the high-speed memory shared with the general-purpose computer. Two codes will be written, one for the computing unit of the general-purpose computer, the other for the simple arithmetic unit of the special-purpose computer.

An interlocking buffer must be designed so that the general-purpose computer will stop and wait if it needs some information not yet retrieved from the special-purpose auxiliary computer, and so that the searching computer will stop and wait if it in turn needs information not yet generated by the general-purpose computer. An auxiliary computer for this special purpose can be exceedingly effective and timesaving when large amounts of this kind of nonnumerical manipulative computing are necessary.

## EXERCISE

(a) Suppose that a factory item is composed of the following word,

where each box can be filled with a digit or an alphabetic character. Define an instruction system for a special-purpose retrieval computer as shown in Fig. 8-9, and write a code that will determine how many objects of type 54321 were completed between Mar. 3, 1959, and Mar. 15, 1959.

## 8-5. Manipulations with Rectangular Arrays: A Business and Logistics Computer $\dagger$

The Need. An important class of computations occurring frequently in business and in logistics (i.e., processes involved in supply) is concerned with rectangular, matrixlike arrays of variables. The operations to be performed on the variables are usually very simple, the main problem being the manipulations necessary for handling such large-scale arrays. In this section we shall first indicate some applications of these techniques; we shall then show how a few relatively simple specialpurpose instructions can significantly aid these processes; and finally we shall discuss a special-purpose computer especially designed to perform manipulations with rectangular arrays.

As a first example, consider the keeping and updating of a spare-parts inventory. Suppose for simplicity that there are 10 parts under consideration and that the first row of the array in Table 8-4 represents the desired inventory for each of the 10 parts-i.e., there should be 100 each of the parts in stock. The second row represents the actual stock level of each of the parts at time $t$. Now let us suppose that the parts are consumed in the course of three kinds of overhauls and that the number of parts used for one of each kind of overhaul appears on lines 4,5 , and 6 , respectively. Now suppose that since time $t$ there were one overhaul of kind 1, two overhauls of kind 2, and three overhauls of kind 3. The
$\dagger$ The main concepts discussed in this section are based on the original research of Dr. W. H. Marlow, principal investigator of The George Washington University Naval Logistics Research Project.
problem is to determine the present stock levels, i.e., to adjust row 2 , and to determine how many of each part should be ordered in order to have the desired number of spare parts on hand, i.e., to determine row 3 . To take account in the inventory levels of the parts used for the overhaul of kind 1 , subtract row 4 from row 2, column by column; for the two

Table 8-4. Data Array for Inventory-updating Problem

|  | Part | Part | Part | Part | Part | Part | Part | Part | Part | Part |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| Row 1, desired inventory. | 100 | 100 | 100 | 100 | 100 | 100 | 100 | 100 | 100 | 100 |
| Row 2, stock on hand (time $t$ ). | 80 | 75 | 90 | 80 | 95 | 90 | 85 | 95 | 70 | 75 |
| Row 3, parts to order... |  |  |  |  |  |  |  |  |  |  |
| Row 4, overhaul kind 1, parts used. | 5 | 15 | 5 | 10 | 5 | 0 | 0 | 5 | 10 | 5 |
| Row 5, overhaul kind 2, parts used. | 10 | 0 | 0 | 10 | 10 | 20 | 15 | 5 | 10 | 0 |
| Row 6, overhaul kind 3, parts used | 5 | 0 | 10 | 10 | 5 | 10 | 15 | 20 | 0 | 5 |

overhauls of kind 2 multiply each figure in row 5 by 2 , and subtract the result from row 2 , column by column; and similarly form

$$
\text { Row } 2-3 \times(\text { row } 6)
$$

We thus obtain the present stock levels in row 2:

$$
\begin{array}{llllllllll}
40 & 60 & 55 & 20 & 55 & 20 & 10 & 20 & 40 & 55
\end{array}
$$

Subtracting row 2 from row 1 and putting the results in row 3 , column by column, we obtain the number of parts to order of each type. Of course many other related problems can be similarly solved; e.g., we may record the usage of parts in each time period and then extrapolate column by column to predict usages in the future, and so forth. We have used only 10 different parts, but in realistic cases thousands of parts may be involved.

Another example is the calculation of building-material purchase schedules and requirements as functions of time, as would be needed in the construction of a ship or of a large office building. An array can be made of the materials needed at the construction site as a function of time. That is, successive rows of the array will represent successive times, and the columns of the array will represent the various building materials; then an element in the array will indicate how much of a certain building material is needed at the building site at a particular time. However, there is a certain time lag that must be allowed for the delivery of each of the materials from the time it is ordered. This time lag differs for different materials and can be represented as a row of the array. The problem here is to schedule the orders so that the materials
will arrive at the site at the proper time. In addition the costs of the materials per unit can be represented in another row. If the materials are paid for at the time they are ordered, then a calculation should be made as to how much money will be spent during each time period. This calculation can be made after the ordering schedules are set by multiplying the number of units to be ordered in a time period (i.e., a row) by the cost of each per unit and summing over the elements of the resulting row, i.e., adding the columns of that row independently.

The keeping of bank accounts presents similar array-manipulation problems. Here suppose that each row contains the balance of each of the savings accounts for successive weeks and that interest is computed monthly, based on the minimum weekly balance. Here the minimum of the rows each month must be obtained and the interest rate applied to each account (i.e., each column of the minimum record row). If the bank desired to know the total deposits each week, the row for each week is totaled. In this way calculations of interest, principal, penalties, interest rates, and other banking problems can be made.

Military and nonmilitary dynamic-operations simulation studies can involve these processes. For example, consider air-traffic control (in three dimensions). Three rows can record the $x$ and $y$ coordinates and altitudes, respectively, of the aircraft represented by the successive columns. If the $x$ and $y$ velocity components are known, the coordinates of the aircraft can be predicted in time and aircraft that may be flying too close appropriately warned. When changes in course are made, recalculations of predicted positions of all the aircraft become easy.

Of course, we could describe above only the simplest of applications. Our intention is to stimulate the reader's awareness of the great variety of fields in which problems arise that involve the manipulations of large arrays. Although a general-purpose computer can handle such problems, special-purpose computers can fulfill the need much more effectively and efficiently. We shall now describe some special-purpose operations that would be incorporated into such a computer.

Basic Operations and Instruction Format. With the above examples in mind the reasons for the definitions of the following basic manipulatory operations are clear. In fact it is quite surprising that these few simple operations can accomplish the task so well. The instructions that we shall illustrate contain the necessary ingredients, although their form in actual practice may vary greatly. It is felt that a concrete example may best serve to demonstrate the concepts.

Since we are concerned primarily with arrays of numbers, i.e., with numbers arranged in rows and columns, suppose that we literally arrange these numbers in such an array in the computer's memory. Figure 8-12 represents such an arrangement on a drum memory. Then in order to "address" a particular number, all we need specify is its row and column. For reasons that will presently appear clear, we denote the number in row $j$ and column $x$ by the following functional notation: $f_{j}(x)$. See, for example, Table 8-5.

Column


Fig. 8-12. Arrays of numbers stored on drum memory.
The address of $f_{j}(x)$ is thus specified by the pair of indices: $j, x$. We use the phrase generalized address because the instruction actually indicates a collection of addresses in the manner now to be described. Consider a multiplication instruction. Rather than form the product of just two numbers, $f_{i}(x) \cdot f_{j}(x)$, we wish now, with a single instruction, to form a whole row of successive column-by-column products, that is,

Table 8-5. Notation of the Array

|  | Column $x$ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 |  | $p$ |  | $q$ |  | $n$ |
| 0 | $f_{0}(0)$ | $f_{0}(1)$ | $f_{0}(2)$ | . | $f_{0}(p)$ | $\cdots$ | $f_{0}(q)$ |  | $f_{0}(n)$ |
| 1 | $f_{1}(0)$ | $f_{1}(1)$ | $f_{1}(2)$ | . . | $f_{1}(p)$ | $\cdots$ | $f_{1}(q)$ |  | $f_{1}(n)$ |
| 2 | $f_{2}(0)$ | $f_{2}(1)$ | $f_{2}(2)$ |  | $f_{2}(p)$ |  | $f_{2}(q)$ |  | $f_{2}(n)$ |
| $i$ | $f_{i}(0)$ | $f_{i}(1)$ | $f_{i}(2)$ |  | $f_{i}(p)$ | - . | $f_{i}(q)$ |  | $f_{i}(n)$ |
| $j$ | $f_{j}(0)$ | $f_{j}(1)$ | $f_{j}(2)$ |  | $f_{j}(p)$ |  | $\stackrel{\cdot}{f_{j}(q)}$ |  | $f_{i}(n)$ |
|  |  |  |  |  |  |  | . . |  | . |
| $m$ | $f_{m}(0)$ | $f_{m}(1)$ | $f_{m}(2)$ |  | $f_{m}(p)$ | $\cdots$ | $f_{m}(q)$ |  | $f_{m}(n)$ |

$f_{i}(1) \cdot f_{j}(1)$, and $f_{i}(2) \cdot f_{j}(2)$, and $f_{i}(3) \cdot f_{j}(3)$, and so forth. We might represent this as the operation $f_{i}(x) \cdot f_{j}(x)$ for $x=1,2,3, \ldots$ To add a little more flexibility to the operation, we might form, with a single instruction, $f_{i}(x) \cdot f_{j}(x)$ for $p \leq x \leq q$, that is, the successive products for only the columns $p$ through $q$. For example, if $i=1, j=2, p=5$, and $q=8$ we would form (see Table 8-6)

$$
f_{1}(5) \cdot f_{2}(5) \quad f_{1}(6) \cdot f_{2}(6) \quad f_{1}(7) \cdot f_{2}(7) \quad \text { and } \quad f_{1}(8) \cdot f_{2}(8)
$$

Thus the multiplication instruction must now contain the row indices $i$ and $j$, and the column indices $p$ and $q$; this collection of indices represents the so-called "generalized addresses." Suppose that we wish the results to be placed in row $k$ of the corresponding columns $p$ to $q$; then the index
$k$ must also appear in the instruction. Thus $i, j$, and $k$, together with $p$ and $q$, represent the generalized $\alpha, \beta, \gamma$, and $\delta$ addresses, and all these indices must appear in the instruction format itself.

Table 8-6. Illustration of Operation $f_{1}(x) f_{2}(x), 5 \leq x \leq 8$

|  | Column |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| Row 1. | 9 | 7 | 8 | 6 | 1 | 5 | 2 | 4 | 3 | 1 |
| Row 2. | 6 | 2 | 5 | 1 | 0 | 3 | 4 | 8 | 7 | 2 |
| Row 3. |  |  |  | . | . . | 15 | 8 | 32 | 21 |  |

A description of the fourth generalized address, that of the next instruction, requires reconsideration of the drum memory. An instruction would appear as a partial row of numbers and can be recorded along with the data on the drum. For greatest efficiency a row length on the drum should be a multiple of an instruction length. To address the part of a row that is an instruction, only the row and column of the first number of the instruction need be known, since the length of the instruction is fixed by the instruction format (see below). Let us denote the row and column number of the first characteristics of an instruction by $\delta_{r}$ and $\delta_{c}$, respectively. These must also appear in each instruction word.

There are several other considerations that can lead to greater flexibility in our instruction format. First suppose that we desired to form $C \cdot f_{i}(x) \cdot f_{j}(x)$ (for $p \leq x \leq q$ ), where $C$ is a constant. Since this is frequently desired (e.g., interest and discount rates), it is convenient to include the constant $C$ in the instruction format itself, rather than address it separately. Second, observe that so far we can work on the different rows within the same column but we cannot have a number in one column affect a number in another column. Thus, for example, the product $f_{i}(x) \cdot f_{j}(x)$ becomes $f_{k}(x)$ in the same column. To circumvent such a restriction, it suffices to introduce into the instruction format the alternative of placing the result of the operation in corresponding columns in the $k$ th row, or of placing the result one column to the left in the kth row, i.e., displaced one column. That is, one may choose to have the product $f_{i} \cdot(x) \cdot f_{j}(x)$ become $f_{k}(x)$ or $f_{k}(x-1)$. Finally recall that $(\gamma)$ is usually replaced by the result of the operation. However, great flexibility results if there is introduced into the instruction the alternative of either replacing ( $\gamma$ ) or else accumulating (adding) the results of the operation to the original contents of $\gamma$. As an example, suppose that, given the initial rows 1,2 , and 3 of Table 8-7, we formed $f_{1}(x) \cdot f_{2}(x)$, for $5 \leq x \leq 8$ (that is, $i=1, j=2, p=5, q=8$ ), and accumulated the result in row 3 , displaced. Then we would have

$$
f_{3}(x-1) \text { final }=f_{1}(x) \cdot f_{2}(x)+f_{3}(x-1) \text { initial }
$$

for $5 \leq x \leq 8$ (see Table 8-7).

Table 8-7. Illustration of Operation $f_{1}(x) f_{2}(x), 5 \leq x \leq 8$, Placed in Row 3 Displaced by One Column, and So as to Accumulate

|  | Column |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| Row 1. | 9 | 7 | 8 | 6 | 1 | 5 | 2 | 4 | 3 | 1 |
| Row 2. | 6 | 2 | 5 | 1 | 0 | 3 | 4 | 8 | 7 | 2 |
| Row 3, initial | 3 | 2 | 4 | 6 | 2 | 1 | 5 | 3 | 2 | 6 |
| Row 3, final. | 3 | 2 | 4 | 6 | 17 | 9 | 37 | 24 | 2 | 6 |

With these considerations in mind we can represent an instruction format as:

| Operation <br> code | Row $i$ | Row $j$ | Row $k$ | $p$ | $q$ | Displaced <br> or not | Accumulated <br> or not | $C$ | $\delta_{r}$ | $\delta_{c}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |

We shall use the convention that 1 means displace, 0 means do not, and that 1 means accumulate, 0 means do not, in their respective columns. The instruction that will produce the final result shown in Table 8-7 is:

| Operation | $i$ | $j$ | $k$ | $p$ | $q$ | Displace | Accumulate | $C$ | $\delta_{r}$ | $\delta_{c}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Multiply | 1 | 2 | 3 | 5 | 8 | 1 | 1 | 1 |  |  |

We are now ready to define seven basic operations, where the column-by-column disposition of each type of result is understood to be in accord with the above discussion, and where only the column-by-column operations on the arguments need be given.

1. Multiplication

$$
C f_{i}(x) \cdot f_{j}(x) \quad p \leq x \leq q
$$

2. Division

$$
\frac{C f_{i}(x)}{f_{j}(x)} \quad p \leq x \leq q
$$

3. Linear combination

$$
C f_{i}(x)+f_{j}(x) \quad p \leq x \leq q
$$

4. Minimum

$$
\min _{i, j}\left[f_{i}(x), f_{j}(x)\right] \quad p \leq x \leq q
$$

The final three instructions require some additional explanation:
5. Displaced linear combination $C f_{i}(x-1)+f_{j}(x)$. Here the addition is not performed column by column, but rather displaced column by column. Of course, it is always understood that $p \leq x \leq q$, but then, when $x=p$ and $p=0$, the meaning of $f_{i}(0-1)$ is undetermined. We therefore define $f_{i}(0-1)=f_{i}(0)$.
6. Partial scalar product $\sum_{\mu=p}^{x} C \cdot f_{i}(\mu) \cdot f_{j}(\mu)$. This defines one result for each $x$ such that $p \leq x \leq q$. For example, if row $i$ and row $j$ were:

|  | Column |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 |
| Row $i \ldots \ldots \ldots \ldots$ | 7 | 6 | 5 | 4 | 3 | 2 |
| Row $j \ldots \ldots \ldots \ldots$ | 2 | 3 | 4 | 5 | 6 | 7 |

and $p=2$ and $q=5$, then the results would be
$5 \times 4=20 \quad 5 \times 4+4 \times 5=40 \quad 5 \times 4+4 \times 5+3 \times 6=58$
and

$$
5 \times 4+4 \times 5+3 \times 6+2 \times 7=72
$$

7. Compare $\left(\min _{p \leq x \leq q}\left[f_{i}(x)\right]\right): C$. This operation does not yield a column-by-column result; rather it is a two-way exit. If the minimum number in row $i$, columns $p$ to $q$, is greater than $C$, then the next instruction is to be taken as the instruction that has row $j$, column $k$ as the address of its first number; otherwise, i.e., if $\min \left[f_{i}(x)\right] \leq C$, the next instruction is to be chosen as usual, from $\delta_{r}, \delta_{c}$. Of course displace and accumulate have no meaning for a compare instruction.

Illustrations of Coding. As a first illustration of using these specialpurpose instructions in writing codes, consider the problem of accumulating the amounts within each column, from row $i_{0}$ to row $i_{0}+h$, putting the results into row $i_{0}+h$. Suppose for simplicity that the drum has 22 columns (just twice the instruction length) and that the code is written in address 0,$0 ; 1,0 ; 2,0$; etc. The code will make use of operation 3, with $C=1$, not accumulating the results of summing $i$ and $i+1$. (Why?) Then a compare instruction will occur for the tally, and the iterations will proceed by adding 1 to the generalized addresses $i, j$, and $k$ of the first instruction until the accumulation is completed. Since the first instruction is updated on each iteration, its $i$ address can be used as the tally. The code appears in Table 8-8.

As a second example, consider a linear extrapolation. Suppose that each column represented an aircraft and that rows $x_{1}, y_{1}$, and $t_{1}$ represented the $x$ and $y$ coordinates of each aircraft at time $t_{1}$, and rows $x_{2}$,
$y_{2}$, and $t_{2}$ represented the $x$ and $y$ coordinates of each aircraft at time $t_{2}$. The problem is to make a linear extrapolation of the coordinates of each plane at time $t$. The formulas to be used are

$$
x=\left(t-t_{2}\right) \frac{x_{2}-x_{1}}{t_{2}-t_{1}}+x_{2} \quad \text { and } \quad y=\left(t-t_{2}\right) \frac{y_{2}-y_{1}}{t_{2}-t_{1}}+y_{2}
$$

We first form $x_{2}-x_{1}$ in row $x_{1}, y_{2}-y_{1}$ in row $y_{1}, t_{2}-t_{1}$ in row $t_{1}$, and finally $t-t_{2}$ in row $t$. Then we form the quotient of rows $x_{1}$ and $t_{1}$ in row $x_{1}$ and of rows $y_{1}$ and $t_{1}$ in row $y_{1}$. Next we form products of rows $t$ and $x_{1}$ in row $x_{1}$ and of rows $t$ and $y_{1}$ in row $y_{1}$. Finally row $x_{2}$ is added to row $x_{1}$ and put in row $x_{3}$; and row $y_{2}$ is added to row $y_{1}$ and put in row $y_{3}$; and the extrapolation is completed. The method of coding is straightforward, using $C=-1$ in operation 3 for subtraction.

Table 8-8. Code to Accumulate the Rows $i_{0}$ to $i_{0}+h$, Column by Column $\dagger$

| Instruction address | Operation | $i$ | $j$ | $k$ | $p$ | $q$ | Displace | Accumulate | C | $\delta_{r}$ | $\delta_{s}$ | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0, 0 | 3 | $i_{0}$ | $i_{0}+1$ | $i_{0}+1$ | 0 | 21 | 0 | 0 | 1 | 1 | 0 | Add $i$ to $i+1$; put in $i+1$ |
| 1, 0 | 7 | 0 | 3 | 0 | 1 | 1 | $\cdots$ | $\cdots$ | $i_{0}+h-1$ | 2 | 0 | $\begin{aligned} & i: i_{0}+h-1 \\ & >: \text { Stop iteration } \\ & \quad \leq: \text { Continue } \end{aligned}$ |
| 2, 0 | 3 | 4 | 0 | 0 | 1 | 3 | 0 | 0 | 1 | 0 | 0 | Update ( 0,0 ) |
| 3, 0 |  |  |  |  | 0 | 0 |  |  |  |  |  | Stop computer |
| 4, 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Constant |

$\dagger$ Recall that the columns are numbered 0 through 21.
As a third example, consider a numerical integration according to the rectangular approximation. Suppose that the successive values of the function at points $x$ are given by $f_{i}(x)$ and that the intervals are unequal and are given in row $i+1$. Then for the rectangular approximation we want to form the product of rows $i$ and $i+1$, column by column, and then accumulate this product over the columns. Here we make direct use of operation 6 and form

$$
\sum_{u=0}^{21} f_{i}(u) f_{i+1}(u)
$$

in row $i+2$. Then the value of the approximation is found in row $i+2$, column 21 .

Systems Design for a Special-purpose Business or Logistics Computer. One of the most important features that a special-purpose computer of this type should have is rapid, flexible input-output. A general characteristic of the problems under consideration in this section is the large
mass of input data to fill the array and the large mass of data computed from the array. This is in fact the main reason for having instructions that operate with generalized addresses. The given data may be characterized as items and characteristics associated with the items. Here the characteristics are the numbers upon which it is necessary to perform operations, and the items are the specifications of these numbers. Hence on the drum the location of a number can represent the item or specification, while the number itself, i.e., the contents of this location, will be the characteristics.

For example, in a naval supply problem an item might consist of the set of numbers ( $x_{0}, x_{1}, x_{2}, x_{3}$ ), where $x_{0}=\operatorname{ship}$ number, $x_{1}=$ time period (e.g., month and year), $x_{2}=$ Navy material class (e.g., class 75, diesel engine parts), and $x_{3}=$ source of supply (e.g., the vessel itself, an afloat activity, a shore activity). The associated characteristics might consist of the set of numbers $\left(y_{0}, y_{1}, y_{2}\right)$, where $y_{0}=$ total number of items consumed, $y_{1}=$ total weight in pounds, and $y_{2}=$ total volume in cubic feet. The source of this data may have covered 12 ships, during 72 time periods, for 50 Navy material classes, and from three sources of supply, or 129,600 items. For each of these items there appear three six-digit numbers representing $y_{0}, y_{1}$, and $y_{2}$. The data would then contain 2,332,800 digits.

Processing this data might consist in computing and printing tables with entries $y_{0}, y_{1}$, and $y_{2}$ corresponding to some specified set of the $x$ 's. For example, the set $\left(x_{0}, x_{1}\right)$ would lead to a two-way table of vessel number vs. time period, with entries covering all classes of material from all sources. Or additional functions of the $y$ 's may be desired. Average values are about the simplest example: $y_{3}=y_{1} / y_{0}=$ average weight in pounds; $y_{4}=y_{2} / y_{0}=$ average volume in cubic feet; $y_{\bar{\circ}}=2,240 y_{2} / y_{1}=$ stowage factor in cubic feet per long ton.

It often occurs that a characteristic of one problem becomes an item specification for another problem, or the reverse. For instance it might be desired to compute a table giving the values of $y_{0}, y_{1}$, and $y_{2}$ for each $x_{0}, x_{1}$, and $y_{3}$, that is, for each ship, time period, and average weight. In such a case the numbers $y_{0}, y_{1}$, and $y_{2}$ will have to be relocated so that $x_{0}, x_{1}$, and $y_{3}$ will now specify their locations. Hence it becomes clear that in business and logistics computations searching, sorting, and ordering play an important role, in addition to the types of computations considered above.

In the previous section we assumed that the information was recorded on a magnetic tape; here, however, we shall consider searching, sorting, and ordering of items by characteristics accomplished on an auxiliary drum, different from the one with which the computations are performed. The input data, which might, for instance, be on punched cards, is read onto the searching drum, both the items and the characteristics being recorded. This drum is appropriately searched, and the characteristics determined by the search are recorded on the computational-array drum in positions (i.e., addresses) that specify the associated item. Any
rearrangement or reordering is accomplished by use of the searching drum.

Our special-purpose business or logistics computer is thus seen to be two interlocking computers, an array-manipulation computer and a searching or information-retrieval computer (see Fig. 8-13). Each would have


Fig. 8-13. Special-purpose business or logistics computer.
its own programming system. The array-manipulation computer would have special-purpose array-manipulation instructions as described above; the information-retrieval computer would have instructions enabling it to perform the operations described in the previous section. Ideally the


Fig. 8-14. Large-scale system consisting of information-retrieval, array-manipulation, and general-purpose computers.
two computers should be able to operate concurrently; appropriate interlocking conditions would have to be satisfied, so that the two computers and computer programs would be properly synchronized.

In addition we could attach a general-purpose computer to this setup to have a large-scale system (Fig. 8-14). Again for concurrent operation interlocks must be maintained. More will be said about such an arrangement in the next section.

## EXERCISES

(a) Consider the example of computing building-material purchase schedules and requirements. Suppose that the requirements at the site for each month during the construction are as follows:

| Month | Type of material |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| March. | 100 | 75 | 60 | 54 | 0 | 0 | 20 | 60 | 10 | 20 | 30 |
| April. | 50 | 0 | 40 | 60 | 0 | 0 | 20 | 90 | 10 | 20 | 0 |
| May. | 25 | 0 | 30 | 50 | 0 | 0 | 30 | 150 | 10 | 30 | 0 |
| June. | 30 | 115 | 20 | 70 | 0 | 0 | 50 | 50 | 50 | 0 | 20 |
| July. | 0 | 0 | 10 | 30 | 10 | 20 | 90 | 20 | 70 | 0 | 10 |
| August. | 0 | 100 | 5 | 50 | 50 | 30 | 100 | 10 | 90 | 50 | 5 |
| September. | 0 | 0 | 0 | 90 | 100 | 100 | 150 | 0 | 100 | 90 | 0 |
| October. | 0 | 0 | 0 | 20 | 0 | 150 | 200 | 0 | 150 | 100 | 0 |

Suppose that the delay time and the cost per unit are as follows (where the cost per unit of the material varies with the number of units ordered as shown):

|  | Type of material |  |  |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| Delay time, |  |  |  |  |  |  |  |  |  |  |  |
| months..... | 3 | 5 | 6 | 2 | 4 | 6 | 5 | 3 | 5 | 6 | 7 |
| Units ordered: |  |  |  |  |  |  |  |  |  |  |  |
| $0-9$ | 10 | 50 | 35 | 20 | 5 | 40 | 30 | 20 | 30 | 100 | 150 |
| $10-19$ | 10 | 45 | 35 | 15 | 5 | 35 | 30 | 15 | 30 | 100 | 120 |
| $20-49$ | 10 | 40 | 30 | 14 | 5 | 30 | 25 | 15 | 25 | 95 | 110 |
| $50-99$ | 7 | 40 | 25 | 13 | 4 | 25 | 25 | 10 | 25 | 95 | 100 |
| 100 or over | 7 | 38 | 20 | 12 | 3 | 20 | 20 | 10 | 20 | 90 | 100 |

Determine the schedule for the ordering, and determine how much money will be spent each month, assuming that the orders are paid for at the time they are ordered.
(b) Write a code that will compute Exercise a.
(c) Write a code for numerical integration by the trapezoidal rule.
(d) Write a code for the linear extrapolation.
(e) What situations might require interlocks between the information-retrieval computer and the array-manipulation computer?

## 8-6. The Large-scale Data Processor

Systems Design. Perhaps the most important observation about systems design is that whenever possible systems design should be accomplished for the specific purpose for which the computer is to be used. This does not mean that the computer should be of limited capabilities-rather, design for a purpose means that the computer's
capabilities should be extended to include features that will enhance its effectiveness for the special purpose for which it is intended to be used. However, one pitfall must be avoided in the design of special-purpose computers. It is usually possible to utilize special-purpose computers for problems not directly involved with the special purpose for which the computer was designed. In such cases the coding may be much more difficult. This often leads to increased cost of coding or to making undesirable simplifications in a problem to have it more nearly conform to the type for which the special-purpose computer was designed. Such a situation tends to diminish the advantages to be derived from using a digital computer in the first place. Hence it is usually unwise to use a special-purpose computer for problems other than those for which it was specifically designed. These considerations emphasize the importance of carefully evaluating the purpose before embarking on a computer design for that purpose, to be certain that the problems under consideration are truly in line with the special features of the proposed design.

The systems design of a digital computer is characterized by the specifications for (1) its computing components, (2) its memory components, (3) its input-output components, and (4) its interlock control. The specifications of a computing component include the instruction and quantity format, the list of instructions, the speed of execution of instructions, the logical design technique, and the type of electronic circuitry used. These last two specifications will be covered in Parts 3 to 5 . The specifications of a memory component include its type (i.e., magnetic core, magnetic drum, etc.), size (i.e., number of words), speed or access time, logic (e.g., for a drum whether the words are round the circumference or along the axis, etc.), and circuitry. The specifications of the input-output components include the kind, speed, and electromechanical design. The interlock controls, already mentioned in the preceding sections, will be discussed in greater detail below.

Special Input-Output Problems. When data is collected, the recording scheme used is ordinarily determined from criteria dictated by the particular problem, by convenience, etc. Rarely is the best form for computer utilization considered as a factor. Also, data produced by a computer will not in general be directly compatible for input into another type of computer. These problems become extremely serious in, for example, missile-testing programs, aircraft-flight evaluations, etc., where exceedingly large masses of data are produced very rapidly. The problem of conversion of this data to a form that can be read directly into the computer for analysis then becomes almost a larger task than collecting the data.

One method for solving this problem is to have a special input drum for the computer. Everything that is read into the computer is read directly onto this drum just as it appears on the input medium. If the input were punched cards with 80 columns and 10 rows, then the data of the cards would be read onto the drum just as it appears on the cards, with a unit corresponding to a hole, a zero to no hole. Then a special translating
computing unit would be coded to interpret this information appropriately. The translating unit would interpret the raw information on the drum, change it into appropriately coded binary data, and put it into the computer's main memory. This technique is extremely flexible, since all that is needed is a method for getting the raw data onto the drum, in any digital fashion whatsoever.

This naturally brings up a second problem. Since reading in and translating the data will be time-consuming, it would be more efficient if the computer could be computing on other data, or even on another program, concurrently with the read-in and translation. Such a concurrent-input feature presents no problems other than logical and electronic design, provided that certain interlocks are observed. In reading data into a computer it is certainly known in which part of the main memory the information will eventually be stored. A simple type of interlock will halt a concurrent computer program that refers to a main memory address that has not yet been read into; when the input information is inserted into this address, the program automatically continues.

In so far as output from the computer is concerned, the translator acts in reverse, putting information on the special drum in a form which when read out from that drum will correspond to any desired external coding scheme. Similarly with proper interlocks concurrent output can be accomplished.

The Large-scale Data Processor. The large-scale data processor as described in this paragraph (see Fig. 8-15) is a fictitious computer; its description is used here as a vehicle for discussing the problems that arise in multiple-unit systems design. The purpose of this illustrative computer would be to perform general data processing. It encompasses each of the three features described in Secs. 8-3, 8-4, and 8-5, in addition to the translating component. Hence it is comprised of a general-purpose computing unit, a logical-control computing unit, a searching, sorting, and ordering computing unit, an array-manipulating computing unit, and an inputoutput translator computing unit. It contains a high-speed memory, a general-purpose magnetic drum, a translator input-output drum, a sorting drum, an array-manipulation drum, as well as magnetic-tape units. It has conventional input-output equipment and a signal-sensing input unit for real-time control.

The main point, however, to be illustrated by this example is that any or all of the computing units may be operating (i.e., computing) concurrently, using any or all of the memories or input-output units. The mechanisms that enable such concurrent operation are found in the in-out selector-concurrent input-output interlock control and in the computingunits interlock control.

Let us consider the computing-units interlock control first and describe two possible ways it can operate. Consider the case where our data processor is operating on multiple independent codes simultaneously. The instructions for each of these codes are found in the memory units. At any time, each code is being computed in a different computing unit.

Each computing unit has its own instruction register, and its own current-address register that sequences the program according to the instruction definitions of the particular unit in which it is located. There are times, however, when one code will want to operate in a different unit, will want to change computing units. These change-unit


Fig. 8-15. Large-scale data processor.
instructions are not handled in the computing units; instead they are sensed and sent to the computing-units interlock control. This interlock control keeps track of which units are being used. If a code wants to change to a computing unit that is being used, the code progress is stopped until the desired unit is free. A waiting line, or queue, is formed if necessary for each computing unit. The order, or priority, in which waiting codes are selected from the queues can be made as complicated as is considered necessary for the purposes of the computer design.

When the desired computing unit becomes available, the contents of the instruction address register is transmitted to this computing unit and the code is continued in its new unit. In other words, a computing unit processes the instructions it retrieves from the memory as directed by its current-address register; when changing from one code to another, a computing unit merely needs to have its current-address register changed. The control mechanism for this change is located in the computing-units interlock control. By this means each of the computing units can act almost as a separate computer in its own right, except when required to idle by the computing-units interlock control. Even though this concept for handling multiple codes at the same time is reasonably simple, the detailed techniques in a specific case may present many special considerations and exceptions.

The second way in which a computing-unit interlock control might operate is to have only a single code being computed. However, it often happens that different parts of this code can be computed at the same time. That is, the logic or flow diagram of the code may not necessitate a completely serial sequencing of operations, but several parts of the code might be processable in parallel at the same time. In this mode the computing-units interlock control scans the entire code, recognizing parts of the code that can be executed independently. It does this by observing memory reference locations. If one part of a code never refers to a memory location used by another part of the code, then it can be accomplished at the same time as that other part of the code. The rules for observing this can become rather complicated. The computing-units interlock control must accomplish both functions; how thoroughly it accomplishes either function depends on the systems design and purpose of the computer.

Finally we consider the in-out selector-concurrent input-output interlock control. Besides in-out selections, this control unit must accomplish input-output interlock control similar to that described above. All input-output instructions are automatically sensed and sent to this interlock control. If free, the appropriate unit is selected; if not, the code will wait, as was the case in the computing-units interlock control. This interlock control must communicate with the computing-units control, so that a code may be stopped when it wants to use a memory location not yet loaded. Again the details can become exceedingly complicated.

## EXERCISES

(a) Make a chart with columns labeled with the specification names of the computer components and rows labeled with the various purposes considered in this chapter. Fill in the table with component specifications, giving a reason for each decision. (For example, the entries in the table will state how many addresses the instruction system should have, how large the memory should be, the access speed, and so forth.)
(b) Draw a flow chart of a code that would interpret raw data from cards. Suppose that a computer word contains 15 bits, with the decimal point to the right. Assume
that the raw data appear on cards with 80 columns and 10 rows, where each card is interpreted as containing 20 four-digit numbers and the digit associated with each column is the row location of a single punch in that column. For example, the first two numbers on the card illustrated in the figure are 1,340 and 1,235 . Assume

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | $\cdots$ |  |
| :--- | :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  |  | $\square$ |  |  |  |  |  |  |  |  |  |  |
| 1 | $\square$ |  |  |  | $\square$ |  |  |  |  |  |  |  |  |  |
| 2 |  |  |  |  |  | $\square$ |  |  |  |  |  |  |  |  |
| 3 |  | $\square$ |  |  |  |  | $\square$ |  |  |  |  |  |  |  |
| 4 |  |  | $\square$ |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  | $\square$ |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

that the translator drum records the rows of each card in sequence, from 0 to 9 . The code is to compile the successive numbers (i.e., successive groups of four columns) in binary in the main memory of the computer.

## 8-7. Additional Topics

a. References on Digital Differential Analyzers. In general, digital differential analyzers are far more versatile and complicated than described in Sec. 8-2. For a more thorough understanding of their variations and potentialities see the following references:

Bush, Vannevar: Differential Analyzer, J. Franklin Inst., vol. 212, no. 4, pp. 447-448, October, 1931.
Donan, J. F.: The Serial-memory Digital Differential Analyzer, Mathematical Tables and Other Aids to Computation, vol. 6, no. 38, pp. 102-112, April, 1952.
Hartree, Douglas R.: "Calculating Instruments and Machines," University of Illinois Press, Urbana, Ill., 1949.
Mendelson, Myron J.: The Decimal Digital Differential Analyzer, Aeronaut. Eng. Rev., February, 1954, pp. 42-54.
Palevsky, M.: The Design of the Bendix Digital Differential Analyzer, Proc. IRE, vol. 41, pp. 1352-1356, October, 1953.
Sprague, R. E.: Fundamental Concepts of the Digital Differential Analyzer, Mathematical Tables and Other Aids to Computation, vol. 6, pp. 41-48, January, 1952.
Weiss, E.: Applications of the CRC 105 Decimal Digital Differential Analyzer, IRE Trans. on Electronic Computers, vol. EC-1, pp. 19-24, December, 1952.
Winslow, D. J.: Incremental Computers in Simulation, Meeting of South East Simulation Council, Oct. 30, 1958, Huntsville, Ala.
b. Multiple-component Computing Systems. In Sec. 8-6 the systems design of computers composed of several different interlocked computing components was
described. The following references give further details about specific examples of systems designs illustrating this principle:

Dreyfus, Phillipe: France's Gamma 60-A Step Forward in Data Processing? Datamation Research Eng. J., May-June, 1958, p. 34.
Dunwell, S. W.: Design Objectives for the IBM Stretch Computer, Proc. Eastern Joint Computer Conf., December, 1956, p. 20.
Eckert, J. P.: Univac-Larc, the Next Step in Computer Design, Proc. Eastern Join Computer Conf., December, 1956, p. 20.
c. System Engineering. We have been considering the systems design of digital computers. However, more often than not the digital computer is itself a component of a larger organized system. The study of such large-scale systems engineering is considered in a text by Harry H. Goode and Robert E. Machol, "System Engineering," McGraw-Hill Book Company, Inc., New York, 1957. Chapter 2 of this text is devoted to examples of such large-scale systems. How can a digital computer fit into each of the systems described in that chapter? Other discussions of systems design can be found in M. M. Hunt, Bell Labs 230 Long Planners, Fortune, May, 1954, p. 120; and P. F. Drucker, The Promise of Automation, Harper's Magazine, April, 1955. The following periodicals frequently discuss large-scale systems: Control Engineering, a McGraw-Hill publication; and the IRE Transactions on Industrial Electronics.

## SYSTEMS DESIGN OF THE PEDAGAC

Purpose. Pedagac, which stands for "pedagogic automatic computer," is the name of a computer that will be completely designed in this text. The purpose of the Pedagac is to provide the necessary thread of continuity to the study of digital-computer engineering. The process of its design as presented in this book will relate the systems design to the logical design and to the electronic design of a computer. Its primary purpose is to teach; its systems design, logical design, and electronic design have been chosen to demonstrate the procedural chain involved in the engineering of a computer. In many ways the Pedagac may not be appropriate for construction for any purpose other than engineering teaching and demonstration; for the oversimplification often used for


Fig. 9-1. Block diagram of the Pedagac.
pedagogic purposes makes the Pedagac less efficient in computing speed and use of electronic hardware than is really necessary. However, the Pedagac can be built; it is a general-purpose digital computer.

Block Diagram. Figure $9-1$ is a block diagram of the Pedagac. The Pedagac is a binary computer, whose code will be written in octal-coded binary notation. The instruction system is a one-address format; the binary point is assumed to be to the left of a quantity word (i.e., all numbers are less than 1). It has a serial arithmetic unit, its memory is a drum, and it has a single output unit and a single input unit.

Word Format. A Pedagac word contains 19 bits. The instruction and quantity formats are summarized in Fig. 9-2. The $\alpha$ address contains 12 bits; hence the addressable memory has $2^{12}=4,096$ addresses, from 0000 to 7777 (octal).

The Pedagac Coding Manual. Table 9-1 summarizes the instructions that will be available on the Pedagac.

Table 9-1. Instruction List for the Pedagac

| Operation code | Operation name | Symbolic description | Meaning |
| :---: | :---: | :---: | :---: |
| 53 | Add | $(\mathrm{acc})+(\alpha) \rightarrow$ acc | Add ( $\alpha$ ) to (acc); put result in acc |
| 42 | Major multiplication unrounded | (acc) $\times(\alpha) \rightarrow$ acc | Multiply ( $\alpha$ ) by (acc); put major product into acc |
| 32 | Minor multiplication | $(\mathrm{acc}) \times(\alpha) \rightarrow$ acc | Multiply ( $\alpha$ ) by (acc); put minor product into acc |
| 41 | Division unrounded | $(\mathrm{acc}) \div(\alpha) \rightarrow \mathrm{acc}$ | Divide (acc) by ( $\alpha$ ); put result into acc |
| 54 | Subtract | $(\mathrm{acc})-(\alpha) \rightarrow \mathrm{acc}$ | Subtract ( $\alpha$ ) from (acc); put result into acc |
| 52 | Transfer | $(\mathrm{acc}) \rightarrow \alpha$ | Transfer (acc) into $\alpha$; leave (acc) unchanged |
| 43 | Conditional jump | (acc) < 0; take $\alpha$ | If (ace) is negative; take ( $\alpha$ ) as next instruction; otherwise take next instruction in sequence as usual; leave (acc) unchanged |
| 44 | Normal jump | Take $\alpha$ | Take ( $\alpha$ ) as next instruction; leave (acc) unchanged |
| 50 | Clear accumulator. | $0 \rightarrow$ acc | Make (acc) $=0$ |
| 71 | Logical multiplication | $(\mathrm{acc}) \stackrel{L}{L}(\alpha) \rightarrow$ acc | Logically multiply (acc) by ( $\alpha$ ); put result into acc |
| 72 | Logical addition | (acc) $\dagger(\alpha) \rightarrow$ acc | Logically add (acc) to ( $\alpha$ ); put result into acc |
| 73 | Logical equivalence | (acc) $L=(\alpha) \rightarrow$ acc | Equalize (acc) with ( $\alpha$ ); put result into acc |
| 74 | Logical nonequivalence | $(\mathrm{acc}) \mid \neq(\alpha) \rightarrow$ acc | Unequalize (acc) with ( $\alpha$ ); put result into acc |
| 70 | Circular shift | (acc) $\alpha$ (acc) | Circular shift (acc) clockwise by $\alpha$ positions |
| 60 | Stop | Stop | Stop computer |
| 00 | Read in | Input unit $\rightarrow \alpha$ | Read in one word from input unit into $\alpha$ |
| 21 | Read out | $(\alpha) \rightarrow$ output unit | Read out ( $\alpha$ ) to output unit |

The Control Panel. The control panel of the Pedagac is very simple. Besides the power on-off button there are only three other manual push buttons: the start button, the stop button, and the run button. Before we can describe the action of these buttons, we must first describe the idling mode and the computing mode of the computer's operation. The computer is said to be idling when the power is on but no instructions are being executed; it is said to be computing when instructions are being sequenced and executed. There are three ways in which the computer can enter
the idling mode: (1) it will assume the idling mode just after the power is turned on; (2) it will be in the idling mode after a stop instruction has been executed; (3) it will be in the idling mode after the stop button has been pushed. There are two ways in which the computer can be made to change from the idling mode to the computing mode: (1) push the start button; (2) push the run button.

As we have observed, pushing the stop button puts the computer into the idling mode. The current-address counter will contain the address of the next instruction, and the computer will begin to idle after completing the execution of the present instruction. The stop button has no effect if pushed when the computer is idling. When the run button is pushed, the computer will proceed with the program, first executing the

Instruction word format:

| Operation (6 bits or 2 octal figures) |  |  |  |  |  | $\alpha$ address 12 bits or 4 octal figures |  |  |  |  |  |  |  |  |  |  |  | a |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\stackrel{\infty}{\sim}$ | $\stackrel{\sim}{\sim}$ | $\stackrel{0}{2}$ | $\stackrel{1}{2}$ | $\stackrel{ \pm}{\square}$ | $\stackrel{m}{a_{1}}$ | $\begin{aligned} & N \\ & \underset{Q}{2} \end{aligned}$ | $\overrightarrow{D_{2}}$ | $\begin{aligned} & O_{1} \\ & Q_{1} \end{aligned}$ | 0 2 1 | ${ }_{\sim}^{\infty}$ | ${ }_{\text {N }}$ | 0 $\square$ 4 | $\stackrel{10}{2}$ | $\pm$ | M $\sim$ | N | $\stackrel{-1}{2}$ | 0 |

Quantity format:


Fig. 9-2. The word format of the Pedagac.
instruction whose address is in the current-address counter. The run button has no effect if pushed when the computer is in the computing mode.

The operation of the start button is more complicated. When pushed, first the current-address counter is cleared, second the instruction register is cleared, and third the computer changes to the computing mode and proceeds to execute the instruction in the instruction register. What instruction in the instruction register? Namely, 00 0000, which says, "Read one word from the input unit into address 0000 and take the next instruction from the address in the current address counter-namely, address 0000." In other words, when the start button is pushed, the computer reads one word into the address 0000 and then proceeds to execute (0000) as an instruction. The start button has no effect if pushed when the computer is in the computing mode. The start button has two uses: First, as we shall soon see, it is used to read in the read-in routine. Second, it is used in interrupting the program to jump out of the normal sequence of instructions; if the programmer desired to jump to a different
part of the program, he would push the stop button, place an appropriate jump instruction in the input unit, and then push the start button.

A Read-in Subroutine for the Pedagac. The read-in instruction of the Pedagac reads in only one word at a time. Usually in reading in a program or data it is desired to read in many words at one time. Thus the need arises for a subroutine which will read $n_{0}$ words into adjacent addresses $\alpha_{0}, \alpha_{0}+1, \alpha_{0}+2, \ldots, \alpha_{0}+\left(n_{0}-1\right)$. The read-in subroutine can be initiated by a program that is being computed, e.g., to call in additional data, or else it can be initiated by pushing the start button. Assuming that the read-in subroutine is already in the memory


Fig. 9-3. Flow chart of read-in routine.
of the Pedagac, Fig. 9-3 represents a flow chart for it. However, for this flow chart to operate properly, the data or words to be read in must be preceded by a word with $\alpha_{0}$, the first address to be loaded, and $n_{0}$, the number of words to be read in. If the read-in process is to be initiated by the start button, the first word of the data must be a jump to RR1, which is the first address of the read-in routine itself (see Fig. 9-4). The read-in code itself appears in Table 9-2. Here $\alpha_{i} R R$ represents the read-in instruction that is modified, $n_{i} \mathrm{RR}$ is the address of the tally word $n_{i}$, and ONE is the address of the constant 1.

Initial Read-in Subroutine for the Pedagac. Suppose that the read-in subroutine was not in the memory. Then a special initial read-in sub-


Fig. 9-4. Sequence of words on the input medium to read in a program or data.
routine must be used. The purpose of this subroutine is to load the computer with the normal read-in routine and then give this routine control. We assume that the computer and drum have been cleared and that the start button is pushed. This reads in one word from the input unit into 0000. This word will be an instruction, "Read one word into 0001." The computer then will execute this instruction, which is

Table 9-2. The Read-in Routine

| Address | Operation | $\alpha$ | Remarks |
| :---: | :---: | :---: | :---: |
| RR1 | 00 | $n_{i} \mathrm{RR}$ | Load $n_{i} \mathrm{RR}$ with $n_{0}$ |
| RR2 | 50 | 0000 |  |
| RR3 | 53 | $n_{i} \mathrm{RR}$ |  |
| RR4 | 54 | ONE | Subtract 1 from $n_{0}$ |
| RR5 | 52 | $n_{i} \mathrm{RR}$ |  |
| RR6 | 00 | $\alpha_{i} \mathrm{RR}$ | Load $\alpha_{i} \mathrm{RR}$ with $00 \alpha_{0}$ |
| $\alpha_{i} \mathrm{RR}$ | 00 | 0000 | Read one word into $\alpha_{i}$ |
| RR7 | 50 | 0000 |  |
| RR10 | 53 | $n_{i} \mathrm{RR}$ | Subtract 1 from $n_{i}$ |
| RR11 | 54 | ONE |  |
| RR12 | 43 | RR21 |  |
| RR13 | 52 | $n_{i} \mathrm{RR}$ | 0:niRR |
| RR14 | 50 | 0000 |  |
| RR15 | 53 | $\alpha_{i} \mathrm{RR}$ | Add 1 to $\alpha_{i}$ |
| RR16 | 53 | ONE | Add 1 to $\alpha_{i}$ |
| RR17 | 52 | $\alpha_{i} \mathrm{RR}$ |  |
| RR20 | 44 | $\alpha_{i} \mathrm{RR}$ | Jump to read-in instruction |
| RR21 | 00 | 0000 | Read one word into 0000 |
| RR22 | 44 | 0000 | Execute (0000) |
| ONE $n_{i} \mathrm{RR}$ | 00 | 0001 |  |

now in 0000 (see description of the start, stop, and run buttons). This second word to be read in will be an instruction, "Read one word into 0002." The current-address counter will be stepped by 1 in its normal fashion, and the instruction, which is now in 0001, will be executed. A third word will then be read into 0002 ; this will be a jump instruction to jump unconditionally to 0000 . Recall that ( 0000 ) is the instruction "Read one word into 0001." This fourth word will be the instruction "Read one word into address RR1," where RR1 is supposed to be the first address of the normal read-in routine. The computer will then execute this instruction, reading in the fifth word, which is the first


Fig. 9-5. This is not a flow chart of a program. It is a flow diagram illustrating the sequence of operations actually performed during the initial read-in routine that reads in the read-in routine.
instruction of the normal read-in routine. The computer will now take the next instruction from address 0002 , which jumps back to address 0000 . The instruction at 0000 will read in a sixth word into 0001 ; this will be an instruction to read in the second instruction of the normal read-in routine, into address $\mathrm{RR1}+1$, of course. This instruction is executed; then the jump to 0000 is executed, and so forth. This process continues until the read-in subroutine has been completely read into the drum memory. Then, when the computer returns to address 0000 , it will read into 0001 a jump instruction to RR1, that is, the first address of
the normal read-in routine (see Fig. 9-5). Note that the sequence of words that will pass through the input unit is as follows:

First word............................. . Read one word into 0001
Second word.......................... . . . Read one word into 0002
Third word. . . . . . . . . . . . . . . . . . . . . . . Jump to 0000
Fourth word......................... . Read one word into address RR1
Fifth word............................ . First instruction of normal read-in routine
Sixth word........................... Read one word into address RR1 +1
Seventh word......................... Second instruction of normal read-in routine
Eighth word......................... Read one word into address RR1 +2
Ninth word.......................... . Third instruction of normal read-in routine
Tenth word, etc..................... Read one word into address RR1 +3 , etc.
Last word of initial read-in word
sequence.............................. . Jump to address RR1

## Additional Topics

$a$. Write an automonitor routine for the Pedagac.
b. Compile a library of subroutines for the Pedagac.
c. Write an automatic program for the Pedagac so that it can be programmed in the simplified International Algebraic Language of Sec. 5-9.

# FOUNDATIONS FOR THE LOGICAL DESIGN OF DIGITAL CIRCUITRY 

CHAPTER 10

## INTRODUCTION TO BOOLEAN ALGEBRA AND DIGITAL-COMPUTER CIRCUITS

## 10-1. Introduction

Boolean Algebra. Boolean algebra is an algebraic discipline analogous to the ordinary algebra with which we are all familiar but which follows different rules. We could begin this chapter directly by presenting these new rules, but such an approach would not provide the rationale and background so necessary to a thorough understanding of the methods involved in Boolean algebra. For Boolean algebra was originally developed, not for designing computer circuits, but as the symbolic interpretation of some forms of logical reasoning and as the method for describing relations between classes and sets. A knowledge of such interpretations can aid significantly in the study of Boolean algebra as applied to computer circuits by suggesting analogies and alternative methods for thinking through circuit-design problems.

Therefore in this chapter we introduce Boolean algebra by means of logic, in accordance with its historical development. A discussion of Boolean algebra itself is then given, followed by its interpretation as the algebra of sets. Having dispensed with these preliminaries, we turn to the main purpose of this chapter, the interpretation of Boolean algebra in terms of digital-computer circuits.

Historical Background. It is of historical interest to note that this algebra was first investigated by George Boole (1815-1864) and the theory essentially completed by Ernst Schroeder in his monumental work on the algebra of logic before the turn of this century. Boole, Schroeder, and other logicians of that time had in mind the practical uses of the algebra of logic in the solution of everyday problems. However, they found that dealing with just four to five variables made practical computation unfeasible, requiring the employment of extremely ingenious methods for solution. Hence interest in solving large-scale logical problems of this kind was lost.

It was at that time, too, that Whitehead and Russell, Hilbert, and
others realized that logic could be developed to encompass the foundations of mathematics, and after the turn of the century the attention of logicians became focused on the so-called functional calculus of symbolic logic. Problems of extreme metamathematical and philosophical importance were considered. Such problems are still today of primary interest to professional logicians. Their methods have necessarily been esoteric and have as yet found little everyday application.

On the other hand, the advent of digital-computer circuitry brought a widespread reawakening of interest in the algebra discovered by Boole. The first use of Boolean algebra in circuit design was made by Shannon $\dagger$ in 1938. Computational difficulties again limited the direct, practical application of Boolean algebra. To help offset some of these difficulties, new digital computational methods have recently been developed, and these are presented in the chapters of this part.

It is to be reemphasized that this chapter will proceed as follows: (1) Logic will be discussed in order to introduce Boolean algebra in a natural way. (2) Boolean algebra itself will be described. (3) The set interpretation of Boolean algebra will be given as an aid to visualizing some of the relationships. And (4) the circuit interpretation will be given, together with methods for going from the circuit diagram to the Boolean function and conversely from the Boolean function to the corresponding circuit diagram.

## 10-2. Definition of Logic and Propositions

Symbolic Logic. Logic is the science that teaches how thinking or reasoning should proceed; it produces the results of thinking; and it encompasses laws by means of which a judgment can be passed as to the correctness of the products of thought or reasoning. As H. Reichenbach points out, however, "When we call logic analysis of thought, the expression should be interpreted so as to leave no doubt that it is not actual thought which we pretend to analyze, it is rather a substitute for thinking processes, their rational reconstruction, which constitutes the basis of logical analysis." In other words, once a result of thinking or reasoning is obtained, a chain of thought can be constructed from the initial premises to the final conclusions and an analysis of this rational reconstruction of thinking reveals those rules called laws of logic. Logic presents a means by which thinking or reasoning may be simulated and the results of thinking obtained or checked.

Only when the results of reasoning have been stated in terms of sentences can they be tested or evaluated; logic deals with sentences (e.g., statements) and the rules correlating premise and conclusion sentences. The best method of handling these sentences in logic is a symbolic method, for while simple logical operations can be performed without the help of a symbolic notation, the structure of complicated relations cannot be seen without the use of symbols.
$\dagger$ C. E. Shannon, A Symbolic Analysis of Relay and Switching Circuits, Trans. AIEE, vol. 57, pp. 713-723, 1933.

The Proposition. The methods of symbolic logic that are concerned with deduction must lead from true sentences to true sentences. Hence the whole sentence becomes a fundamental unit for logic since only a whole sentence can be true or false. In fact, attention in this book will be limited only to whole sentences with this property, and such sentences will be called propositions. A proposition is a whole sentence about which it is meaningful to say that its content is true or false. Some authors put this somewhat differently, limiting their consideration only to meaningful sentences. In their system a sentence is meaningful only if it is verifiable as true or false. The part of symbolic logic that deals with propositions is called the propositional calculus.

Examples of propositions and their truth values are as follows:


In textbooks dedicated solely to symbolic logic a distinction in symbolism is made between propositions and propositions about propositions. However, since the purpose of this chapter is only to introduce computational methods in the propositional calculus of symbolic logic and not to expound the subject itself, no consistent attempt will be made to separate propositions of these two types. The distinction between propositions of these types is to be made by the reader from the context.

## 10-3. Definition of Propositional Operations

The Propositional Operations. It is to be reemphasized that this chapter deals with a logic of two truth values, viz., true and false, and that the primary interest is in determining the truth value of propositions. In considering combinations of propositions, the truth value of the combination is again the primary object.

Propositions can be combined or manipulated by the words and, or, and not (negation), these words being called the propositional operations. The operations and and or combine two propositions, whereas the operation not (or negation) is associated with only one proposition. Given the truth value of propositions, the truth value of their combinations with the propositional operations is defined as follows:

1. The and combination of two propositions is true if and only if both propositions are true. If either one or both of them are false, the combination is false. For example, "The grass is green, and logic is the science that teaches how thinking or reasoning should proceed" is true, but "The grass is green, and 3 is an even number" is false. The and combination of two propositions is often called their conjunction, or logical product.
2. The or combination of two propositions is true if and only if either one or both of the propositions are true. The or combination of two propositions is false only if both propositions are false. For example, "The grass is green, or 3 is an even number" is true; " 3 is an even number, or January is a summer month" is false. The or combination of two propositions is often called their disjunction, or their logical sum.
3. The negation of a proposition is true if and only if the proposition is false. For example, " 3 is not an even number" (which is the negation of " 3 is an even number") is true.

Propositions may be symbolized by letters: $A, B, C, \ldots, W, X$, $Y, \ldots$ In a later chapter we shall symbolize propositions by letters with subscripts: $A_{1}, A_{2}, \ldots, B_{1}, B_{2}, \ldots$ We use the symbol • for the operation and, + for or, and - (bar) over the letter to indicate negation. This symbolism is summarized in the following table:

| Operational symbol | Interpretation | Terminology |
| :---: | :---: | :--- |
|  |  |  |
|  | Not $A$ | Negation |
| $A+B$ | $A$ or $B$ | Disjunction, logical sum |
| $A \cdot B$ | $A$ and $B$ | Conjunction, logical product |

The use of + for the or symbol arises from the parallelism between this logical operation and arithmetic addition. For example,

## 2 bananas +3 apples $=5$ pieces of fruit

where pieces of fruit $=$ bananas or apples. The parallelism between the logical product and the arithmetical product also holds; for example, $2 \mathrm{ft} \cdot 3 \mathrm{lb}=6 \mathrm{ft}-\mathrm{lb}$ since the unit of work, namely, foot-pounds, is a logical and combination.

Boolean Functions. Combinations of propositions joined by or, not, and and can be determined true or false and hence are propositions themselves. The uncombined propositions are called elementary elements and are usually denoted by letters at the beginning of the alphabet: $A, B$, . . . . Propositions combined by the propositional operations are called combined elements, or Boolean functions, and are usually denoted by letters at the end of the alphabet: $X, Y, \ldots$ Combined elements are sometimes written in functional form, that is, $f(A, B, \ldots$.$) .$

For example, consider the combined element $\bar{A}+B \cdot C$. Suppose that $A$ is false, $B$ is true, and $C$ is false (that is, $A$ might represent proposition $a$ of the examples in Sec. 10-2, $B$ might represent proposition $b$, and $C$ might represent proposition $e$ ). In such a case $B \cdot C$ is false (since $C$ is false), and $\bar{A}$ is true (since $A$ is false); hence $\bar{A}+B \cdot C$ is true (since $\bar{A}$ is true). Note that $\bar{A} \cdot \bar{B}$ is distinct from $\overline{A \cdot B}$; the former is read (not $A$ ) and (not $B$ ), while the latter is read [not $(A$ and $B)$ ] (the parentheses are for clarity). If $A$ is true and $B$ is false, then $\bar{A} \cdot \bar{B}$ is false and $\overline{A \cdot B}$ is true.

## EXERCISES

Suppose that $A$ is false, $B$ is true, and $C$ is false; determine the truth value of the following combined elements:
(a) $\bar{A} \cdot B \cdot \bar{C} \quad$ True
(b) $\bar{A} \cdot B+A \cdot \bar{B} \quad$ True
(c) $(\bar{A} \cdot B+A \cdot \bar{B}) \cdot C \quad$ False
(d) $\overline{A \cdot C} \quad$ True
(e) $\overline{A+B} \quad$ False
(f) $(A+B) \cdot C+(A+C) \cdot \bar{C}+\bar{A} \cdot \bar{B} \cdot \bar{C} \quad$ False

## 10-4. Implication, Equivalence, and Tautology

There are two particularly important combined elements, namely, $\bar{A}+B$ and $A \cdot B+\bar{A} \cdot \bar{B}$. Their significance and meaning are discussed here.

Implication. First consider $\bar{A}+B$. This is usually abbreviated $A \rightarrow B$, called " $A$ implies $B$," or "If $A$, then $B$," by logicians. In a sense this corresponds to the everyday linguistic use of the word implies, for if $A$ is true and $A \rightarrow B$ is true, then $B$ must be true; also, if $A \rightarrow B$ is true and $B$ is true, $A$ may or may not be true. For example, consider the proposition "if an airplane is a fighter plane, then it has light armor." Certainly, if the airplane is a fighter, it will have light armor, according to the proposition; but if the airplane has light armor, the proposition does not reveal whether it is a fighter or not, for other types of airplanes than fighters have light armor.

Equivalence. Consider now the important function $A \cdot B+\bar{A} \cdot \bar{B}$, called " $A$ is equivalent to $B$ " and abbreviated $A=B$. If $A \cdot B+\bar{A} \cdot \bar{B}$ is true, then $A$ and $B$ have the same truth values, for then either $A$ and $B$ are both true or they are both false. Also, the meaning of the equals (=) sign in logic parallels its meaning in arithmetic, in which any item can be substituted for an equivalent one. For it can be shown that, if $A=B$ is true, then some combination of the propositions $U, V$, and $A$, say, $f(U, V, A)$, is equivalent to that combination with $B$ replacing $A$, that is, $f(U, V, A)=f(U, V, B)$. In other words, it is always true that $(A=B) \rightarrow[f(U, V, A)=f(U, V, B)]$ in the propositional calculus.

Tautology. This naturally brings up the topic of tautology. A tautology is a combined element that is always true, independent of the truth or falseness of its component propositions. For example, $A+\bar{A}$, $(\overline{A \cdot B})+A,(\overline{A \cdot B})+(A+\bar{B}) \cdot(\bar{A}+B)$, as well as

$$
(A=B) \rightarrow[f(U, V, A)=f(U, V, B)]
$$

are all tautologies, for they are true no matter what the truth values of $A, B, U$, and $V$ are (or what the truth value of the combined element $f$ is). Therefore there is no logical reason to distinguish between these combined elements, and any one of them is called the universally true
element, or tautology, and denoted by $I$. The negation of $I$, namely, $\bar{I}$, is the universally false element, denoted by 0 . A consequence of these concepts is that $0 \rightarrow X$ and $X \rightarrow I$ are always true; i.e., the universally false element implies everything, while everything implies the tautology.

To review, then, there are two meanings to truth. One is "tautologically true," and the other is "true because it is a physical fact or supposition." "The grass is green" is true in the latter sense; "Today is Tuesday, or today is not Tuesday" is tautologically true. Logicians often use a special symbol to distinguish these meanings, but for our limited purposes this would be an unnecessary complication.

## EXERCISES

(a) Note that $A \rightarrow B$ is true if both $A$ is false and $B$ is false. Can you think of examples of this situation that might occur in real life?
(b) Consider the sentence " $A+\bar{A}$ is a tautology." Is this tautologically true, or is it factually true?

## 10-5. Truth Tables

The truth values of a combined element depend on the truth values of its component elementary elements, as dictated by the definitions of the propositional operations. A table can be made presenting all possible combinations of truth values; we call this a truth table. Consider, for example, $A+B$. The columns under $A$ and $B$ represent all possible truth-value combinations of $A$ and $B$, and the column under $A+B$ represents the corresponding truth value of $A+B$, where $T$ stands for true and $F$ for false.

| $A$ | $B$ | $A+B$ |
| :---: | :---: | :---: |
| $T$ | $T$ | $T$ |
| $F$ | $T$ | $T$ |
| $T$ | $F$ | $T$ |
| $F$ | $F$ | $F$ |

Similarly the truth tables for $\bar{A}$ and $A \cdot B$ are:

| $A$ | $\bar{A}$ |
| :---: | :---: |
| $T$ | $F$ |
| $F$ | $T$ |


| $A$ | $B$ | $A \cdot B$ |
| :---: | :---: | :---: |
| $T$ | $T$ | $T$ |
| $F$ | $T$ | $F$ |
| $T$ | $F$ | $F$ |
| $F$ | $F$ | $F$ |

These truth tables follow from the definitions of the propositional operations and, conversely, could have been taken to be the definitions of these operations. With these basic truth tables in mind the truth table for any :ombined element can be constructed.

Sec. 10-5] boolean algebra and digital circuits 301
For example, recalling that $A \rightarrow B$ stands for $\bar{A}+B$ and that $A=B$ stands for $A \cdot B+\bar{A} \cdot \bar{B}$, the following table can be formed:

| $A$ | $B$ | $A \rightarrow B$ | $A=B$ |
| :---: | :---: | :---: | :---: |
| $T$ | $T$ | $T$ | $T$ |
| $F$ | $T$ | $T$ | $T$ |
| $T$ | $F$ | $F$ | $F$ |
| $F$ | $F$ | $T$ | $T$ |

Note that $A=B$ is true only when $A$ and $B$ have the same truth values. Similarly truth tables can be made for combinations of any number of elementary elements. For example, for three elementary elements $A$, $B$, and $C$, the truth table for the combined element $\bar{A}+B \cdot C$ becomes:

| $A$ | $B$ | $C$ | $\bar{A}+B \cdot C$ |
| :---: | :---: | :---: | :---: |
| $T$ | $T$ | $T$ | $T$ |
| $F$ | $T$ | $T$ | $T$ |
| $T$ | $F$ | $T$ | $F$ |
| $F$ | $F$ | $T$ | $T$ |
| $T$ | $T$ | $F$ | $F$ |
| $F$ | $T$ | $F$ | $T$ |
| $T$ | $F$ | $F$ | $F$ |
| $F$ | $F$ | $F$ | $T$ |

## EXERCISES

Find the truth tables for:
(a) $(\overline{A \cdot B})+A$.
(b) $\bar{A} \cdot B \cdot \bar{C}$.
(c) $(\bar{A} \cdot B+A \cdot \bar{B}) \cdot C$.
(d) $\overline{A \cdot C}$.
(e) $\overline{A+B}$.

Solution

| $A$ | $B$ | $C$ | $(\overline{A \cdot B})+A$ | $\bar{A} \cdot B \cdot \bar{C}$ | $(\bar{A} \cdot B+A \cdot \bar{B}) \cdot C$ | $\overline{A \cdot C}$ | $\overline{A+B}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $T$ | $T$ | $T$ | $T$ | $F$ |  | $F$ | $F$ |
| $F$ | $T$ | $T$ | $T$ | $F$ | $F$ |  |  |
| $T$ | $F$ | $T$ | $T$ | $F$ | $T$ | $T$ | $F$ |
| $F$ | $F$ | $T$ | $T$ | $F$ | $F$ | $F$ | $F$ |
| $T$ | $T$ | $F$ | $T$ | $F$ | $F$ | $T$ | $T$ |
| $F$ | $T$ | $F$ | $T$ | $T$ | $F$ | $T$ | $F$ |
| $T$ | $F$ | $F$ | $T$ | $F$ | $F$ | $T$ | $F$ |
| $F$ | $F$ | $F$ | $T$ | $F$ | $F$ | $T$ | $F$ |

Note that $(\overline{A \cdot B})+A$ is indeed a tautology since it is true for every combination of truth values of the elementary elements of which it is a combination.
(f) Show that $A+\bar{A}$ and $\overline{A \cdot B}+(A+\bar{B}) \cdot(\bar{A}+B)$ are tautologies.

## 10-6. Boolean Algebra

Equations of Boolean Algebra. With the foregoing interpretation the algebraic properties of the logical operations can be more clearly understood. The following equations characterize a Boolean algebra. It is to be noted that these equations are quite different from the familiar rules of ordinary algebra. The subject that comprises algebraic manipulations according to the equations given below is therefore called Boolean algebra to distinguish it from ordinary algebra. Some of the equations of Boolean algebra are particularly important, and mathematicians have given them special names as shown:

## Name of equation

1. $A+A=A$
2. $A \cdot A=A$
3. $A+B=B+A$
4. $A \cdot B=B \cdot A$
5. $(A+B)+C=A+(B+C)=A+B+C$
6. $(A \cdot B) \cdot C=A \cdot(B \cdot C)=A \cdot B \cdot C$
7. $A \cdot(B+C)=A \cdot B+A \cdot C$
8. $A+B \cdot C=(A+B) \cdot(A+C)$
9. $\overline{A \cdot B}=\bar{A}+\bar{B}$
10. $\overline{A+B}=\bar{A} \cdot \bar{B}$
11. $A+I=I$
12. $A \cdot I=A$
13. $0+A=A$
14. $0 \cdot A=0$
15. $\bar{A}+A=I$
16. $A \cdot \bar{A}=0$
17. $A+A \cdot B=A$
18. $A+\bar{A} \cdot B=A+B$
19. $A \cdot B+B \cdot C+C \cdot A=(A+B) \cdot(B+C) \cdot(C+A)$
20. $A \cdot \bar{B}+A \cdot C+B \cdot C=A \cdot \bar{B}+B \cdot C$
21. $\bar{A}=A$

These equations are to be interpreted as tautologies. The equals sign means that, for any given combination of truth values for $A, B$, and $C$, the combined element on the right-hand side of the equation has the same truth value as the combined element on the left-hand side. Hence these equations can be checked by writing the truth tables for the right-hand and left-hand combined elements.

Algebraic Proofs. Some of these equations can be "proved" algebraically by using others. For example, let us prove (20) by using (12), (15), (7), (6), (4), (3), and (17). $\dagger$
$\dagger$ Note how difficult and rather "tricky" it is to prove (20). With experience and practice some facility can be gained in performing such manipulations. However, the

$$
\begin{array}{rlrl}
A \cdot & \vec{B}+A \cdot C+B \cdot C & & \\
& =A \cdot \bar{B}+A \cdot C \cdot I+B \cdot C & & \text { by (12) } \\
=A \cdot \bar{B}+A \cdot C \cdot(\bar{B}+B)+B \cdot C & & \text { by (15) } \\
=A \cdot \bar{B}+(A \cdot C) \cdot \bar{B}+(A \cdot C) \cdot B+B \cdot C & & \text { by (7) } \\
=A \cdot \bar{B}+(A \cdot \bar{B}) \cdot C+B \cdot C+(B \cdot C) \cdot A & & \text { by (6), (4), and (3) } \\
=A \cdot \bar{B}+B \cdot C & & \text { by (17) applied twice }
\end{array}
$$

New equations may also be proved by using those listed above. To show that $I \cdot A=A$, we have $I \cdot A=A \cdot I=A$ by (4) and (12).

## EXERCISES

(a) Using $I \cdot A=A$, (8), and (15), prove (18).

Solution

$$
\begin{aligned}
A+\bar{A} \cdot B & =(A+\bar{A}) \cdot(A+B)=I \cdot(A+B) \\
& =A+B
\end{aligned}
$$

as desired.
(b) What other equations listed above would be used to prove (19)?

Solution. (1), (2), (3), (6), (7), (8). [Hint: Start with the right-hand side of (19) and apply (8), using (1), (2), (3), (6), and (7) to simplify the terms.]

Alternative Algebraic Proofs. There is another way of proving equations, namely, by making use of (15) and (11), for we want to show that an equation is a tautology (i.e., the meaning of "proving equations"). If we can show that the equation itself is equivalent to $I$ (in truth value), then we have shown that it is a tautology, since $I$ is the universally true element (i.e., always true for all truth-value combinations of the elementary elements).

For example, consider the proof of (17): $A+A \cdot B=A$ is an abbreviation for

$$
(A+A \cdot B) \cdot A+(\overline{A+A \cdot B}) \cdot \bar{A}
$$

but, on using (2), (3), (4), (6), (7), (9), (10), (11), and (15), we find that this expands to

$$
\begin{aligned}
A+A \cdot B+\bar{A} \cdot(\bar{A}+\bar{B}) \cdot \bar{A} & =A+A \cdot B+\bar{A}+\bar{A} \cdot \bar{B} \\
& =A+\bar{A}+A \cdot B+\bar{A} \cdot \bar{B} \\
& =I+A \cdot B+\bar{A} \cdot \bar{B} \text { by (15) } \\
& =I \quad \text { by (11), to complete the proof }
\end{aligned}
$$

As another example, we can show that $A \cdot B \rightarrow A$ is a tautology, for $A \cdot B \rightarrow A$ is an abbreviation for $\overline{A \cdot B}+A$, which becomes, by (9), $\bar{A}+\bar{B}+A$. But $\bar{A}+\bar{B}+A=\bar{A}+A+\bar{B} \quad[$ by (3) and (5) $]=$ $I+\bar{B}[\mathrm{by}$ (15)] $=I$ [by (11)], to complete the proof.

[^5]
## EXERCISES

Are the following tautologies?

## Answer

(a) $\bar{A} \cdot B \rightarrow A$

No
(b) $A \rightarrow A+B$ Yes
(c) $(A \rightarrow B)=(\bar{B} \rightarrow \bar{A})$ Yes
(d) $(A \cdot B \cdot C \rightarrow D)=(\bar{D} \cdot B \cdot C \rightarrow \bar{A})$ Yes

Another Method for Algebraic Proof. There is still another way for proving equations, i.e., to make both sides of the equals sign look identical. For example, let us prove that $(A \rightarrow B)=(\bar{B} \rightarrow \bar{A})$. From the definition of $\rightarrow$ we have $\bar{A}+B=B+\bar{A}$ or $\bar{A}+B=\bar{A}+B$, by (21) and (3). As another example, let us show that

$$
A \rightarrow(B \rightarrow C)=A \cdot B \rightarrow C
$$

By the definition of $\rightarrow$ the left-hand side becomes $\bar{A}+\bar{B}+C$. Similarly the right-hand side becomes $\overline{A \cdot B}+C$; by using (9) this becomes $\bar{A}+\bar{B}+C$, as desired.

## 10-7. Boolean Algebra as the Algebra of Sets

Sets. We have introduced Boolean algebra as the algebra of propositional logic. However, Boolean algebra can also be interpreted as the algebra of sets, or classes. A class is a collection of objects all of which have a certain property; such a well-defined collection of objects is often called a set. For example, the collection of all automobiles manufactured in the year 1956 and still in operating condition is a set. Or the collection


Fig. 10-1. $A, \bar{A}$.
of people who registered at the national meeting of the Institute of Radio Engineers in 1960 forms a set. However, most often for the purposes of mathematics a set is visualized as the area inside a closed curve drawn on a piece of paper: the set is roughly interpreted as the collection of points that lie inside the closed curve (see Fig. 10-1). The objects that belong to the set are called elements of the set. For example, the point $p$ is an element of the set (the interior of the circle) of Fig. 10-1. Sets are often denoted by letters; for example, we call the set in Fig. 10-1 the set $A$.

Just as the prime purpose of propositional logic was to determine the truth value of a proposition, so the prime purpose of the algebra of sets is to determine whether or not a point is in a set. In fact the only difference between the propositional calculus of logic and the algebra of sets is that the algebra of sets deals with a very restricted kind of propositions. These are propositions of the form "The point $p$ is in the set $A$ " and combinations of such propositions with and, or, and not. Hence the crosshatched area of Fig. 10-1 represents all those points for which the


Fig. 10-2. A • B.


Fig. 10-3. $A+B$.
proposition "The point $p$ is in the set $A$ " is true. Let us symbolize this proposition by $A$. Then $\bar{A}$ is true for all points $p$ not lying in the crosshatched area.

Intersection and Union. All the points for which $A \cdot B$ is true (i.e., for which "the point $p$ is in the set $A$, and the point $p$ is in the set $B$ " is true) are represented by the crosshatched area of Fig. 10-2. All the points for which $A+B$ is true (i.e., for which "the point $p$ is in the set $A$, or the point $p$ is in the set $B$ " is true) are represented by the crosshatched area in Fig. 10-3. The crosshatched area in Fig. 10-2 is called


Fig. 10-4. $\bar{A}$.


Fig. 10-5. $\bar{B}$.
the intersection of the set $A$ with the set $B$, that is, the set of points that lie in both $A$ and $B$. The crosshatched area in Fig. 10-3 is called the union of the set $A$ with the set $B$, that is, the set of points that lie in either $A$ or $B$ or both.

Now, as we have seen, Boolean algebra holds for propositions, and hence it must also hold for our set interpretation of propositions. Hence we can visualize some of the relations of Boolean algebra by means of the set diagrams. For example, consider the relation $\overline{A \cdot B}=\bar{A}+\bar{B}$.

We shall show that $\overline{A \cdot B}$ and $\bar{A}+\bar{B}$ represent the same area. Figure 10-4 gives the area for $\bar{A}$, Fig. $10-5$ for $\bar{B}$, and Fig. 10-6 for $\bar{A}+\bar{B}$. But, observing Fig. 10-2 for $A \cdot B$, we see that the area for $\bar{A}+\bar{B}$ is the same as that for $\overline{A \cdot B}$.

Just as in the propositional logic, given the truth value of the elementary elements, the truth value of a combined element can be determined, so, given the location of a point $p$ with respect to the elementary sets $A, B, \ldots$, we can determine if it is in the set described by a com-


Fig. 10-6. $\bar{A}+\bar{B}$.


Fig. 10-7. $(\bar{A}+\bar{B}) \cdot \bar{C}$.
bined element. For example, if a point $p$ is in set $A$, not in set $B$, not in set $C$, then is it in the set for which $(\bar{A}+\bar{B}) \cdot \bar{C}$ is true? The solution is given in Fig. 10-7. The crosshatched areas are all points for which $(\bar{A}+\bar{B}) \cdot \bar{C}$ is true, and the point $p$ is in set $A$, but not in set $B$ or set $C$. Hence $p$ is in the set $(\bar{A}+\bar{B}) \cdot \bar{C}$.

## EXERCISES

(a) Show by set diagrams that $A+B \cdot C=(A+B) \cdot(A+C)$.

If a point is in set $A$, not in set $B$, and not in set $C$, then is it in the following sets. i.e., in the sets for which the following combined elements are true?

|  | Answer |
| :--- | :---: |
| (b) $(A+B) \cdot \bar{C}$ | Yes |
| $($ c) $A+B \cdot \bar{C}$ | Yes |
| (d) $A \cdot B \cdot \bar{C}$ | No |
| (e) $A \cdot(B+\bar{C})$ | Yes |
| (f) $\bar{B}+A \cdot C$ | Yes |

(g) Draw the set diagram for $A \rightarrow B$.
(h) Draw the set diagram for $A=B$.

## 10-8. Digital-computer Circuits

In this section and the following sections we shall begin to see why the study of Boolean algebra is important for digital-computer circuit design. However, first we must make clear just what a digital-computer circuit is (see Fig. 10-8).

The Condition-function table. Consider a digital-computer-circuit black box with, say, two input wires called wire $A$ and wire $B$ and one output wire called wire $C$. Suppose that only one of two voltages may appear on wire $A$, to be specific, say a 0 -volt and a 1 -volt signal; the same holds for wire $B$. Hence a table can be made describing all possible input conditions:

|  | Possible input conditions |  |  |  |
| :--- | :---: | :---: | :---: | :---: |
| Wire $A \ldots \ldots \ldots \ldots$ | 0 | 1 | 2 | 3 |
| Wire $B \ldots \ldots \ldots \ldots$ | 0 | 1 | 0 | 1 |
| Wire $C \ldots \ldots \ldots \ldots$ | 0 | 0 | 1 | 1 |

Let condition 3 be the case when there is a 1 -volt signal on both wires $A$ and $B$; condition 2 be the case when there is a 0 -volt signal on wire $A$, 1 volt on wire $B$; condition 1 when there is 1 volt on wire $A, 0$ volts on wire $B$; condition 0 when there are 0 -volt signals on both wires $A$ and $B$. Then the function of the black box will be completely specified if we tell


Fig.10-8. Digital-computer black box.
what voltage will appear on wire $C$ for each of the four input conditions on wires $A$ and $B$. For instance, suppose that 1 volt appears on wire $C$ only when 1 volt appears on both wires $A$ and $B$ and that 0 volts appear on wire $C$ otherwise. Then the table of input conditions can be completed for the output wire $C$ as shown, and then the function of the black box is completely specified by the condition-function table. Such a black box is a type of digital-computer circuit.

Hence we define a (binary) digital-computer circuit as a circuit black box the input wires of which are limited to two voltage levels, the output wires of which are limited to two voltage levels, and such that the voltage levels of the output wires depend on the present voltage levels of the input wires. $\dagger$
$\dagger$ Circuits that seem to depend on the past history of the input-voltage levels as well can always be interpreted in terms of present input-voltage levels provided that the number of "inputs" is increased; this will be discussed in a later chapter.

## EXERCISE

(a) Make a condition-function table for a circuit with three input wires $A, B, C$ and one output wire $D$ such that $D$ will have a unit voltage signal whenever $A$ has a unit voltage signal and $B$ has a unit voltage signal, or else when $C$ has a zero voltage signal; otherwise $D$ has a zero voltage signal.

Solution

|  | Possible input conditions |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| Wire $A \ldots \ldots \ldots$ | 0 | 1 | 0 | 1 | 0 | 1 |  |  |
| Wire $B \ldots \ldots \ldots$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| Wire $C \ldots \ldots \ldots$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| Wire $D \ldots \ldots \ldots$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |

## 10-9. Boolean Algebra as the Algebra of Digital-computer Circuits

We have introduced Boolean algebra as the algebra of propositional logic and have shown that it is in addition the algebra of sets. Boolean algebra can also be interpreted as the algebra of digital-computer circuits. Just as the prime purpose of propositional logic was to determine the truth value of a proposition and that of the algebra of sets was to determine whether or not a point is in a set, the prime purpose of the algebra of digital-computer circuits is to determine the signal-voltage level on a wire (e.g., either a 0 -volt or a 1 -volt signal). In fact, just as in the algebra of sets, the algebra of digital-computer circuits deals with a restricted kind of proposition. These are propositions of the form "The wire $X$ has a 1-volt signal" and combinations of such propositions with and, or, and not.

Suppose that we symbolize by $X$ the proposition "The wire $X$ has a 1 -volt signal." Then we can symbolize, for example, the statement in Exercise $a$ of Sec. 10-8 that describes when wire $D$ will have a 1 -volt signal as follows: $A \cdot B+\bar{C}$. In fact, when that combined element is true, then $D$ is to be true; that is, $D=A \cdot B+\bar{C}$. Hence we can symbolize the conditions that describe the output of a computer circuit in terms of its input by means of Boolean algebra.

The condition-function table now becomes analogous to the truth tables of propositional logic when 0 corresponds to false and 1 corresponds to true. In fact, given the Boolean algebraic conditions for $D$ to have a 1 -volt signal, a function table can be constructed directly in a manner similar to the construction of truth tables.

For example, suppose that the conditions for output wire $D$ of a computer circuit were given in terms of the voltage signals on input wires $A$, $B$, and $C$ by

$$
D=\bar{A}+B \cdot C
$$

Then the condition-function table would be:

|  | Possible input conditions |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| Wire $A \ldots \ldots \ldots$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| Wire $B \ldots \ldots \ldots$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| Wire $C \ldots \ldots \ldots$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| Wire $D \ldots \ldots \ldots$ | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 |

For example, if $A$ is true (i.e., if "Wire $A$ has a 1 -volt signal" is true) and if $B$ is true and if $C$ is true, then $\bar{A}$ is false, but $B \cdot C$ is true, whence $\bar{A}+B \cdot C$ is true and therefore $D$ is true (i.e., "Wire $D$ has a 1 -volt signal" is true). Hence for condition 7 we put a unit in the row for wire $D$, and so forth.

Immediately we see that the description of the same black-box computer circuit can be stated in more than one way in terms of Boolean algebra. For example, if an output wire $D$ is given in terms of the input wires $A, B, C$ as $D=\bar{A}+B \cdot C$, then, since

$$
\bar{A}+B \cdot C=(\bar{A}+B) \cdot(\bar{A}+C)
$$

we could equivalently write $D=(\bar{A}+B) \cdot(\bar{A}+C)$. On the other hand both $\bar{A}+B \cdot C$ and $(\bar{A}+B) \cdot(\bar{A}+C)$ have the same truth table and consequently the same condition-function table.

## 10-10. From Circuit Diagram to Boolean Function

The Gates. We shall presently show that any such digital-computercircuit black box can be constructed out of three circuit elements, called, respectively, an and gate, an or gate, and an inverter. $\dagger$ However, the three kinds of circuit elements must first be defined. They are all digitalcomputer circuits and can therefore be defined by a condition-function table.

The and gate has two inputs $A$ and $B$ and one output $X$, which takes the voltage values given by the following table:

|  | Possible input conditions |  |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 |
| Wire $A \ldots \ldots \ldots \ldots$ | 0 | 1 | 0 | 1 |
| Wire $B \ldots \ldots \ldots \ldots$ | 0 | 0 | 1 | 1 |
| Wire $X \ldots \ldots \ldots \ldots$ | 0 | 0 | 0 | 1 |

[^6]In words, wire $X$ will have a 1-volt signal if and only if the wires $A$ and $B$ each have a 1 -volt signal. One possible method for constructing such a circuit is illustrated in Fig. 10-9. The arrows indicate the direction of


Fig. 10-9. Diode and circuit.
flow of electron current; $T_{1}$ and $T_{2}$ are diodes, and $R$ is a resistor. When either wire $A$ or wire $B$ has a 0 -volt signal, current will flow through the resistor until $X$ is at 0 volts; when all of wires $A$ and $B$ are at +1 volt, then no current will flow through $R$ and wire $X$ will be at +1 volt. $\dagger$

The or gate has two inputs, $A, B$, and one output, $X$, which takes the voltage values given by the following table:

|  | Possible input conditions |  |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 |
| Wire $A \ldots \ldots \ldots \ldots$ | 0 | 1 | 0 | 1 |
| Wire $B \ldots \ldots \ldots \ldots$ | 0 | 0 | 1 | 1 |
| Wire $X \ldots \ldots \ldots \ldots$ | 0 | 1 | 1 | 1 |

In words, wire $X$ will have a 1 -volt signal if and only if at least one of wire $A$ or $B$ has a 1-volt signal. The schematic for such a circuit is


Fig. 10-10. Diode or circuit.
illustrated in Fig. 10-10. Whenever any one of $A$ or $B$ or $C$ becomes +1 volt, electron current will flow until $X$ is at +1 volt.
$\dagger$ Detailed description of and gates, or gates, and inverters is given in Part 5. We merely indicate how these might be made to enable the student to obtain a more concrete picture at this time.

An inverter has one input wire $A$ and one output wire $X$. Wire $X$ will have a 1 -volt signal if wire $A$ is at 0 volts, and wire $X$ will have a 0 -volt signal if wire $A$ is at 1 volt. The table becomes:

|  | Possible input conditions |  |
| :--- | :---: | :---: |
|  | 0 | 1 |
| Wire $A \ldots \ldots \ldots$ | 0 | 1 |
| Wire $X \ldots \ldots \ldots$ | 1 | 0 |

Symbolized Gates. Rather than draw the schematic for an and gate, or gate, or inverter, we use standardized symbols to represent them, as shown in Fig. 10-11.


And gate


Or gate


Inverter

Fig. 10-11. Symbolized gates.
We can generalize the and gate and or gate symbols for more than two inputs as shown in Figs. 10-12 and 10-13.


Fig. 10-12. Symbol for and gate with four inputs.


Fig. 10-13. Symbol for or gate with four inputs.

From the Circuit Diagram to the Boolean Function. Complicated digitalcomputer circuits can be built up by connecting the output of such gates to the input terminals of other gates. For example, consider Fig. 10-14. The outputs $X$ and $Y$ of the and gates are connected to the inputs of the or gate. Hence the output $Z$ of the or gate then depends on the original inputs $A, B, C$, and $D$ of the and gates. What is the precise dependence? Note that $X=A \cdot B$ and $Y=C \cdot D$ whereas $Z=X+Y$. Hence $Z=A \cdot B+C \cdot D$. In other words, the circuit of Fig. 10-14 can be thought of as a black box with input $A, B, C$, and $D$ and output $Z$ such that $Z=A \cdot B+C \cdot D$.

Hence, given a digital-computer-circuit diagram, the Boolean expression for its output can now readily be derived. For example, consider the circuit of Fig. 10-15. The problem is to write $Z$ in terms of $A$ and $B$,
as given by the circuit diagram. This is done as follows: $Z=X \cdot Y$, $X=A+B, Y=\bar{C}$; therefore $Z=(A+B) \cdot \bar{C}$. For another example, consider the circuit of Fig. 10-16. Here $Z=X+Y, X=A \cdot B$, $Y=U \cdot V, U=\bar{A}$, and $V=\bar{B}$. Putting these together, we find that $Z=A \cdot B+\bar{A} \cdot \bar{B}$.

Summary. The procedure for writing the output Boolean functions in terms of the input elements (wires) for a given circuit diagram is as


Fig. 10-14. $Z=X+Y=A \cdot B+C \cdot D . \quad$ Fig. $10-15 . Z=X \cdot Y=(A+B) \cdot \bar{C}$.
follows: First, assign letters to all input wires, all internal connecting wires, and all output wires. Second, proceed to write down the successive functions for each gate or inverter. Third, substitute in the equations until the outputs are given in terms of the inputs.

The relations between the propositional calculus of symbolic logic and the circuit interpretation of Boolean algebra can now be reviewed. The


Fig. 10-16. $Z=X+Y=A \cdot B+U \cdot V=A \cdot B+\bar{A} \cdot \bar{B}$.
symbol $A$ corresponds to the proposition "Wire $A$ has a 1-volt signal." Hence consider the propositional interpretation of the answer to the second example: $Z=A \cdot B+\bar{A} \cdot \bar{B}$. This says that "The output wire $Z$ has a 1 -volt signal" has the same truth values as "Either both input wires $A$ and $B$ have a 1-volt signal, or neither $A$ nor $B$ has a 1-volt signal." In other words, wire $Z$ will have a 1-volt signal whenever either both $A$ and $B$ have 1 volt or neither $A$ nor $B$ has a 1-volt signal; otherwise wire $Z$ will have a 0 -volt signal.

## EXERCISES

Determine the Boolean function (i.e., the combined element) of the inputs $A, B, C$, and $D$ that corresponds to the outputs $Y$ and $Z$ of the following diagrams:

Solution

$Z=A+B \cdot C$
(b)


$$
Z=(A+B) \cdot(A+C)
$$

(c)


$$
Z=\overline{\bar{A} \cdot B+\bar{C} \cdot D}
$$

(d)


$$
\begin{aligned}
Z=A \cdot \bar{B} \cdot \bar{C}+ & \bar{A} \cdot B \cdot \bar{C} \\
& +\bar{A} \cdot \bar{B} \cdot C+A \cdot B \cdot C
\end{aligned}
$$



## 10-11. From Boolean Function to Circuit Diagram

In this section is illustrated how to proceed in the direction opposite to that of Sec. 10-10: given a desired output Boolean function in terms of the inputs, draw a circuit design. Let $Z$ be the ouput and $A$ and $B$ the inputs. Suppose that it is desired to design a circuit so that

$$
Z=A \cdot B+\bar{A} \cdot \bar{B}
$$

The right-hand side is the sum of two combined elements; so let

$$
Z=X+Y
$$

where $X=A \cdot B$ and $Y=\bar{A} \cdot \bar{B}$. Now $Y$ is the product of two combined elements: let $Y=U \cdot V$, where $U=\bar{A}, V=\bar{B}$. Then we draw


Fig. 10-17. $Z=X+Y=A \cdot B+U \cdot V=A \cdot B+\bar{A} \cdot \bar{B}$.
$Z$ as the result of $X+Y, X$ as $A \cdot B, Y$ as $U \cdot V, U$ as $\bar{A}$, and $V$ as $\bar{B}$ (see Fig. 10-17). For another example, consider

$$
Z=A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}
$$

Let $Z=U+V+W$, where $U=A \cdot \bar{B} \cdot \bar{C}, \quad V=\bar{A} \cdot B \cdot \bar{C}, \quad$ and $W=A \cdot B \cdot \bar{C}$. Hence the diagram is as in Fig. 10-18. This example is interesting for the following reason: Note that

$$
\begin{aligned}
& A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}=(A \cdot \bar{B}+\bar{A} \cdot B+A \cdot B) \cdot \bar{C} \\
&=(A \cdot(\bar{B}+B)+\bar{A} \cdot B) \cdot \bar{C}=(A+\bar{A} \cdot B) \cdot \bar{C}=(A+B) \cdot \bar{C}
\end{aligned}
$$

or $A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}=(A+B) \cdot \bar{C}$, which is just the output expression for the second example of the previous section (Sec. 10-10). In other words, the above circuit diagram gives the same output as the circuit diagram of the second example of the previous section.


Fig. 10-18. $Z=U+V+W=A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}$.
Hence we see that the design of a digital-computer-circuit black box is not unique and, in general, that there are many ways of arranging the and gates, or gates, and inverters to obtain equivalent results. How to choose the best design is discussed in the next chapter.

## EXERCISES

If $Z$ is the output and $A, B, C$, and $D$ are inputs, draw the circuit diagrams for computer circuits such that:
(a) $Z=A \cdot \bar{B}+\bar{A} \cdot B$.
(b) $Z=(A \cdot \bar{B}+\bar{A} \cdot B) \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C$.
(c) $Z=(A+\bar{B}) \cdot(C+\bar{D})$.
(d) $Z=(A+\bar{B} \cdot C) \cdot(\bar{A}+B \cdot \bar{C})+D$.

## 10-12. Additional Topics

a. Axiomatic Development of Boolean Algebra, and References. Boolean algebra, or the propositional calculus of symbolic logic, can be developed from several different sets of postulates. As an example, consider a set of postulates defined in terms of the following "fundamental concepts"': a set S of elements ( $a, b, c, \ldots$ ); $a+b$, the result of the binary operation +; and $\bar{a}$, the result of the operation -. The postulates are:

1. If $a$ and $b$ are elements of S , then $a+b$ is an element of S .
2. If $a$ is an element of $S$, then $\bar{a}$ is an element of $S$.
3. $a+b=b+a$.
4. $(a+b)+c=a+(b+c)$.
5. $\overline{(\bar{a}+\bar{b})}+\overline{(\bar{a}+b)}=a$.

The equals sign ( $=$ ) is interpreted as an equivalence relation (see Sec. 7-8), and in addition the following substitution rule is assumed to hold: If $x=y$, then $f(x, a, b, c, \ldots)=f(y, a, b, c, \ldots .$. . From these five postulates and the properties of $=$, all the equations of Boolean algebra can be proved (see Sec. 10-6). Evidently + can be interpreted as the logical sum; the logical product is defined as $a \cdot b=\overline{\bar{a}+\bar{b}}$. The tautology $I$ is defined by $I=a+\bar{a} ; 0$ is defined by $0=a \cdot \bar{a}$. For example, let us prove that $a \cdot b=b \cdot a$. By the definition $a \cdot b=\overline{(\bar{a}+\bar{b})}$; by (3), $\overline{(\bar{a}+\bar{b})}=\overline{(\bar{b}+\bar{a})}$; but $\overline{(\bar{b}+\bar{a})}=b \cdot a$, as desired. Can you prove that $a+(b \cdot c)=(a+b) \cdot(a+c)$ ?

A system of postulates is called independent when it is impossible to deduce from any portion of the system a conclusion deducible from any other portion. Can you prove that the five postulates given above are independent? Since the above set of postulates used the set $S$ and the operations + and - , we denote this set as the ( $\mathrm{S},+,-$ ) postulate set. Another set of postulates, denoted by ( $\mathrm{A},+, \cdot)$, is as follows:

1. There is an element 0 in A such that $0+a=a$ for all $a$ in A.
2. There is an element 1 in $\mathbf{A}$ such that $1 \cdot a=a$ for all $a$ in $\mathbf{A}$.
3. $0 \cdot a=0$ for all $a$ in A.
4. $1+a=1$ for all $a$ in $A$.
5. A consists of two elements (that is, 0,1 ).

Two sets of postulates $\mathbf{P}$ and $\mathbf{P}^{\prime}$ are called equivalent if starting with the postulates $\mathbf{P}$, after finding suitable definitions for the primitive concepts of $\mathbf{P}^{\prime}$ in terms of the primitive symbols of $\mathbf{P}$, the postulates of $\mathbf{P}^{\prime}$ can be derived. Can you show that the postulate sets $(\mathrm{S},+,-)$ and $(\mathrm{A},+, \cdot)$ as given above are equivalent? This latter set is closely related to the techniques to be considered in the next chapter.

The following references deal with the foundations and the axiomatic approach to Boolean algebras:

Bernstein, B. A.: A Set of Four Independent Postulates for Boolean Algebra, Trans. Am. Math. Soc., vol. 17, 1916; Sets of Postulates for the Logic of Propositions, Trans. Am. Math. Soc., vol. 28, 1926.
Boole, G.: "George Boole's Collected Logical Works" (1859), vols. 1 and 2, P. E. B. Jourdain (ed.), The Open Court Publishing Company, La Salle, Ill., 1940; "An Investigation of the Laws of Thought," Dover Publications, New York, 1951.
Huntington, E. V.: Sets of Independent Postulates for the Algebra of Logic, Trans. Am. Math. Soc., vol. 5, pp. 288-309, 1904; A New Set of Independent Postulates for the Algebra of Logic, Proc. Natl. Acad. Sci. U.S., vol. 18, 1932; New Sets of Independent Postulates for the Algebra of Logic, Trans. Am. Math. Soc., vol. 35, 1933.
Jevons, W. S.: "Pure Logic (1864) and Other Minor Works," R. Adamson and H. A. Jevons (eds.), The Macmillan Company, London and New York, 1890.
Schroeder, E.: "Algebra der Logik," vol. 1, Teubner Verlagsgesellschaft, Leipzig, 1890.

A discussion of the axiomatic method and techniques for proving the independence of and equivalence between axiom systems is found in R. L. Wilder, "Introduction to the Foundations of Mathematics," John Wiley \& Sons, Inc., New York, 1952.
b. Formal Rules of Inference. We have been discussing above axioms from which the identities or tautologies of Boolean algebra may be derived. We have tacitly assumed that the "usual rules" of logic are to be used in such derivations. But it is just these rules themselves which we are proposing to study! This is the problem which is
considered in logic texts and which will now be briefly treated. We are dealing with propositions whose content may be true or false and with tautologies that are stated in terms of propositions and that are themselves the rules of logic. However, we must start with primitive tautologies (axioms) and some primitive laws of deduction. One such primitive set is as follows: The primitive tautologies are:

1. $(x+x) \rightarrow x$.
2. $x \rightarrow(x+y)$.
3. $(x+y) \rightarrow(y+x)$.
4. $(x+y) \rightarrow((z+x) \rightarrow(z+y))$.

The primitive rules are: (1) The rule of substitution (dictum de omni); we may substitute for a propositional variable any other variable or combination of variables, provided that the substitution is made wherever that sentential variable occurs. (2) The rule of inference (modus ponens); if $x$ and $x \rightarrow y$ are tautologies, then $y$ is a tautology. From these we can prove all the tautologies of Boolean algebra. For example, let us prove that, if $z \rightarrow x$ and $x \rightarrow y$ are tautologies, then $z \rightarrow y$ is a tautology. To show this, first note that by our rule of substitution we shall let $\bar{z}$ replace $z$ in (4), obtaining as a tautology $(x \rightarrow y) \rightarrow((\bar{z}+x) \rightarrow(\bar{z}+y))$ or $(x \rightarrow y) \rightarrow((z \rightarrow x) \rightarrow(z \rightarrow y))$. Now, by the rule of inference, since $x \rightarrow y$ is a tautology, then $(z \rightarrow x) \rightarrow(z \rightarrow y)$ is a tautology; by our rule of inference again, since $z \rightarrow x$ is a tautology, then $z \rightarrow y$ is a tautology, as desired.

For detailed discussions of the formal theory of symbolic logic, the reader is referred to the following:

Church, A.: Introduction to Mathematical Logic, Part I, Ann. Math. Studies 13, Princeton University Press, Princeton, N.J., 1944.
Cohen, M., and E. Nagel: "An Introduction to Logic and the Scientific Method," Harcourt, Brace and Company, Inc., New York, 1934.
Hilbert, D., and W. Ackerman: "Principles of Mathematical Logic," R. E. Luce (ed.), Chelsea, New York, 1950.
Quine, Willard van Orman: "Mathematical Logic," rev. ed., Harvard University Press, Cambridge, Mass., 1951.
Reichenbach, H.: "Elements of Symbolic Logic," The Macmillan Company, New York, 1950.
Rosser, J. B.: "Logic for Mathematicians," McGraw-Hill Book Company, Inc., New York, 1953.
Whitehead, A. N., and B. Russell: "Principia Mathematica," vol. 1, 1910, vol. 2, 1912, vol. 3, 1913, Cambridge University Press, New York (2d ed., 1925-1927).
c. Other Logical Operations. As we have observed above, Boolean algebra can be accomplished with just two operations, + and - , since the - operation can be given in terms of + and - as $a \cdot b=\overline{\vec{a}+\bar{b}}$. There are in fact single operations in terms of which Boolean algebra can be accomplished. Consider the operation $p_{1}(a, b)$ defined in terms of + and ${ }^{-}$as follows: $p_{1}(a, b)=\overline{a+b}$. To show that Boolean algebra can be accomplished in terms of this single operation, all we need do is define,$+ \cdot$, and - in terms of $p_{1}(a, b)$. Thus, as can easily be checked from our definition, $\bar{a}=p_{1}(a, a)$; $a+b=p_{1}\left[p_{1}(a, b), p_{1}(a, b)\right] ;$ and $a \cdot b=p_{1}\left[p_{1}(a, a), p_{1}(b, b)\right]$. Another such single operation is $p_{2}(a, b)=\overline{a \cdot b}$. Here we have $\bar{a}=p_{2}(a, a), a+b=p_{2}\left[p_{2}(a, a), p_{2}(b, b)\right]$, and $a \cdot b=p_{2}\left[p_{2}(a, b), p_{2}(a, b)\right]$. Note that $I$ and 0 can be defined in terms of $p_{1}$ or $p_{2}$. For $p_{1}$ we have $I=p_{1}\left\{p_{1}\left[a, p_{1}(a, a)\right], p_{1}\left[a, p_{1}(a, a)\right]\right\}$, and then $0=p_{1}(I, I)$. Can you define $I$ and 0 in terms of $p_{2}$ ? If we admit $I$ and 0 as primitive concepts, then there are four further single operations that can be defined, namely, $p_{3}(a, b)=\vec{a}+b$, $p_{4}(a, b)=a+\bar{b}, \quad p_{5}(a, b)=\bar{a} \cdot b, \quad p_{6}(a, b)=a \cdot \bar{b}$. For example, for $p_{3}$ we have
$\bar{a}=p_{3}(a, 0), a+b=p_{3}\left[p_{3}(a, 0), b\right]$, and $a \cdot b=p_{3}\left\{p_{3}\left[a, p_{3}(b, 0)\right], 0\right\}$. Can you show that $p_{4}, p_{5}$, and $p_{6}$ are each also valid single operations? What algebraic properties do $p_{1}, \ldots, p_{6}$ have? The single operation $p_{1}$ was first introduced by H. M. Sheffer [A Set of Five Independent Postulates for Boolean Algebras, Trans. Am. Math. Soc., vol. 14, pp. 481-488, 1913, where $p_{1}(a, b)$ was denoted by $a \mid b$, commonly known as Sheffer's stroke]. A single primitive formula can be used in terms of $p_{1}$ (instead of the four given in Additional Topic $b$ above), namely,

$$
p_{1}\left[p_{1}\left(x, p_{1}\{y, z\}\right), p_{1}\left(p_{1}\left\{u, p_{1}[u, u]\right\}, p_{1}\left\{p_{1}[v, y], p_{1}\left[p_{1}(x, v), p_{1}(x, v)\right]\right\}\right)\right]
$$

This was first developed by J. Nicod (A Reduction in the Number of the Primitive Propositions of Logic, Proc. Cambridge Phil. Soc., vol. 19, pp. 32-42, 1916).
d. Logical Translation of English. The limitation on the practical application of the propositional calculus arises from the difficulty of translation of the practical worldly situations into these precise statements. This translation, the first step in formulating the problem for solution, is by no means obvious and requires the work of a trained logical analyst. Part of this difficulty is the prevalent loose and often obscure use of language, and in particular of those very conjunctions which form the logical operations.

## Table 10-1. Translations of English Connectives

## English connective

Logical translation

| Not $A$ | $\bar{A}$ |
| :---: | :---: |
| $A$ and $B$ | $A \cdot B$ |
| $A$ or (inclusive) $B$; $A$ or $B$ or both. | $A+B$ |
| $A$ or (exclusive) $B$; either $A$ or $B$. | $A \neq B, A \cdot \bar{B}+\bar{A} \cdot B$ |
| $A$ but $B$. | $A \cdot B$ |
| $A$ although $B$. | $A \cdot B$ |
| $A$ unless $B$. | $\bar{B} \rightarrow A, B+A$ |
| $A$ on condition that $B$. | $B \rightarrow A, \bar{B}+A$ |
| $A$ if $B$. | $B \rightarrow A, \bar{B}+A$ |
| If $A$, then $B ; A$ implies $B$. | $A \rightarrow B, \bar{A}+B$ |
| $A$ only if $B \dagger$. | $A \rightarrow B, \bar{A}+B$ |
| Not unless $A$ then $B$ | $\bar{A} \rightarrow \bar{B}, A+\bar{B}$ |
| $A$ provided that $B$. | $B \rightarrow A, \bar{B}+A$ |
| $A$ as well as $B$. | $A \cdot B$ |
| $A$ if and only if $B$. | $A=B, A \cdot B+\bar{A} \cdot \bar{B}$ |
| Not both $A$ and $B$ | $\overline{A \cdot B}, \bar{A}+\bar{B}$ |
| Neither $A$ nor $B$. | $\bar{A} \cdot \bar{B}, \overline{A+B}$ |
| When $A$, then $B$. | $A \rightarrow B, \bar{A}+B$ |
| $A$ because $B$. | $B \rightarrow A, \bar{B}+A$ |

$\dagger$ Often imprecisely synonymous with " $A$ if and only if $B$."
For example, the word unless as used in the combined proposition " $A$ unless $B$ " is defined by logicians as $A+B$, since " $A$ unless $B$ " is considered equivalent to " $A$ if not $B$," that is, "if not $B$, then $A$, " which is written symbolically as $\bar{B} \rightarrow A$. However, since not all users of the word unless are familiar with the logicians' delineation of the term, one often finds it employed with an entirely different connotation. For instance, " $A$ unless $B$ " is often used to denote "If $B$, then not $A$," symbolically $B \rightarrow \bar{A}$, or $\bar{B}+\bar{A}$. A third possibility for " $A$ unless $B$ " might be " $A$, but
if $B$ then not $A$," which becomes $A \cdot(\bar{B}+\bar{A})$, or $A \cdot \bar{B}$. It is thus evident that in the formulation of the propositional elements from the original raw sentences one must have enough familiarity with the subject matter to be able to discern the intent of a sentence in its given context.

In Table 10-1 we have suggested some translations for various English connectives. Caution must be used for the translation of or to distinguish between the inclusive or, that is, $A$ or $B$ or both, and the exclusive or, that is, either $A$ or $B$ but not both. Also care must be observed in using "If $A$ then $B$," or " $A$ implies $B$." Strict logical interpretation is $A \rightarrow B$, or $\bar{A}+B$. Consider, for example, $A \rightarrow B \cdot C$. This is equivalent to $(A \rightarrow B) \cdot(A \rightarrow C)$, which is reasonable in terms of the English translation. Similarly $A \rightarrow(B+C)$ is equivalent to $(A \rightarrow B)+(A \rightarrow C)$, which again is reasonable. However, $A \cdot B \rightarrow C$ is equivalent to $(A \rightarrow C)+(B \rightarrow C)$, which upon English translation is not obvious without considerable reflection; i.e., "Both $A$ and $B$ imply $C$ " is the same as " $A$ implies $C$, or $B$ implies $C$, or both $A$ implies $C$ and $B$ implies $C$." Similarly $(A+B) \rightarrow C$ is equivalent to $(A \rightarrow C) \cdot(B \rightarrow C)$, which again is not particularly obvious upon English translation.

For further discussion of this topic see these works:
Allen, L. E.: Toward More Clarity in Business Communications by Modern Logical Methods, Management Sci., vol. 5, no. 1, pp. 121-135, October, 1958.
Carnap, R.: "The Logical Syntax of Language," Routledge and Kegan Paul, Ltd., London, 1949.
Ledley, R. S.: Mathematical Foundations and Computational Methods for a Digital Logic Machine, J. Operations Research Soc. Am., vol. 2, no. 3, pp. 249-274, August, 1954. (See also letters on Logical Translation of English by L. Davidson, J. Operations Research Soc. Am., vol. 3, no. 2, p. 466, November, 1954, and J. W. Gilmore, J. Operations Research Soc. Am., vol. 3, no. 1, p. 104, February, 1955.)
Reichenbach, H.: "Elements of Symbolic Logic," The Macmillan Company, New York, 1947.

## CHAPTER 11

## THE DESIGNATION NUMBERS AND THE DESIGN OF FUNCTION CIRCUITS

## 11-1. Introduction

Boolean Algebra. In the last chapter Boolean algebra was introduced by means of its logical interpretation. Then it was shown how Boolean algebra could also be applied to describe relationships between sets and between input and output wires of digital-computer circuitry. This latter application is, of course, of primary interest to us. It was shown how to draw a circuit diagram corresponding to a Boolean function and, conversely, how to write a Boolean function, corresponding to a circuit diagram, for the output wires in terms of the input wires.

However, certain problems appeared in this study that were not resolved. For instance, it was seen that there are in general many circuit designs that will do the same job. Also the algebraic manipulations of Boolean algebra seem rather difficult, requiring considerable skill and imagination together with a thorough knowledge of many of the relationships given in Sec. 10-6. This chapter will present systematic computational methods that enable the relatively easy and straightforward solutions to these and many more problems that may arise in the design of computer circuitry.


Fig. 11-1. Procedural chain for algebraic manipulation.
Computational Methods and Circuit Design. The computational methods to be given depend on the systematic manipulation of designation numbers that will be described in this chapter. The procedure is first to turn the initial Boolean algebraic functions into designation numbers, then to perform the indicated computations with these numbers, and finally to transform the resulting numbers back into the final desired Boolean algebraic expressions. In this way algebraic manipulations are replaced by the systematic numerical computations to be described. This procedure is diagramed in Fig. 11-1.

As we have seen, two disciplines of study are brought together for the design of computer circuitry. The first is that of Boolean algebra, which


Frg. 11-2. From verbal statement to circuit diagram.
has broad applications to many fields. The second is that which is specific to digital-computer circuitry. Figure 11-2 diagrams procedures of the latter kind, some of which were described in the last chapter.

The first parts of the present chapter will be devoted to the procedures diagramed in Fig. 11-1; the rest of the chapter will be concerned with the procedures of Fig. 11-2 and their combination with those of Fig. 11-1. In fact the entire circuit-design problem can be summarized by the diagram in Fig. 11-3. The double-lined arrows refer to procedures that involve only Boolean algebra and the computational methods; the singlelined arrows refer to procedures unique to the digital-computer circuit problem.


Fig. 11-3. Combination of Figs. 11-1 and 11-2. The circuit-design problem outlined.

## 11-2. The Designation Numbers

The computational methods to be described involve binary numbers called designation numbers. To every element, elementary or combined, we associate a designation number. In doing a problem, the designationnumber representation for each proposition is obtained; the computations are performed in terms of these numbers; and finally the answer is reinterpreted in terms of propositions or sentences. The procedure for going from propositions to designation numbers will be considered first, and that for returning from designation numbers to propositions will follow.

The Basis. The designation numbers for the elementary elements are assigned first. Such an assignment is called a basis. One such basis for a system of three elementary elements is

$$
\begin{array}{lr} 
& 0123 \\
\# 5667 \\
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# C=0000 & 1111
\end{array}
$$

where the upper small numbers merely number the positions of the
columns of the basis. $\dagger$ For a system of $n$ elementary elements, $\ddagger$ there are $2^{n}$ digits, or bits, in each designation number and hence $2^{n}$ columns in a basis. Any permutation of the columns of the basis shown will result in a different but nonetheless valid basis. The columns of a valid basis for $n$ elementary elements need only represent all the $2^{n}$ possible combinations of 0 and 1 taken $n$ at a time. Hence there can be $2^{n}!$ different bases.

One advantage of the type of basis illustrated above is that it may be written out directly for any number of elementary elements as follows: the number for the first elementary element alternates zeros and units; for the second alternates pairs of zeros and units; for the third alternates 4 zeros and 4 units; for the fourth would alternate 8 zeros and 8 units, and so forth, each such designation number being extended to comprise the full complement of $2^{n}$ bits. The column positions of the basis are numbered from the left, from 0 through $2^{n}-1$. Such a basis is called a standard basis, and unless otherwise stated it is always assumed that all designation numbers refer to this type of basis. Following this convention we have, for example, in the case of four elementary elements, the standard basis:

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | $\mathbf{1 2}$ | 13 | 14 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\# A=0$ | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\# B=0$ | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| $\# C=0$ | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\# D=0$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

Observe that each column of a standard basis, read from the bottom to the top, forms a binary number which is the same as the number of the column position. For example, column 3 is $\underset{0}{\substack{1 \\ 0}}$ corresponding to $0011=3$ (decimal), and column 14 is $\underset{1}{0} \begin{aligned} & 0 \\ & 1 \\ & 1\end{aligned}$ corresponding to $1110=14$ (decimal).

Determining the Designation Number of a Boolean Function. In order to find \# $(A+B)$, we define an operation of "logical addition," to be performed on $\# A$ and $\# B$, wherein $0+0=0,0+1=1+0=1$, and $1+1=1$ without carry. For example, with respect to the standard basis for two elementary elements,

$$
\begin{aligned}
\# A & =0101 \\
\# B & =0011 \\
\#(A+B) & =0111
\end{aligned}
$$

To find \# $(A \cdot B)$, we similarly define the position-by-position operation of "logical multiplication," wherein $0 \cdot 0=0,0 \cdot 1=1 \cdot 0=0$, and $1 \cdot 1=1$. For example,

$$
\begin{aligned}
\# A & =0101 \\
\# B & =0011 \\
\#(A \cdot B) & =0001
\end{aligned}
$$

$\dagger$ The \# symbol means "The designation number of . . . "
$\ddagger$ Also called basic symbols.

To find $\# \bar{A}$, we invert each digit of $\# A$, that is, change 0 to 1 and 1 to 0 . For example,

$$
\# \bar{A}=1010
$$

With these operations on designation numbers in mind, we determine the designation number of a combined element merely by performing the indicated operations with respect to the chosen basis. For example, to find $\#(\bar{A}+B \cdot C)$, we have, with respect to a basis for three elementary elements,

$$
\begin{array}{rlr}
\# B & =0011 & 0011 \\
\# C & =0000 & 1111 \\
\#(B \cdot C) & =0000 & 0011 \\
\# \bar{A} & =1010 & 1010 \\
\#(\bar{A}+B \cdot C) & =1010 & 1011
\end{array}
$$

There should be no confusion as to the dual role of the symbols $+, \cdot,-$ When applied to propositions $A, B, C, \ldots$, they are the logical operations or, and, and not, respectively; when applied to designation numbers $\# A, \# B, \# C, \ldots$, , they are the numerical operations logical add, logical multiply, and invert, respectively.

Important Results. Some important results of this digitalization of propositions are: (1) $\# I=1111 \cdots$; that is, $\# I$ has all units. (2) $\# X=\# Y$ if, and only if, $X=Y$. (3) $X \rightarrow Y$ if, and only if, $\# Y$ has units in at least those positions which correspond to the units of $\# X$.

For example, to demonstrate equivalences, we simply calculate the designation number of each side; if they are identical, the equation holds. To show that $A \cdot B+A \cdot C+\bar{B} \cdot C=A \cdot B+\bar{B} \cdot C$, we find

$$
\#(A \cdot B)=0001 \quad 0001 \quad \#(A \cdot C)=0000 \quad 0101
$$

and

$$
\#(\vec{B} \cdot C)=0000 \quad 1100
$$

whence

$$
\#(A \cdot B+A \cdot C+\bar{B} \cdot C)=0001 \quad 1101
$$

but $\#(A \cdot B+\bar{B} \cdot C)=00011101$ also, whence the equivalence must hold. To show that an implication is true, simply show that the implied proposition has units in at least the same position as the implier. For example, to demonstrate that $A \cdot B+\bar{B} \cdot C \rightarrow A+C$, we note that $\#(A \cdot B+\bar{B} \cdot C)=0001_{3}^{3}{ }^{4} 10{ }^{7}$, which has units in positions $3,4,5$, and 7 ; also $\#(A+C)=0101$ 1111, which obviously has units in at least these positions.

Basis and Truth Tables. To see the relationship between the truth tables and the basis, observe that, if in the truth table of Sec. $10-5, T$ is replaced by 1 and $F$ is replaced by 0 and the columns are written as rows, then a basis results, together with the designation number of $\bar{A}+B \cdot C$.

$$
\begin{array}{ll}
0101 & 0101=\# A \\
0011 & 0011=\# B \\
0000 & 1111=\# C \\
\hline 1010 & 1011=\#(\bar{A}+B \cdot C)
\end{array}
$$

The reason for this is as follows: The main feature of our basis is that the $2^{n}$ columns represent all the $2^{n}$ possible arrangements of $n$ digits, each place of which can be 0 or 1 . This corresponds precisely to all possible truth values of $n$ elementary elements.

The limitations of the truth-table method as compared with our numerical basis hinge on the fact that the order of the columns of the basis is fixed by the basis, while in the truth table it makes no difference in what order the rows are considered. (The truth table illustrated above was chosen so as to compare with our basis.) Thus merely to specify a particular combined element it is necessary to present a complete "two-dimensional" truth table. The usefulness and applicability of truth tables have therefore been confined primarily to elementary didactic discussions and visual aid rather than as a notational representation for extensive computational techniques.

## EXERCISES

With respect to standard bases determine the following:


## 11-3. The First and Second Canonical Forms

From Designation Number to Boolean Function. Given a designation number, there is a systematic method for finding its symbolic Boolean algebraic representation in several different forms. For an example of five different equivalent representations of the same designation number, consider the number 01110100 . (1) The first canonical form of this is $A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}+A \cdot \bar{B} \cdot C$. (2) The second canonical form is $(A+B+C) \cdot(A+B+\bar{C}) \cdot(A+\bar{B}+\bar{C}) \cdot(\bar{A}+\bar{B}+\bar{C})$. (3) The simplest sum-of-products form is $A \cdot \bar{B}+B \cdot \bar{C}$. (4) The simplest product-of-sums form is $(A+B) \cdot(\bar{B}+\bar{C})$. (5) A mongrel form is $(A+B) \cdot \bar{C}+A \cdot \bar{B} \cdot C$. All these combined elements are equivalent. In this section systematic methods for obtaining the first two forms are given; the methods for finding the latter three forms are given in subsequent sections.

The First Canonical Form. The so-called first canonical form, also called the disjunctive normal form, is a sum of elementary products. An
elementary product is a product that contains all the elementary elements or their negations. For example, all possible elementary products for three elementary elements are $\bar{A} \cdot \bar{B} \cdot \bar{C}, A \cdot \bar{B} \cdot \bar{C}, \bar{A} \cdot B \cdot \bar{C}, A \cdot B \cdot \bar{C}$, $\bar{A} \cdot \bar{B} \cdot C, A \cdot \bar{B} \cdot C, \bar{A} \cdot B \cdot C$, and $A \cdot B \cdot C$. Observe that the designation of an elementary product always has a single unit. For example,

$$
\begin{array}{ll}
\#(\bar{A} \cdot \bar{B} \cdot \bar{C})=1000 & 0000 \\
\#(A \cdot \bar{B} \cdot \bar{C})=0100 & 0000 \\
\#(\bar{A} \cdot B \cdot \bar{C})=0010 & 0000 \\
\#(A \cdot B \cdot \bar{C})=0001 & 0000 \\
\#(\bar{A} \cdot \bar{B} \cdot C)=0000 & 1000 \\
\#(A \cdot \bar{B} \cdot C)=0000 & 0100 \\
\#(\bar{A} \cdot B \cdot C)=0000 & 0010 \\
\#(A \cdot B \cdot C)=0000 & 0001
\end{array}
$$

For $n$ elementary elements there are $2^{n}$ such products. The first canonical form of a designation number is the sum of only those elementary products each of which contributes a unit to the number. For example, 01000011 has units in positions 1, 6, and 7 and can therefore be constructed by summing the elementary products whose designation numbers have units in positions 1,6 , and 7. Hence, we have

$$
\begin{array}{ll}
\#(A \cdot \bar{B} \cdot \bar{C})=0100 & 0000 \\
\#(\bar{A} \cdot B \cdot C)=0000 & 0010 \\
\#(A \cdot B \cdot C)=0000 & 0001 \\
\hline+A \cdot B \cdot C)=0100 & 0011
\end{array}
$$

i.e., the first canonical form representation of 01000011 is

$$
A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot C+A \cdot B \cdot C
$$

The Second Canonical Form. To find the second canonical form, also called the conjunctive normal form, note that the designation number of the sum of all the elementary elements or their negations has exactly one zero:

$$
\begin{array}{ll}
\#(\bar{A}+\bar{B}+\bar{C})=1111 & 1110 \\
\#(A+\bar{B}+\bar{C})=1111 & 1101 \\
\#(\bar{A}+B+\bar{C})=1111 & 1011 \\
\#(A+B+\bar{C})=1111 & 0111 \\
\#(\bar{A}+\bar{B}+C)=1110 & 1111 \\
\#(A+\bar{B}+C)=1101 & 1111 \\
\#(\bar{A}+B+C)=1011 & 1111 \\
\#(A+B+C)=0111 & 1111
\end{array}
$$

These sums are called elementary sums; for $n$ elements there are $2^{n}$ elementary sums. The conjunctive normal form corresponding to a given designation number is the product of those elementary sums which correspond to the zeros in the designation number. For example, for 02345
01000011 we have zeros in positions $0,2,3,4$, and 5 , and hence

$$
\begin{aligned}
& \#[(A+B+C) \cdot(A+\bar{B}+C) \cdot(\bar{A}+\bar{B}+C) \cdot(A+B+\bar{C}) \cdot(\bar{A}+B+\bar{C})] \\
&=0100 \quad 0011
\end{aligned}
$$

This follows because each elementary sum in the product contributes one of the zeros of the designation number.

$$
\begin{array}{rll}
\#(A+B+C) & =0111 & 1111 \\
\#(A+\bar{B}+C) & =1101 & 1111 \\
\#(\bar{A}+\bar{B}+C) & =1110 & 1111 \\
\#(A+B+\bar{C}) & =1111 & 0111 \\
\#(\bar{A}+B+\bar{C}) & =1111 & 1011 \\
\hline \# \text { (product }) & =0100 & 0011
\end{array}
$$

as desired.

## EXERCISES

Find the first and second canonical form corresponding to the following designation numbers:
(a) $1001 \quad 0110$
(b) $0101 \quad 0101$
(c) $1000 \quad 0001$
(d) $0111 \quad 1110$
(e) 1011
(f) 0010
(g) 101100010110

$$
\begin{aligned}
& \text { Answer } \\
& \#[\bar{A} \cdot \bar{B} \cdot \bar{C}+A \cdot B \cdot \bar{C}+A \cdot \bar{B} \cdot C+\bar{A} \cdot B \cdot C] \\
& \#[(\bar{A}+B+C) \cdot(A+\bar{B}+C) \cdot(A+B+\bar{C}) \\
& \quad \cdot(\bar{A}+\bar{B}+\bar{C})] \\
& \#[A \cdot B \cdot C+A \cdot B \cdot \bar{C}+A \cdot \bar{B} \cdot C+A \cdot \bar{B} \cdot \bar{C}] \\
& \#[(A+B+C) \cdot(A+\bar{B}+C) \cdot(A+B+\bar{C}) \\
& \quad \cdot(A+\bar{B}+\bar{C})] \\
& \#[\bar{A} \cdot \bar{B} \cdot \bar{C}+A \cdot B \cdot C] \\
& \#[(\bar{A}+B+C) \cdot(A+\bar{B}+C) \cdot(\bar{A}+\bar{B}+C) \\
& \quad \cdot(A+B+\bar{C}) \cdot(\bar{A}+B+\bar{C}) \cdot(A+\bar{B}+\bar{C})] \\
& \#[A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}+\bar{A} \cdot \bar{B} \cdot C \\
& \quad+A \cdot \bar{C} \cdot C+\bar{A} \cdot B \cdot C] \\
& \#[(A+B+C) \cdot(\bar{A}+\bar{B}+\bar{C})] \\
& \#[\bar{A} \cdot \bar{B}+\bar{A} \cdot B+A \cdot B] \\
& \#[\bar{A}+B] \\
& \#(\bar{A} \cdot B) \\
& \#[(A+B) \cdot(\bar{A}+B) \cdot(\bar{A}+\bar{B})] \\
& \#[\bar{A} \cdot \bar{B} \cdot \bar{C} \cdot \bar{D}+\bar{A} \cdot B \cdot \bar{C} \cdot \bar{D}+A \cdot B \cdot \bar{C} \cdot \bar{D} \\
& \quad+A \cdot B \cdot C \cdot \bar{D}+A \cdot \bar{B} \cdot \bar{C} \cdot D+\bar{A} \cdot B \cdot \bar{C} \cdot D \\
& \quad+A \cdot \bar{B} \cdot C \cdot D+A \cdot B \cdot C \cdot D] \\
& \#[(\bar{A}+B+C+D) \cdot(A+B+\bar{C}+D) \\
& \quad(\bar{A}+B+\bar{C}+D) \cdot(A+\bar{B}+\bar{C}+D) \\
& \quad(A+B+C+\bar{D}) \cdot(\bar{A}+\bar{B}+C+\bar{D}) \\
& \quad(A+B+\bar{C}+\bar{D}) \cdot(A+\bar{B}+\bar{C}+\bar{D})]
\end{aligned}
$$

## 11-4. Included and Nonincluded Elementary Elements

Elimination Pairs of Positions. Certain information about a Boolean function can be obtained from the designation number even before the Boolean function is explicitly displayed. For example, 00111111 can be written as a function in which $A$ does not appear. To see this, consider the first canonical form of 0011 1111, namely,

$$
\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}+\bar{A} \cdot \bar{B} \cdot C+A \cdot \bar{B} \cdot C+\bar{A} \cdot B \cdot C+A \cdot B \cdot C
$$

This can be factored as follows:

$$
(\bar{A}+A) \cdot B \cdot \bar{C}+(\bar{A}+A) \cdot \bar{B} \cdot C+(\bar{A}+A) \cdot B \cdot C
$$

but $\bar{A}+A=I$, whence the expression reduces to

$$
B \cdot \bar{C}+\bar{B} \cdot C+B \cdot C
$$

in which $A$ does not appear explicitly. This example illustrates how it may be possible to combine pairs of elementary products so as to eliminate an elementary element from appearing explicitly in the form of a Boolean expression. On the other hand, if only one of a pair of elementary products is in the canonical form, then $A$ could not be eliminated; e.g., consider 0001 1111. The canonical form is

$$
A \cdot B \cdot \bar{C}+\bar{A} \cdot \bar{B} \cdot C+A \cdot \bar{B} \cdot C+\bar{A} \cdot B \cdot C+A \cdot B \cdot C
$$

and on combining pairs
or

$$
A \cdot B \cdot \bar{C}+(\bar{A}+A) \cdot \bar{B} \cdot C+(\bar{A}+A) \cdot B \cdot C
$$

in which $A$ appears explicitly. (It can be shown that no equivalent function exists in which $A$ does not appear.) Hence we have shown that it is plausible to expect that the necessary occurrence or nonoccurrence (i.e., necessary inclusion or noninclusion) of an elementary element can be determined by observing the canonical form or, what is close to the same thing, by directly observing the designation number. Such is the case, and the purpose of this section is to present rules for such determinations.


Fig. 11-4. Elimination-pair positions for three variables.
These rules are given as properties of so-called elimination pairs of positions of the designation number. Each elementary element has a set of pairs of positions. For three elementary elements, with respect to the standard basis the numbers of the positions of these pairs are

| $A:$ | $(0,1)$ | $(2,3)$ | $(4,5)$ | $(6,7)$ |
| :--- | :--- | :--- | :--- | :--- |
| $B:$ | $(0,2)$ | $(1,3)$ | $(4,6)$ | $(5,7)$ |
| $C:$ | $(0,4)$ | $(1,5)$ | $(2,6)$ | $(3,7)$ |

The elimination pairs may be visualized as shown in Fig. 11-4. The
extension of this system to four elementary elements follows directly:

| $A:$ | $(0,1)$ | $(2,3)$ | $(4,5)$ | $(6,7)$ | $(8,9)$ | $(10,11)$ | $(12,13)$ | $(14,15)$ |
| :--- | :--- | :--- | :--- | :--- | :--- | ---: | ---: | ---: |
| $B:$ | $(0,2)$ | $(1,3)$ | $(4,6)$ | $(5,7)$ | $(8,10)$ | $(9,11)$ | $(12,14)$ | $(13,15)$ |
| $C:$ | $(0,4)$ | $(1,5)$ | $(2,6)$ | $(3,7)$ | $(8,12)$ | $(9,13)$ | $(10,14)$ | $(11,15)$ |
| $D:$ | $(0,8)$ | $(1,9)$ | $(2,10)$ | $(3,11)$ | $(4,12)$ | $(5,13)$ | $(6,14)$ | $(7,15)$ |

Nonincluded Elementary Elements. Now that we have defined the elimination pairs with respect to the standard basis, the rules can be stated.
rule 1. A Boolean function can be written that does not involve explicitly an elementary element if in the designation number all the elimination pairs of positions for that elementary element contain either both zeros or both units.

For example, consider 0011 1111. The elimination pairs for $A$ satisfy rule 1 , for positions $(6,7)$ contain 11 , positions $(4,5)$ contain 11 , positions $(2,3)$ contain 11 , and positions $(0,1)$ contain 00 . Hence, as we have seen, a Boolean function for this designation number can be written in which $A$ does not appear explicitly.

Consider as another example 1101 1101. Here rule 1 is satisfied for the elimination pairs of $C$; that is, positions $(3,7)$ contain 11, positions $(2,6)$ contain 00 , positions $(1,5)$ contain 11 , and positions $(0,4)$ contain 11.

In fact its Boolean function is just $A+\bar{B}$, in which $C$ does not explicitly appear. In such a case we say that $C$ is a nonincluded elementary element. In the previous example $A$ was the nonincluded elementary element.

Included Elementary Elements. Next we shall give a rule for telling from the designation number whether an elementary element must appear explicitly in every form of the Boolean expression or whether the negation of the element must appear. However, we must first discuss the meaning of the appearance of an elementary element or its negation.

An elementary element or its negation is said to appear in a Boolean function if it appears when the function is reduced to one in which a bar is applied only to individual elementary elements. For instance, $A$ appears in the expression $(A+B) \cdot C$, whereas $\bar{A}$ does not appear. However, if we consider the expression $\overline{A \cdot B+C}$, it is not clear whether it is $A$ or $\bar{A}$ which appears; if this is reduced to $(\bar{A}+\bar{B}) \cdot \bar{C}$ [that is, $\overline{A \cdot B+C}=(\bar{A}+\vec{B}) \cdot \bar{C}]$ we see that $\bar{A}$ appears and $A$ does not. Similarly, for example, $\overline{\bar{A} \cdot B}+C=A+\bar{B}+C$, in which $A$ appears, and $\overline{\overline{\bar{A} \cdot B}+C}=\bar{A} \cdot B \cdot \bar{C}$, in which $\bar{A}$ appears.
rule 2. An elementary element (as distinguished from the negation of an elementary element) must appear explicitly in every Boolean functional representation of a designation number if at least one of the elimination pairs of positions of that elementary element contains 01.
rule 3. The negation of an elementary element must appear explicitly in every Boolean functional representation of a designation number if at least one of the elimination pairs of positions of that elementary element contains 10. For example, consider

$$
\begin{array}{rrrrrrrrrrrrrrrr}
0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & 10 & 11 & 12 & 13 & 14 & 15 \\
0 & 0 & 0 & 1 & 1 & 1 & 0 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 0 & 1
\end{array}
$$

Here $A$ must appear since the elimination pair (2,3) contains 01 . Both $B$ and $\bar{B}$ must appear since the elimination pair $(1,3)$ contains 01 and the pair $(4,6)$ contains 10 . Also $C$ and $\bar{C}$ must both appear since the elimination pair $(1,5)$ contains 01 and $(10,14)$ contains 10 . Only $D$ appears since $(0,8),(1,9)$, and $(2,10)$ each contain 01 , but $(3,11),(4,12),(5,13)$, and $(7,15)$ each contain 11 and $(6,14)$ contains 00 . In fact the Boolean function is $A \cdot B+\bar{B} \cdot C+\bar{C} \cdot D$. In this example we call $A, B, \bar{B}$, $C, \bar{C}$, and $D$ included elementary elements.

## EXERCISES

Find the included and nonincluded elementary elements for the following designation numbers:

| (a) | 0101 | 0101 |  | $A$ | $B, C$ |
| :--- | :--- | :--- | :--- | :--- | :--- |
| (b) | 1100 | 0011 |  | $B, \bar{B}, C, \bar{C}$ | $A$ |
| (c) | 0111 | 0111 |  |  | $A, B$ |
| (d) | 1111 | 1100 | 1100 | 1100 | $\bar{B}, \bar{C}, \bar{D}$ |
| (e) | 0000 | 1111 | 1010 | 1010 | $\bar{A}, C, D, \bar{D}$ |

## 11-5. Mongrel Forms

Examples of Mongrel Forms. The mongrel form is not a unique form; i.e., two people determining a mongrel form for the same designation number may not arrive at the same Boolean function. In general, in the mongrel form, anything goes, just as long as the final Boolean function actually represents the designation number under consideration. For example, consider the designation number 00010111 . We note that

$$
\begin{array}{rlr}
\# A & =0101 & 0101 \\
\# B & =0011 & 0011 \\
\# C & =0000 & 1111 \\
\#(A \cdot B) & =0001 & 0001 \\
\#(A+B) & =0111 & 0111
\end{array}
$$

But since $\# \bar{C}=11110000$, then $\# A \cdot B \cdot \bar{C}=00010000$; also, since $\# C=0000$ 1111, then $\#(A+B) \cdot C=0000$ 0111, whence

$$
00010111=\#[A \cdot B \cdot \bar{C}+(A+B) \cdot C]
$$

or $A \cdot B \cdot \bar{C}+(A+B) \cdot C$ is a mongrel form. The mongrel form is
particularly useful in more complicated cases. For example, consider 00010111011100011110111010001000 . Here we have the basis

| $\# A=0101$ | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\# B=0011$ | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 |
| $\# C=0000$ | 1111 | 0000 | 1111 | 0000 | 1111 | 0000 | 1111 |
| $\# D=0000$ | 0000 | 1111 | 1111 | 0000 | 0000 | 1111 | 1111 |
| $\# E=0000$ | 0000 | 0000 | 0000 | 1111 | 1111 | 1111 | 1111 |

Since

$$
\begin{array}{rllllllll}
\#(A \cdot B) & =0001 & 0001 & 0001 & 0001 & 0001 & 0001 & 0001 & 0001 \\
\#(A+B) & =0111 & 0111 & 0111 & 0111 & 0111 & 0111 & 0111 & 0111 \\
\#(\bar{A}+\bar{B}) & =1110 & 1110 & 1110 & 1110 & 1110 & 1110 & 1110 & 1110 \\
\# \bar{A} \cdot \bar{B} & =1000 & 1000 & 1000 & 1000 & 1000 & 1000 & 1000 & 1000
\end{array}
$$

and

| $\#(\bar{C} \cdot \bar{D} \cdot \bar{E})=1111$ | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\#(C \cdot \bar{D} \cdot \bar{E})=0000$ | 1111 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| $\#(\bar{C} \cdot D \cdot \bar{E})=0000$ | 0000 | 1111 | 0000 | 0000 | 0000 | 0000 | 0000 |
| $\#(C \cdot D \cdot \bar{E})=0000$ | 0000 | 0000 | 1111 | 0000 | 0000 | 0000 | 0000 |
| $\#(\bar{D} \cdot E)=0000$ | 0000 | 0000 | 0000 | 1111 | 1111 | 0000 | 0000 |
| $\#(D \cdot E)=0000$ | 0000 | 0000 | 0000 | 0000 | 0000 | 1111 | 1111 |

we can immediately write down the following mongrel form:
$(A \cdot B) \cdot(\bar{C} \cdot \bar{D} \cdot \bar{E})+(A+B) \cdot(C \cdot \bar{D} \cdot \bar{E})+(A+B) \cdot(\bar{C} \cdot D \cdot \bar{E})$

$$
+(A \cdot B) \cdot(C \cdot D \cdot \bar{E})+(\bar{A}+\bar{B}) \cdot(\bar{D} \cdot E)+(\bar{A} \cdot \bar{B}) \cdot(\bar{D} \cdot E)
$$

A useful fact to remember in writing mongrel forms is that
and

$$
0110=\#(A \cdot \bar{B}+\bar{A} \cdot B)
$$

Of course this can be generalized to observe, for example, that
$0000 \quad 1111 \quad 1111 \quad 0000 \quad 0000 \quad 1111 \quad 1111 \quad 0000=\#(C \cdot \bar{D}+\bar{C} \cdot D)$ and
$1111000000000 \quad 1111 \quad 11110000 \quad 0000 \quad 1111=\#(C \cdot D+\bar{C} \cdot \bar{D})$
Applying this to 0001011101110001111011101000 1000, we find the mongrel form

$$
\begin{aligned}
{[(A \cdot B) \cdot(C \cdot D+\bar{C} \cdot \bar{D})+(A+B) \cdot} & (C \cdot \bar{D}+\bar{C} \cdot D)] \cdot \bar{E} \\
& +[(\bar{A}+\bar{B}) \cdot \bar{D}+\bar{A} \cdot \bar{B} \cdot D] \cdot E
\end{aligned}
$$

The writing of "good" mongrel forms depends on ingenuity and practice. Of course the individual component products and sums need not be written out explicitly as was done above. For example, consider 0110100110010110 . A little thought will enable the following mongrel form to be written down immediately:

$$
(A \cdot \bar{B}+\bar{A} \cdot B) \cdot(C \cdot D+\bar{C} \cdot \bar{D})+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot(C \cdot \bar{D}+\bar{C} \cdot D)
$$

## EXERCISES

Write down directly mongrel forms for:

| "Good" solution |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| (a) 0110 | 1001 |  |  | $(A \cdot \vec{B}+\bar{A} \cdot B) \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C$ |  |
| (b) 1001 | 0110 | 0110 | 1001 | $(A \cdot B+\bar{A} \cdot \bar{B}) \cdot(C \cdot D+\bar{C} \cdot \bar{D})$ |  |
|  |  |  |  |  | $+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot(C) \cdot \bar{D}+\bar{C} \cdot D)$ |
| (c) 0010 | 0100 | 0010 | 0010 | $\bar{A} \cdot B \cdot(\bar{C}+D)+(A \cdot \bar{B}) \cdot(C \cdot \bar{D})$ |  |
| (d) 1010 | 0010 | 0010 | 0010 | $\bar{A} \cdot \bar{C} \cdot \bar{D}+\bar{A} \cdot B$ |  |
| (e) 0111 | 1011 | 1101 | 1110 | $(A+\bar{B}) \cdot \bar{C} \cdot \bar{D}+(\bar{A}+B) \cdot C \cdot \bar{D}$ |  |
|  |  |  |  |  | $+(A+\bar{B}) \cdot \bar{C} \cdot D+(\bar{A}+\bar{B}) \cdot C \cdot D$ |
| (f) 1011 | 0111 | 1011 | 0111 | $(\bar{A}+B) \cdot(\bar{C} \cdot \bar{E})+(A+B) \cdot C \cdot \bar{E}+(\bar{C}+D) \cdot E$ |  |
|  | 1111 | 0000 | 1111 | 1111 |  |

## 11-6. Simplest Sum-of-products Representation $\dagger$

The Role of the Prime Implicants. This symbolic representation of a designation number has the property of being a sum of products with the least number of operations • and + . There may be several such forms associated with a single designation number. A systematic process can be described that will result in such a form. To understand this process, let us first discuss the general nature of a product.

The number of letters that enter into a product is called the number of terms in the product. Thus $A \cdot \bar{B} \cdot C$ is a three-term product, $A \cdot \bar{B}$ is a two-term product, and $A$ is called a one-term product. In general, for $n$ basic symbols, the designation number of an $n$-term product has $2^{0}(=1)$ unit, of an $(n-1)$-term product the designation number has $2^{1}$ units, of an ( $n-2$ )-term product it has $2^{2}$ units, . . ., of an $(n-s)$ term product the designation number has $2^{s}$ units. For example, $\# A \cdot \bar{B} \cdot C=00000100$ with 1 unit, $\# A \cdot \bar{B}=01000100$ with 2 units, and $\# A=01010101$ with 4 units. Another observation about products that follows directly is that, if $P$ and $P^{\prime}$ are products such that $\# P \rightarrow \# P^{\prime}$, then $P^{\prime}$ is formed from $P$ by deleting some of the terms of $P$. For example, $\# A \cdot \bar{B} \cdot C \rightarrow \# A \cdot \bar{B}$, the latter being formed by deleting $C$ from the former. The converse is evidently also true.

Now we can turn to the discussion of the simplest sum-of-products form. If $\# F$ is the designation number in question, consider a simplest sum-of-products representation of $\# F$. Clearly each product $P_{i}$ of the sum must be such that $\# P_{i} \rightarrow \# F$ (that is, $\# P_{i}$ cannot have units in positions where $\# F$ has zeros), for otherwise the sum of the products would not have the same designation number as $\# F$. Also, if this sum is indeed the simplest sum of products, then certainly no product $P_{i}$ of this sum can be replaced by a product $P_{i}^{\prime}$ such that $\# P_{i} \rightarrow P_{i}^{\prime}$, for then the resulting

[^7]sum of products would become even simpler (i.e., one of the products would have a term deleted). In other words, in order that a product $P$ be considered at all for inclusion in a simplest sum-of-products form for $\# F$, it must be such that:

1. $\# P \rightarrow \# F$.
2. There exists no $P^{\prime}$ such that $\# P \rightarrow \# P^{\prime}$ and $\# P^{\prime} \rightarrow \# F$.

If $P$ has the first property, it is called an implicant of $F$; if it also has the second, it is a prime implicant of $F$.

For example if $\# F=01110100$, then $A \cdot \bar{B} \cdot \bar{C}, \bar{A} \cdot B \cdot \bar{C}, A \cdot B \cdot \bar{C}$, $A \cdot \bar{B} \cdot C, A \cdot \bar{C}, A \cdot \bar{B}$, and $B \cdot \bar{C}$ are all implicants of $F$, as can be readily checked, but only $A \cdot \bar{C}, A \cdot \bar{B}$, and $B \cdot \bar{C}$ are prime implicants of $F$. To show that $A \cdot \bar{B}$ is a prime implicant of $F$, note that the only products implied by $A \cdot \bar{B}$ are $A$ and $\bar{B}$. But $\# A \nrightarrow \# F$, and $\# \bar{B} \nrightarrow F F$, and hence $A \cdot \bar{B}$ is a prime implicant of $F$. (On the other hand, $A \cdot \bar{B} \cdot C$ is not a prime implicant because $\# A \cdot \bar{B} \cdot C \rightarrow \# A \cdot \bar{B}$ and $\# A \cdot \bar{B} \rightarrow \# F$.)

There are two stages in determining the simplest sum-of-products form of $F$. The first is the systematic generation of all the prime implicants of $F$; the second is the selection from this collection of a subcollection of products the sum of which will truly be the simplest sum of products, as defined above. We shall now describe in detail how to generate all the prime implicants of a given designation number. Then we shall show how with the aid of a so-called prime-implicant chart the final simplest sum of products is chosen.

The First Stage-Generating the Prime Implicants. The rationale for generating the prime implicants can best be understood by examining the first canonical form. For 01110100 the first canonical form is $A \cdot \bar{B} \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}+A \cdot \bar{B} \cdot C$. The following reductions can be made by combining pairs of products:

$$
\begin{aligned}
& A \cdot \bar{B} \cdot \bar{C}+A \cdot \bar{B} \cdot C=A \cdot \bar{B} \cdot(\bar{C}+C)=A \cdot \bar{B} \cdot I=A \cdot \bar{B} \\
& \bar{A} \cdot B \cdot \bar{C}+A \cdot B \cdot \bar{C}=(\bar{A}+A) \cdot B \cdot \bar{C}=I \cdot B \cdot \bar{C}=B \cdot \bar{C}
\end{aligned}
$$

Thus the first canonical form reduces to $A \cdot \bar{B}+B \cdot \bar{C}$. We can determine whether or not two products can be combined by comparing the pair of associated basis columns: if the two columns differ in just one row, the terms can be combined. For instance, the pair $A \cdot \bar{B} \cdot \bar{C}, A \cdot \bar{B} \cdot C$
 similarly the pair $\vec{A} \cdot B \cdot \bar{C}, A \cdot B \cdot \bar{C}$ corresponds to the columns $\underset{\substack{0 \\ 0 \\ 0}}{\frac{1}{0}}$, which differ only in the first row. Based on these concepts, the first stage involves three steps. We shall illustrate these steps by following through a specific example.

Consider the following designation number in four basic symbols:

$$
\begin{array}{ccccccccccccccccc}
0 & 1 & & 3 & 4 & & 6 & 7 & & 9 & 10 & 11 & & 13 & 14 & 15 \\
1 & 1 & 0 & 1 & 1 & 0 & 1 & 1 & 0 & 1 & 1 & 1 & 0 & 1 & 1 & 1 & 1
\end{array}
$$

The first step is to display only the columns of the basis that correspond
to the units of the given designation number,

| 0 | 1 | 3 | 4 | 6 | 7 | 9 | 10 | 11 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 |
| 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 |

The second step is to arrange these columns in order by the number of units contained in each column.

| 0 -unit <br> columns | 1 -unit <br> columns | 2-unit <br> columns | 3-unit <br> columns | 4-unit <br> columns |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 10 | 1010 | 1110 | 1 |
| 0 | 00 | 1101 | 1101 | 1 |
| 0 | 01 | 0100 | 1011 | 1 |
| 0 | 00 | 0011 | 0111 | 1 |

The third step is an iterative process of combining pairs of columns that differ only in a single row. For example, ${\underset{0}{0} 0}_{0}^{0}$ and $\left.\underset{0}{1} \begin{array}{c}\frac{1}{0} \\ 0 \\ 0\end{array}\right)$ where the symbol $\Phi$ means 0 or 1 . Similarly ${ }_{\substack{0 \\ 0 \\ 0 \\ 0}}^{0} \underset{1}{0}{\underset{1}{0}}_{0}^{0}$ are combined to form $\begin{gathered}0 \\ 0 \\ 0 \\ 0\end{gathered}$. Note that, since the pairs are to differ in a single row only, each $u$-unit column need be compared with only ( $u+1$ )-unit columns. To combine with a $u$-unit column, a $(u+1)$-unit column must have $u$ of its $u+1$ units in the same rows as the $u$-unit column [i.e., the $u$-unit column must imply the ( $u+1$ )-unit column]. Thus the 1 -unit columns are combined with the 2 -unit columns as follows:


When a pair of columns are combined, a check is placed above them to record the fact. As will be seen shortly, this checking process is of the utmost importance. In this way the adjacent collections of $u$-unit
columns and $(u+1)$-unit columns are successively compared and checked. In our example, this results in

| $\checkmark$ | $\checkmark \checkmark$ | $\checkmark \checkmark \vee \checkmark$ | $\checkmark \checkmark \vee \checkmark$ | , |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 10 | 1010 | 1110 | 1 |
| 0 | 00 | 1101 | 1101 | 1 |
| 0 | 01 | 0100 | 1011 | 1 |
| 0 | 00 | 0011 | 0111 | 1 |
| $\Phi 0$ | 110 | 11 ¢ 0 | Ф 0 | $111{ }^{1}$ |
| 00 | $\Phi 0 \pm$ | 1111 | 11 | $11 \Phi 1$ |
| $0 \Phi$ | 001 | $\Phi 011$ | 0¢ | 1\$11 |
| 00 | $0 \Phi 0$ | $0 \Phi 0$ ¢ | 11 | \$111 |

The process is continued on this and each successive set of combined columns. But this time for two combined columns to be further combined they must have $\Phi$ s as well as units in the same rows. The process ends when no further combinations can be formed. For our example the rest of the work is shown below:

|  | $\checkmark \checkmark$ | $\checkmark \checkmark \checkmark \checkmark \checkmark \checkmark \checkmark \checkmark$ | $\checkmark \checkmark V \checkmark$ |
| :--- | :--- | :--- | :--- |
| $\Phi 0$ | 110 | $11 \Phi 011 \Phi 0$ | $111 \Phi$ |
| 00 | $\Phi 0 \Phi$ | $1111 \Phi 011$ | $11 \Phi 1$ |
| $0 \Phi$ | 001 | $\Phi 0110 \Phi 0 \Phi$ | $1 \Phi 11$ |
| 00 | $0 \Phi 0$ | $0 \Phi 0 \Phi 111$ | $\Phi 111$ |



Duplicate columns have been crosshatched above. The prime implicants can all now be read from the unchecked columns. For example, ${\underset{0}{0} 0}_{0}^{0}$ corresponds to $\bar{B} \cdot \bar{C} \cdot \bar{D}$, or ${ }_{\phi}^{\infty}$ corresponds to $A \cdot \bar{C}$, and so forth. For our example the prime implicants are thus $\bar{B} \cdot \bar{C} \cdot \bar{D}, \bar{A} \cdot \bar{B} \cdot \bar{D}, \bar{A} \cdot C \cdot \bar{D}$, $A \cdot \bar{C}, A \cdot B, B \cdot C, A \cdot D$, and $B \cdot D$.

The Second Stage-Using the Prime-implicant Chart. A chart showing the prime implicants is used in selecting for inclusion in the simplest sum of products those prime implicants which will produce the given designation number with the least number of operations $\cdot$ and + . The chart is simply a display of the prime-implicant designation-number unit positions. For our example this chart is shown in Table 11-1. (Note that, to determine, for instance, the unit positions of $\# \bar{B} \cdot \bar{C} \cdot \bar{D}$, we simply observe that $\bar{B} \cdot \bar{C} \cdot \bar{D}$ corresponded to $\begin{gathered}\begin{array}{c}0 \\ 0 \\ 0 \\ 0\end{array} .\end{gathered}$ The $\Phi$ in the first row means that $A$ was eliminated between the two columns $\stackrel{0}{0}_{\substack{0 \\ 0 \\ 0 \\ 0}}$ and ${ }_{0}^{1} \begin{aligned} & 0 \\ & 0 \\ & 0\end{aligned}$; the zeros indicate that $B, C$, and $D$ must be complemented in the two positions.

As another illustration, $A \cdot \bar{C}$ corresponds to $\stackrel{\begin{array}{c}1 \\ 0 \\ 0\end{array} \text {; the } \Phi s \text { indicate that }}{ }$ $B$ and $D$ have been eliminated, and the zero indicates that $C$ must be complemented.)
To choose the appropriate prime implicants for inclusion in the simplest sum of products, first note that $A \cdot D$ and $B \cdot D$ must be included because the units of $\# F$ in positions 10 and 13 are covered only by $B \cdot D$ and $A \cdot D$, respectively. If either $B \cdot D$ or $A \cdot D$ were left out of our sum, the designation number of the sum, lacking units in positions 10 or 13 , could never be the same as $\# F$. Prime implicants that must for this reason be included are called essential prime implicants. Thus part of our sum must be $A \cdot D+B \cdot D$.

Table 11-1. Prime-mplicant Chart


Next note that \# ( $A \cdot D+B \cdot D$ ) covers positions $9,10,11,13,14$, and 15 , leaving only positions $0,1,3,4,6$, and 7 to be covered by additional prime implicants. The second step in using the prime-implicant chart is, then, to choose in the best possible way from the nonessential prime implicants those combinations whose sum will cover unit positions of \#F not already covered by the sum of the essential prime implicants. There is no known systematic procedure for doing this, except for trying all combinations. For our illustration it can be seen that $\bar{A} \cdot \bar{B} \cdot \bar{D}+A \cdot \bar{C}+B \cdot C$ will cover positions $0,1,3,4,6$, and 7 in the best way. (Note that $\bar{B} \cdot \bar{C} \cdot \bar{D}+\bar{A} \cdot C \cdot \bar{D}+A \cdot B$ will also cover positions $0,1,3,4,6$, and 7 , but has one more operation $\cdot$ than the best choice.)
Thus we finally have for the simplest sum-of-products form of the designation number 1101101101110111

$$
A \cdot D+B \cdot D+\bar{A} \cdot \bar{B} \cdot \bar{D}+A \cdot \bar{C}+B \cdot C
$$

Summary. Summarizing, the process of finding the simplest sum-ofproducts form for a given designation number $\# F$ has two stages. The
first stage is the determination of all the prime implicants of \#F by combining pairs of basis columns that correspond to the unit positions of \#F. To aid the formation of the combinations, the columns are first ordered into a 0 -unit collection, 1 -unit collection, 2 -unit collection, etc. The prime implicants are represented by those columns which do not enter into any further combinations, i.e., which are left unchecked when all combinations have been made. The second stage is to choose in the best way those prime implicants which are to be included in the simplest sum of products. As an aid to making this choice the prime-implicant chart is constructed, and from this essential prime implicants are noted. Then from the nonessential prime implicants a best sum is chosen to cover those units of $\# F$ not covered by the sum of the essential prime implicants. The simplest sum of products then becomes the sum of the essential prime implicants and this best sum of the nonessential prime implicants.

## EXERCISES

Find the simplest sum-of-products forms of the following designation numbers:
Solution


The simplest product-of-sums form is a product of sums that has the least number of operations + and . Find the simplest product-of-sums forms of each of the following designation numbers. (Hint: Work with the zeros instead of the units.)

## Solution

(f) $1001 \quad 1010$

$$
\begin{aligned}
& (\bar{A}+B) \cdot(A+\bar{B}+C) \cdot(\bar{A}+\bar{B}+\bar{C}) \\
& (B+\bar{C}+D) \cdot(B+C+\bar{D}) \cdot(A+\bar{B}+\bar{D}) \\
& \quad \cdot(\bar{A}+\bar{C}+\bar{D})
\end{aligned}
$$

(g) $11110011 \quad 0001 \quad 1000$
(h) $0100 \quad 1001 \quad 1101 \quad 0110$
(i) $0110 \quad 0101 \quad 1001 \quad 1010$
(j) $000100110111 \quad 1111$

## 11-7. Obtaining Essential Prime Implicants Directly $\dagger$

Preliminary Notational Review. Let us recall the meaning of our $\Phi$


$\dagger$ The method of this section is based on R. D. Elbourn's adaptation of a method developed by Harris. (See B. Harris, An Algorithm for Determining Minimal Representation of a Logic Function, IRE Trans. on Electronic Computers, vol. EC-6, pp. 103-108, June, 1957.)
$\Phi$ in $p$ of its rows, it represents $2^{p}$ basis columns, in which the $p$ rows are filled in all $2^{p}$ possible ways. Recall also that we interpret ${ }_{0}^{1} 0$ mean $A \cdot \bar{B} \cdot \bar{C}$, with $D$ eliminated; similarly $\AA_{\AA}^{1}$ means $A$, with $B, C$, and $D$ eliminated, and so forth. We interpret a basis column as a binary number, with the least significant digit on top, and thus the rows in a basis column are associated with successive powers of 2 ; for example, for four variables

$$
\begin{aligned}
& A \leftrightarrow 2^{0}=1 \\
& B \leftrightarrow 2^{1}=2 \\
& C \leftrightarrow 2^{2}=4 \\
& D \leftrightarrow 2^{3}=8
\end{aligned}
$$

Hence we shall refer to the power position of a bit in a column (e.g.,
 power positions 1 and 8). Finally, observe that the $2^{p}$ basis column numbers represented by a column with $p$ of its components $\Phi$ can be found by taking the number formed with the $\Phi s$ read as zeros and adding all combinations of powers of 2 corresponding to the power positions of the $\Phi$ s. For example, ${ }_{0}^{1}{ }_{0}^{1}$ represents basis columns 1 and $1+8=9$, and ${ }_{8}^{\frac{1}{\circ}}$ represents basis columns $1,1+8=9,1+4=5,1+2=3$, $1+8+4=13,1+8+2=11,1+4+2=7$, and $1+8+4+2$ $=15$.
Finding the Essential Prime Implicants Directly. In essence, in the previous simplification method we tried all combinations to obtain columns with the most $\Phi$ s by a uniform "building-up" process. These columns then represented the prime implicants, and we had to make a prime-implicant table in order to choose the essential prime implicants. Now, however, we shall approach the problem from a different point of view. We focus our attention on a single column at a time (a column corresponding to a unit of the given designation number); if we can show that this column is in a single prime implicant, then that prime implicant must be essential (in such a case we say that the essential prime implicant is based on this column). If we make this examination for each (unit) column, then clearly we shall have determined all essential prime implicants, because an essential prime implicant is a prime implicant that has at least one (unit) column contained in no other prime implicant.

To find whether a column is in a single prime implicant, first find all columns that differ from it in only one power position, i.e., by only 1 bit. Suppose that there are $p$ such power positions (that is, $p$ columns). Then determine whether or not columns occur that have all possible
combinations of 0 and 1 in these power positions, that is, $2^{p}$ columns altogether. If so, the original column is in an essential prime implicant. Suppose, for example, we are given a column $\underset{\substack{1 \\ 0 \\ 0}}{1}$. The first step is to find all columns which differ from this by only 1 bit. Suppose that
 1 bit). Then-and this is the crux of our whole argument-the column 1
0 $0_{0}^{0}$ will be in a single prime implicant (i.e., essential) only if columns
 tion written as $\stackrel{1}{\frac{1}{\circ}}{ }_{!}^{\circ}$. The essential prime implicant would be in this case simply $A$. On the other hand, suppose, say, that ${ }_{1}^{1}$ i were missing; then we have the following reduction by our above simplification method:
 three prime implicants.

Systematic Method of Procedure. A systematic method of procedure is as follows: Write out the columns corresponding to units of the designation number. For any given column under consideration find another column that also occurs differing in 1 bit, say in power position $p_{1}$. Next find a second column that occurs differing from the original columns in 1 bit, say in power position $p_{2}$; then make sure the other column occurs that completes the $2^{2}$ combinations of 0 and 1 in both these power positions, $p_{1}$ and $p_{2}$. Next find a third column that occurs differing in 1 bit from the original column, say in power position $p_{3}$; make sure all other columns also occur that complete all $2^{3}$ combinations of 0 and 1 in these three power positions $p_{1}, p_{2}, p_{3}$; and so forth. This process will stop either when for a certain number of power positions all combinations do not occur (in which case our original column is in more than one prime implicant) or when no further columns occur that differ from the original column in only one power position (in which case the original column is in an essential prime implicant).

This process can be tabulated. Let us illustrate with the following designation number:

|  | 1 |  | 3 | 4 | 5 | 6 | 7 |  | 9 |  | 11 |  | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 |

The first step is to make the prime-implicant table format with the

Sec. 11-7] designation numbers and function circuits
successive power positions to the right,

| 1 | 4 |
| :--- | :--- |\(\left|\begin{array}{llll} \& <br>

3 \& 5 \& 6 \& 9\end{array}\right|\)\begin{tabular}{llll}
\& \& <br>
7 \& 11 \& 13 \& 14

$|15|$

Power positions <br>
$D$ \& $C$ \& $B$ \& $A$ <br>
8 \& 4 \& 2 \& 1 <br>
\hline
\end{tabular}

We have grouped the column numbers according to the number of units in the column. Start, say, with the leftmost column as the original given column, and write its binary form (as a row for convenience) under the power positions; place an x under the 1 to record that this is the column under consideration:

| 14 | $\begin{array}{cccc}3 & 5 & 6 & 9\end{array}$ | 7 | 11 | 13 | 14 | 15 | $D$ <br> 8 | $C$ 4 | 2 | A 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| x |  |  |  |  |  |  | 0 | 0 |  | 1 |

Now ask: Does the column occur that differs from the original column in power position 8 , that is, does column $1+8=9$ occur? It does; so we record this by placing an 8 under column number 9 and changing 0001 to Ф001 since both these columns do occur:


Next ask: Does the column occur that differs from the original column in power position 4 , that is, does column $1+4=5$ occur? Yes. Do all $2^{2}$ combinations occur? To answer this, note that $9+4=13$, and column 13 does occur, so the answer is "yes." Thus we can change $₫ 001$ to $\Phi \varnothing 01$, and record the work as follows:

| 14 | 3 | 5 | 6 | 9 | 7 | 11 | 13 | 14 | 15 |  | C | 2 | A 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| x |  | 4 |  | 8 |  |  | 4 |  |  | $\pm$ | $\underline{\$}$ | 0 | 1 |

Next, try power position 2 : column $1+2=3$ occurs; so try $5+2=7$, $9+2=11$, and $13+2=15$. All these columns occur, and hence all combinations of 0 and 1 occur in the three power positions 2, 4, and 8; hence we have

| 1 | 4 | 3 | 5 | 6 | 9 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| x | 2 | 4 | 8 | 7 | 11 |

Next try power position 1. Note that, since column 1 has a unit in power position 1, the column that differs from column 1 in this position only is
column $1-1=0$. But column 0 does not occur, and therefore column 1 is in a single, hence essential, prime implicant, namely, $A$.

At this point we are ready to see the main advantage of the present method. Since we have found an essential prime implicant that covers columns $1,3,5,9,7,11,13$, and 15 , we need no longer worry about covering them. So our problem is reduced to covering only columns 4, 6, and 14. Thus we check off all columns except these and choose column 4 as our next given column,


The process for column 4 is the same. However, note that, in considering a power position corresponding to a zero in the original column, we add this power of 2 in order to determine what combinations of columns should occur, i.e., change the zero to a unit; if the power position corresponds to a unit in the original column, we would subtract this power of 2 in order to determine what columns should occur, i.e., change the 1 to a 0 . The work for column 4 becomes


Here column $4+8=12$ did not occur, nor did column 4-4=0. But column $4+2=6$ did occur, and so did columns $4+1=5$ and $6+1=7$. Thus we can check columns 4 and 6 . Only column 14 remains unchecked; so we choose this column as the next given column. The work appears as follows:

| $\begin{array}{ll} \checkmark & \checkmark \\ 1 & 4 \end{array}$ |  |  | 6 | $V$ 9 |  |  |  |  | $\checkmark$ 15 | D <br> 8 | C | $B$ 2 | $A$ 1 | Essential prime implicant |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| x | 2 | 4 | 2 8 |  | 2 1 1 |  |  | $x$ | 2 1 | $\$$ 0 $\$$ | $\pm$ 1 1 | \$ | 1 $\$$ $\$$ | $A$ $\bar{D} \cdot C$ C $\cdot$ B |

Column $14-8=6$ occurs; column $14-4=10$ does not occur; column $14-2=12$ does not occur; columns $14+1=15,6+1=7$ do occur. Hence $C \cdot B$ is an essential prime implicant.

Examples and Discussion. Consider the following designation number, and let us find its simplest sum-of-products form:


The work format appears as follows:


Note that in adding (or subtracting) to a column number the result is always in an adjacent group of column numbers (to the right in adding, to the left in subtracting). For column 1 we find $1+16=17$, which occurs; $1+8=9$, which does not occur $; 1+4=5,17+4=21$, both of which occur; $1+2=3,5+2=7,17+2=19$, and $21+2=23$, all of which occur; but $1-1=0$ does not occur. Thus an essential prime implicant has been found, namely, $\bar{D} \cdot A$, and column numbers $1,3,5,17,7$, 19,21 , and 23 need not be used as a given column again. Note that nothing combined with column 8 . When column number 26 is the given column, note that neither $26-16=10$ nor $26-8=18$ occurs; but $26+4=30$ occurs. Continuing, $26-2=24$ does not occur, but $26+1=27$ does occur; however, $30+1=31$ does not occur, and no essential prime implicant is found-we encircle the 1 to show that it did not combine with 30 . Similarly, when 30 is the given column number, $30-8=22$ occurs, and $30-4=26$ occurs; but $22-4=18$ does not occur, and so we have encircled the 4 . The only column not covered by an essential prime implicant is column 30 ; this can be covered in two ways, namely, by $E \cdot D \cdot B \cdot \bar{A}$ or by $E \cdot C \cdot B \cdot \bar{A}$. Hence the result is

$$
\begin{aligned}
& A \cdot \bar{D}+\bar{A} \cdot \bar{B} \cdot \bar{C} \cdot D \cdot \bar{E}+\bar{B} \cdot \bar{D} \cdot E+B \cdot C \cdot \bar{D}+B \cdot \bar{C} \cdot D \cdot E \\
&+\left\{\begin{array}{l}
\bar{A} \cdot B \cdot D \cdot E \\
\bar{A} \cdot B \cdot C \cdot E
\end{array}\right.
\end{aligned}
$$

Consider a six-variable problem with units in the following designationnumber positions: $1,3,4,5,7,13,17,19,20,23,31,33,35,36,37,39$, $44,45,49,51,52,53,55,60$, and 61 . The work is shown in Table 11-2, in which the columns are grouped appropriately. Here we have introduced a variation of the present method. For example, starting with column number 1 we find that $1+32=33$ occurs; $1+16=17$ and $33+16=49$ both occur; $1+8=9$ does not occur; but although $1+4=5$ occurs, $17+4=21$ does not occur, and so we encircle 4 . Now instead of proceeding as above let us see if we can at this point make further use of the information so far obtained, namely, $\Phi \boldsymbol{\Phi} 0001$. To do this, suppose that we transfer to column number 17 as our given column; we indicate this transfer by putting a slash through the 16 below column number 17, as is shown. Then $\Phi \Phi 0001$ still holds
for column 17, and we need not try power 32 or power 16 again or, for that matter, power 4 (why?). But we must try power 8 again, for we have never tried it on this column (why not?). Thus $17+8=25$ does not occur; but $17+2=19,1+2=3,33+2=35,49+2=51$ all occur, giving us $\Phi \Phi 00 \Phi 1$. Finally $17-1=16$ does not occur; so we have discovered an essential prime implicant, based on column 17 rather than on the column we started with, column 1. The next two rows of work in Table 11-2 also indicate a transfer to some other column number in finding the essential prime implicant.

Next observe the fourth row of work. Here we meet several further circumstances, which we shall explain by means of the illustration. The original column number is $7 ; 7+32=39$ occurs; $7+16=23$ and $39+16=55$ occur; $7+8=15$ does not occur; $7-4=3,23-4=19$, $39-4=35$, and $55-4=51$ all occur, giving so far $\Phi \Phi 0 \Phi 11$. Next observe that $7-2=5,3-2=1,19-2=17,35-2=33$ all occur but that $23-2=21$ does not. Transferring to 23 as above, we need not try powers $32,16,4$, or 2 again. Trying 8 , we find that $23+8=31$ occurs but that $3+8=11$ does not occur. We could try to transfer once again, completing the crossing off of the 16 below column number 23 for the record. But we must transfer to a column with the following properties: (1) it is not covered by a previously determined essential prime implicant and (2) it does not combine with powers that have already been tried and circled. If the transfer were made to a column already covered, then this column obviously could not be the basis for another essential prime implicant; if the column to which we transferred combined with a circled power, then this power clearly would not again allow the completion of an essential prime implicant. For our illustration it is seen that no further column satisfying $\Phi \Phi 0 \Phi 11$ as well as our conditions 1 and 2 exists. Thus we must go on to a new row of work, i.e., another uncovered column. Note that since we already have determined that no column satisfying $\Phi \Phi 0 \Phi 11$ can be the basis of an essential prime implicant we should not go on to any of these columns either. For our illustration the next given column will be 44 , and the rest of the work is completed as above.

## EXERCISES

Find the simplest sum-of-products forms of the following designation numbers by the method of this section:
(a) 01110101.
(b) $0110 \quad 1001$.
(c) $0100 \quad 0100 \quad 1111 \quad 0100$.
(d) $0010 \quad 0100 \quad 0010 \quad 0010$.
(e) $00011 \quad 1010 \quad 1001 \quad 0010 \quad 1000 \quad 1101 \quad 0100 \quad 1011$.

Find the simplest product-of-sums forms of each of the following designation numbers. (Hint: Work with the zeros instead of the units.)
(f) 10011010.

Table 11-2. The Simplest Sum of Products Is $A \cdot \bar{C} \cdot \bar{D}+\bar{A} \cdot \bar{B} \cdot C \cdot \bar{D}+A \cdot \bar{B} \cdot C \cdot \bar{E}+\bar{B} \cdot C \cdot F+A \cdot B \cdot C \cdot E \cdot \bar{F}+$ $\bar{D} \cdot B \cdot A$, Where Only the Last Term Is Not an Essential Prime Implicant $\dagger$

$\dagger$ Note that $\Phi \Phi 0 \Phi 11$, corresponding to $\bar{D} \cdot B \cdot A$, in the fourth row covers the unchecked columns. By our method of procedure this is as good as any other product which covers them, and hence we include $\bar{D} \cdot B \cdot A$ in our simplest sum of products.
(g) $0100 \quad 1001 \quad 1101 \quad 0110$.
(h) $11110011 \quad 0001 \quad 1000$.
(i) $0110 \quad 0101 \quad 1001 \quad 1010$.
(j) $0001 \quad 0011 \quad 0111 \quad 1111$.

## 11-8. Simplification of Computer-circuit Design

The Simplification Procedure. The problem of the simplification of computer circuits can be stated as follows: Given a computer-circuit design, how can this circuit be redesigned using fewer and gates and or gates such that the output of the newly designed circuit is the same Boolean function (of the inputs) as the output of the original design?


Fig. 11-5. Circuit for $Z=\bar{C} \cdot(A+\bar{B})+\bar{A} \cdot(\bar{B}+C)+B \cdot(A+C)$.
We shall illustrate the procedure by means of an example. Consider the circuit of Fig. 11-5.

By the methods of Sec. 10-10

$$
Z=\bar{C} \cdot(A+\bar{B})+\bar{A} \cdot(\bar{B}+C)+B \cdot(A+C)
$$

With respect to the standard basis we then find $\# Z=11011011$. One simplest sum-of-products form is $\bar{A} \cdot \bar{B}+A \cdot \bar{C}+B \cdot C$, whence the simplified circuit can be made as in Fig. 11-6.


Fig. 11-6. Simplest sum-of-products form for $Z$ of Fig. 11-5.


Fig. 11-7. Simplest product-of-sums form for $Z$ of Fig. 11-5.

On the other hand the simplest product-of-sums form is

$$
(A+\bar{B}+C) \cdot(\bar{A}+B+\bar{C})
$$

and another simplified circuit is as in Fig. 11-7.
Summary. The method for simplifying a circuit is first to form the Boolean function for the output in terms of the inputs, second to form the designation number of this function, third to find the simplest sum-of-products or product-of-sums form for this designation number, and fourth to draw the circuit diagram corresponding to the simplest form.

## EXERCISES

Simplify the following circuits:

(a)

(c)

(b)

(d)

This last problem is of interest since it has two outputs, $X$ and $Y$. The procedure is to treat each output separately at first, obtaining the designation number and the simplest form for each output. Then those wires which are common to both outputs (written in simplest form) are utilized in this dual capacity. Hence $A$ goes to gates for both $X$ and $Y$.

## 11-9. The Design of Circuits That Compute Functions

The Condition-function Table and the Basis. The following discussion about the relationship between the condition-function table (of Sec. 10-8) and the basis (of Sec. 11-2), albeit seeming trivial perhaps in the light of the contents of this chapter, is nevertheless of fundamental importance to the whole concept of the design of computer circuits. A clear understanding of this relationship should be grasped by the student.

The relationship between the function table and the basis is analogous to the relationship of the truth tables and the basis. The columns of both function table and basis are composed of all possible combinations of the $n$ units and zeros, for a system of $n$ elementary elements. However, the order of the columns of a basis is fixed. Hence, if the function table is considered as a basis, with the input wires as elementary elements, the output-wire row giving the voltage signal (as 0 or 1) becomes simply a designation number-in fact the designation number of the Boolean function of the output in terms of the input wires.

For example, consider the problem of Sec. 10-8. The conditionfunction table of the solution was

| Wire $A \ldots \ldots \ldots$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Wire $B \ldots \ldots \ldots$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| Wire $C \ldots \ldots \ldots$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| Wire $D \ldots \ldots \ldots$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |

where $A, B, C$ are input wires and $D$ is the output. In order to reinterpret this function table as a basis and designation number, we let the designation numbers of the input wires be the same as the designation numbers of the elementary elements. Hence we have

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# C=0000 & 1111 \\
\# D=1111 & 0001
\end{array}
$$

In terms of $A, B, C$ we have $D=\bar{C}+A \cdot B$; that is, the designation number of $D$ with respect to the standard basis for three elementary elements is $\# D=11110001=\#(\bar{C}+A \cdot B)$. Henceforth we shall use the basis notation where its meaning as a condition-function table will be understood.

As another example, consider the following condition-function table:

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# C=0000 & 1111 \\
\# Z=1010 & 1011
\end{array}
$$

where $A, B$, and $C$ are the inputs and $Z$ is the output. To find $Z$ in terms of $A, B$, and $C$, consider $Z$ as a designation number, whence we have $Z=\bar{A}+B \cdot C$ as the simplest sum-of-products form.

Verbally Described Problems. In general the condition-function table is not given explicitly; rather some verbal description is given from which the function table can be constructed. Once the function table has been constructed, the Boolean function of the outputs is determined, usually in simplest form. Finally the circuit diagram is drawn. This circuit is then a circuit that will perform the duties described in the original verbal form of the problem.

For example, suppose that it is desired to design a circuit with three inputs and one output, such that, whenever an even number of inputs have a unit signal voltage, so will the output; otherwise the output is to have a zero signal voltage. The function table thus becomes

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# C=0000 & 1111 \\
\hline \# Z=1001 & 0110
\end{array}
$$

whence $Z=(A \cdot B+\bar{A} \cdot \bar{B}) \cdot \bar{C}+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot C$. Hence the circuit of Fig. 11-8 will do the job.


Fig. 11-8. Circuit for $Z=(A \cdot B+\bar{A} \cdot \bar{B}) \cdot \bar{C}+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot C . \quad Z$ is 1 volt when an even number of inputs are at 1 volt.

In many problems the voltage on the input wires is taken to represent a bit in a binary number. For example, if there were three input wires, the voltage on wire $A$ might represent the bit in the least significant position of a 3 -bit binary number, $B$ the next most significant bit, and $C$ the most significant bit. For instance, to represent 5, or binary 101, wire $A$ would have a 1 -volt signal, wire $B$ a 0 -volt signal, and wire $C$ a 1 -volt signal. Similarly the output wires would represent the bits of an output binary number.

Suppose that we are to design a circuit that forms $3 N$, where $N$ represents a 3 -bit number. Since $N$ can go only up to 7 , then the output can go only up to 21 , and five output wires are necessary. Let $N_{1}, N_{2}$, and $N_{3}$ represent the input wires (instead of $A, B, C$ as described above), and let $M_{1}, M_{2}, M_{3}, M_{4}$, and $M_{5}$ represent


Fig. 11-9. Input-output wires of circuit to form $M=3 N$. the output wires (see Fig. 11-9).

Now consider

|  | 0123 | 4567 |
| :--- | :--- | :--- |
| $\# N_{1}$ | $=0101$ | 0101 |
| $\# N_{2}$ | $=0011$ | 0011 |
| $\# N_{3}$ | $=0000$ | 1111 |

The columns represent the possible states of the wires $N_{1}, N_{2}$, and $N_{3}$. In fact, if the input number were 5 , then the state of the wires would be as shown in column 5, that is, the column would form the binary number 5 with the top row the least significant bit, the bottom row the most significant bit. Now, if $N=0$, then $3 N=0$; if $N=1,3 N=3$, etc. Hence we have

$$
\begin{array}{rlr}
N & =0,1,2,3,4,5,6,7 \\
3 N & =0,3,6,9,12,15,18,21
\end{array}
$$

or

$$
\begin{array}{ll}
\# N_{1}=0101 & 0101 \\
\# N_{2}=0011 & 0011 \\
\# N_{3}=0000 & 1111 \\
\# M_{1}=0101 & 0101 \\
\# M_{2}=0110 & 0110 \\
\# M_{3}=0010 & 1101 \\
\# M_{4}=0001 & 1100 \\
\# M_{5}=0000 & 0011
\end{array}
$$

This tabulation gives for any state of the $N_{1}, N_{2}$, and $N_{3}$ wires the desired state of the $M_{1}, M_{2}, M_{3}, M_{4}$, and $M_{5}$ wires. For instance, if $N=5$, then $3 N=15$; that is, if

## Volts

Wire $N_{1}=1$
Wire $N_{2}=0$
Wire $N_{3}=1$ then

## Volts

$$
\begin{aligned}
& \text { Wire } M_{1}=1 \\
& \text { Wire } M_{2}=1 \\
& \text { Wire } M_{3}=1 \\
& \text { Wire } M_{4}=1 \\
& \text { Wire } M_{5}=0
\end{aligned}
$$

where of course 101 is 5,1111 is fifteen, in binary. Now we can read off the answers:

$$
\begin{array}{ll}
M_{1}=N_{1} & M_{4}=N_{1} \cdot N_{2} \cdot \bar{N}_{3}+\bar{N}_{2} \cdot N_{3} \\
M_{2}=N_{1} \cdot \bar{N}_{2}+\bar{N}_{1} \cdot N_{2} & M_{5}=N_{2} \cdot N_{3} \\
M_{3}=\bar{N}_{1} \cdot N_{2} \cdot \bar{N}_{3}+\left(N_{1}+\bar{N}_{2}\right) \cdot N_{3} &
\end{array}
$$

The circuit then becomes as in Fig. 11-10.


Fig. 11-10. Circuitry for the output wires of $M$.

Consider now a more complicated problem. Suppose that we are to design a circuit to have four inputs, $N_{1}, N_{2}, M_{1}$, and $M_{2}$. Let $N_{1}$ and $N_{2}$ represent a 2-bit binary number $N$ with $N_{1}$ the least significant bit, and let $M_{1}$ and $M_{2}$ represent a binary number $M$ with $M_{1}$ the least significant bit. The circuit is to produce the product of the two input numbers. Since each input number has 2 bits, the largest product is $3 \times 3=9$. Hence 4 bits for the resulting product outputs, i.e., four output wires, are sufficient. Hence a listing of the states becomes

$$
\begin{array}{rrrrr}
N & 0,1,2,3 & 0,1,2,3 & 0,1,2,3 & 0,1,2,3 \\
M & 0,0,0,0 & 1,1,1,1 & 2,2,2,2 & 3,3,3,3 \\
\hline N \times M & 0,0,0,0 & 0,1,2,3 & 0,2,4,6 & 0,3,6,9
\end{array}
$$

whence the function table becomes

$$
\begin{aligned}
& N\left\{\begin{array}{llll}
\# N_{1}=0101 & 0101 & 0101 & 0101 \\
\# N_{2}=0011 & 0011 & 0011 & 0011
\end{array}\right. \\
& M\left\{\begin{array}{llll}
\# M_{1}=0000 & 1111 & 0000 & 1111 \\
\# M_{2}=0000 & 0000 & 1111 & 1111 \\
\hline \# R_{1} & 0000 & 0101 & 0000
\end{array}\right. \\
& N \times M\left\{\begin{array}{llll}
\# R_{1}=0000 & 0101 & 0000 & 0101 \\
\# R_{2}=0000 & 0011 & 0101 & 0110 \\
\# R_{3}=0000 & 0000 & 0011 & 0010 \\
\# R_{4}=0000 & 0000 & 0000 & 0001
\end{array}\right.
\end{aligned}
$$

Hence we have

$$
\begin{aligned}
& R_{1}=N_{1} \cdot M_{1} \\
& R_{2}=N_{2} \cdot M_{1} \cdot \bar{M}_{2}+N_{1} \cdot \bar{M}_{1} \cdot M_{2}+\bar{N}_{1} \cdot N_{2} \cdot M_{1}+N_{1} \cdot \bar{N}_{2} \cdot M_{2} \\
& R_{3}=N_{2} \cdot \bar{M}_{1} \cdot M_{2}+\bar{N}_{1} \cdot N_{2} \cdot M_{2} \\
& R_{4}=N_{1} \cdot N_{2} \cdot M_{1} \cdot M_{2}
\end{aligned}
$$

The multiplying circuit can then be drawn from this result.
Consider an example of a decoding circuit. Suppose that the input code is 3 bits (i.e., three input wires) and that the output code is 3 bits. The relation between the input code and output code is
$\begin{array}{lll}\text { Input code } & 0123 & 4567\end{array}$
Output code $0647 \quad 0377$
i.e., if 1 goes in, then 6 must come out; if 5 goes in, 3 must come out, etc. The function table for this decoding scheme is

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# C=0000 & 1111 \\
\# X=0001 & 0111 \\
\# Y=0101 & 0111 \\
\# Z=0111 & 0011
\end{array}
$$

whence

$$
\begin{aligned}
& X=A \cdot B+A \cdot C+B \cdot C \\
& Y=A \cdot C+B \cdot C+A \cdot \bar{C} \\
& Z=B \cdot C+A \cdot \bar{C}+\bar{C} \cdot B
\end{aligned}
$$

and the circuit diagram appears in Fig. 11-11.


Fig. 11-11. A decoding circuit. Input code of 01234567 corresponds to output code of 06470377 .

## EXERCISES

Design circuits that perform the following functions:
(a) A parallel digital squaring circuit where the input is a 4-bit binary number $N$ and the output is $N^{2}$.
(b) A circuit that forms the positive values of $2 N-1$ for $N$ a 4-bit binary number (and forms zero for $N=0$ ).
(c) A circuit the input of which is the 4-bit binary number $N$, the output of which is $N+3$ in binary.
(d) A circuit that will produce a unit output only when an odd number of its four input wires contain unit signal voltages.

## 11-10. Synchronous Recursive-function Circuits

Input as a Function of the Output. Until this section the output of a circuit depended on the inputs, but the inputs of the circuit have not depended in any way on the output of the circuit. In this section circuits will be considered in which the inputs depend on the outputs. For example, consider a digital-computer-circuit black box with three inputs and three outputs such that the outputs are connected to the inputs (see Fig. 11-12). Hence the future output depends on the past output. Such an output function is called a recursive function. Two kinds of inputs can be distinguished, external inputs, which are not related to the output, and internal inputs, which are related to theoutput. In Fig. 11-12 $P$ is an external input, and $A, B$, and $C$ are internal inputs.

Consider the following example of a recursive-function circuit: Let $A$ and $B$ represent a 2-bit binary-number input in the manner of the last section, and let $A^{\prime}$ and $B^{\prime}$ represent a 2 -bit output number. Let $P$ represent another input wire which is attached to a push button; i.e., when the push button is pushed, a unit signal voltage will appear on $P$. The circuit is to work as follows: Suppose that initially the output "number" is 0 ; when the button is pushed, the output should change to 1 ;


Fig. 11-12. A recursive circuit with four inputs and three outputs.


Fig. 11-13. A two-digit counter.
when the button is pushed a second time, the output is to change to 2 ; when pushed a third time, the output should change to 3 ; and when pushed again, the output should return to 0 again. This cycle can be repeated. Such a circuit is called a counter since it counts how many times the button is pushed (but only up to three!).

The output number is to become the future input number, i.e., the circuit is to be wired as in Fig. 11-13. Hence the output immediately becomes the internal input. The function table becomes

$$
\begin{array}{rr}
0123 & 4567 \\
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# P=0000 & 1111 \\
\hline \# A^{\prime}=0101 & 1010 \\
\# B^{\prime}=0011 & 0110
\end{array}
$$

To see how this function table was derived, consider, for example, column 2. Here the input number is ${ }_{1}^{0}$, or 2 , and the push button is not being pushed. Let us assume that, if the push button is not pushed, then the output number is the same as the input number. Hence the output number becomes also ${ }_{1}^{0}$, or 2. A similar discussion also holds for columns 0, 1, and 3.

Now let us consider column 6, for example. Here the input number is 0 $1_{1}$, or 2 , and this time the push button is being pushed. Hence the output number must be 3 , or $\frac{1}{1}$ as indicated in column 6 . Similarly in column 4, the input number of 0 becomes the output number of 1 , in column 5 the input number of 1 becomes the output number of 2 , and in column 7 the input number of 3 becomes the output number of 0 .

We can now observe that

$$
\begin{array}{ll}
\# A^{\prime}=0101 & 1010=\#(A \cdot \bar{P}+\bar{A} \cdot P) \\
\# B^{\prime}=0011 & 0110=\#[B \cdot \bar{P}+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot P]
\end{array}
$$

Timing. But wait! There is something wrong here! Suppose that the output number was, say, 2 . Then immediately the input number will become 2 since $A$ is connected directly to $A^{\prime}$ and $B$ is connected directly to $B^{\prime}$. If $P$ is not being pushed, then everything stays in this state; i.e., the output that corresponds to an input of 2 , with no button being pushed, is just 2. However, suppose that now the button is pushed. The output immediately changes to 3 ; this 3 immediately becomes the input. Suppose that the button is still being pushed; then the output immediately changes to 0 , etc., before the button can be released. But we only wanted the output to change from 2 to 3 during a single push of the button.

The most obvious way out of this dilemma is to delay the output from becoming the new input for a long enough time so that the push button can be released. In such a case this is what will happen: Suppose initially, for example, that both output and input were 2 and the button is pushed. Then the output immediately becomes 3 , but not the input; it stays at 2 because we now have a delay in propagation of the signals along the wires $A^{\prime} A$ and $B^{\prime} B$. Then the button is released, after which the 3 propagates to the input. But an input of 3 with the button not pushed produces an output of 3 as


Fig. 11-14. Circuit of Fig. 11-13 with unit delays. desired. Hence by the introduction of the delay the circuit has been made to do what we desired. The wiring of the circuit will now look like Fig. 11-14, where the delay is represented by a rectangle with a number in it that represents the time of the delay in microseconds.

Hence the only other necessary condition is that the duration of the push-button signal is shorter than the delay. Of course the push-button signal is not really manually operated: it is an external electronic signal


Fig. 11-15. The detailed circuitry of the two-digit counter.
generated in some other circuit. Using our Boolean-function derivation above, we can now draw the complete circuit diagram as in Fig. 11-15. Circuitry that depends on the synchronization of the pulses in this manner is called synchronous circuitry.

The Timing Diagram. The time sequencing of signals in the wires $A$, $B, P, A^{\prime}$, and $B^{\prime}$ can be visualized by the voltage-time diagram. Here the voltage as a function of time is plotted for each wire, as shown in


Fig. 11-16. Voltage levels vs. time for the two-digit counter.

Fig. 11-16. Figure 11-17 illustrates the voltage levels in wires $A$ and $B$ when the 2 -bit binary number represented by $A$ and $B$ (with $A$ the least significant bit) is $0,1,2$, and 3 , respectively. Let us return now to Fig. 11-16. At time $t_{0}$, suppose that both $A, B$ and $A^{\prime}, B^{\prime}$ represent the "number" 2 and that the button was not being pushed. At $t_{1}$ (say $1 \mu \mathrm{sec}$ later) the button is pushed; $A^{\prime}, B^{\prime}$ then form the "number" 3 almost immediately, but $A, B$ stay the same. At $t_{2}$ the 3 has propagated through to $A, B$. Note that $A^{\prime}, B^{\prime}$ stay the same at 3 since $A, B$ form 3 and the button has been released. When the button is again pushed at $t_{3}, A^{\prime}, B^{\prime}$ form 0 but $A, B$ stay at 3 since the 0 has not propagated through to them yet. By $t_{4}$ this propagation has occurred, and $A, B$ form 0 , etc.


Frg. 11-17. Voltage levels for $A$ and $B$.

Summary. Given the voltage levels of $A, B$, and $P$ at $t_{i}$, the voltage levels for $A^{\prime}$ and $B^{\prime}$ at $t_{i}$ are determined by means of the function table; the voltage levels of $A$ and $B$ at $t_{i+1}$ are the same as those of $A^{\prime}$ and $B^{\prime}$ were at $t_{i}$ (see crosshatching and arrows in Fig. 11-16).

We have shown how to design a recursive-function digital-computer circuit, i.e., a circuit whose present input depends on its past output. The computational procedure is almost the same as for the nonrecursive case discussed in the previous section. However, delay lines have to be included in the circuit to delay the output from changing the internal input too fast, and any external input signal must have a duration a little less than the delay time.

## EXERCISES

(a) Consider a circuit with one internal input $A$, one output $A^{\prime}$, and one external input $P$, again a push button. If the input


Fig. 11-18. Solution to Exercise a. has a 1 -volt signal and the button is pushed (i.e., wire $P$ has a 1 -volt signal), then the output changes to zero. If the output is zero volts and the button is pushed, the output signal changes to 1 volt. Design this circuit. Solution

$$
\begin{aligned}
& \# A=0101 \\
& \# P=0011 \\
& \# A^{\prime}=0110=A \cdot \bar{P}+\bar{A} \cdot P
\end{aligned}
$$

The circuit diagram is as shown in Fig. 11-18.
(b) Design a circuit that counts as follows: $0,1,3,2,0,1,3,2, \ldots$ (i.e., the output wires, say $A^{\prime}, B^{\prime}$, form a 2 -bit binary number; the count is stepped by a push button satisfying the above requirements).

Solution. The function table is

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# P=0000 & 1111 \\
\# A^{\prime}=0101 & 1100=A \cdot \vec{P}+\bar{B} \cdot P \\
\# B^{\prime}=0011 & 0101=B \cdot \bar{P}+A \cdot P
\end{array}
$$

The circuit diagram is as shown in Fig. 11-19.
(c) Draw the voltage-time diagram for Exercise $b$.


Fig. 11-19. Solution to Exercise $b$.

## 11-11. The States of Circuits

Boolean Matrices. Boolean matrices are involved in the discussion of the states of circuits. A Boolean matrix is a rectangular array of zeros and units, for example,

$$
\left(\begin{array}{l}
01010 \\
10010 \\
01011
\end{array}\right)
$$

The columns are labeled by successively increasing integers starting with 0, from left to right. The rows are similarly labeled from top to bottom:

$$
\begin{gathered}
j 01234 \\
i \\
0 \\
1 \\
2
\end{gathered}\left(\begin{array}{c}
01010 \\
20010 \\
01011
\end{array}\right)
$$

The zeros and units are called the elements of the matrix. An element of the matrix can be represented by $a_{i j}$, where $i$ is the row in which the element appears and $j$ is the column in which it appears. (The mnemonic Roman Catholic can be used to recall that the first subscript refers to the row, the second subscript to the column.) Thus in our example $a_{13}=1$, and $a_{20}=0$. The whole matrix is represented symbolically by placing parentheses around the symbol for an element, thus: $\left(a_{i j}\right)$. In summary a Boolean matrix is the same as the usual concept of a matrix except that the elements can only be zero or unit and the numbering of the rows and columns starts with 0 .

Boolean matrix multiplication, indicated by the symbol $\otimes$, follows the same rules as ordinary matrix multiplication except that logical multiplication and logical addition of the elements are employed. That is to say, if ( $c_{i j}$ ) is the matrix resulting from the Boolean multiplication of the matrix $\left(a_{i k}\right)$ by the matrix $\left(b_{k j}\right)$, that is, $\left(c_{i j}\right)=\left(a_{i k}\right) \otimes\left(b_{k j}\right)$, then
the elements of $\left(c_{i j}\right)$ are determined by

$$
c_{i j}=\sum_{k} a_{i k} \cdot b_{k j}
$$

where • represents logical multiplication and + now represents logical addition. For example, if
then

$$
\left.\left(\begin{array}{cccc}
18 / T X / X S / X O \\
1 & 0 & 0 & 1 \\
0 & 1 & 0 & 1
\end{array}\right) \otimes \begin{array}{ll}
0 & 1 \\
0 & 0 \\
1 & 0 \\
0 & 0 \\
1 & 1
\end{array}\right)=\begin{aligned}
& 0 \\
& 1
\end{aligned}\left(\begin{array}{lll}
0 & 1 & 2 \\
0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1
\end{array}\right)=\left(c_{i j}\right)
$$

To form $c_{60}$, note that

$$
c_{00}=\sum_{k} a_{0 k} \cdot b_{k 0}=a_{00} \cdot b_{00}+a_{01} \cdot b_{10}+a_{02} \cdot b_{20}+a_{03} \cdot b_{30}+a_{04} \cdot b_{40}
$$

## EXERCISES

Show that
(a)

$$
\left(\begin{array}{llll}
1 & 1 & 0 & 1 \\
0 & 0 & 1 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{lll}
1 & 0 & 0 \\
0 & 0 & 0 \\
0 & 0 & 1 \\
0 & 1 & 0
\end{array}\right)=\left(\begin{array}{lll}
1 & 1 & 0 \\
0 & 0 & 1 \\
0 & 0 & 0
\end{array}\right)
$$

$$
\left(\begin{array}{llll}
1 & 1 & 0 & 1 \\
0 & 0 & 1 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{l}
1 \\
0 \\
1 \\
0
\end{array}\right)=\left(\begin{array}{l}
1 \\
1 \\
0
\end{array}\right)
$$

(c)

$$
\left(\begin{array}{lll}
0 & 1 & 1
\end{array}\right) \otimes\left(\begin{array}{llll}
1 & 1 & 0 & 1 \\
0 & 0 & 1 & 0 \\
0 & 1 & 0 & 0
\end{array}\right)=\left(\begin{array}{llll}
0 & 1 & 1 & 0
\end{array}\right)
$$

$$
\left(\begin{array}{lll}
1 & 0 & 0 \\
0 & 1 & 0 \\
0 & 0 & 1
\end{array}\right) \otimes\left(\begin{array}{lll}
1 & 1 & 0 \\
0 & 0 & 1 \\
0 & 1 & 0
\end{array}\right)=\left(\begin{array}{lll}
1 & 1 & 0 \\
0 & 0 & 1 \\
0 & 1 & 0
\end{array}\right)
$$

States of a Circuit. Now we are ready to consider the definition of "states of a circuit." First let us restrict ourselves to recursive circuits where the outputs are connected to the inputs through delay lines; in addition suppose that the circuits have no external input and have the same number of output wires as input wires, as in Fig. 11-20. As we saw in the last section, at a given time the signals in the wires $A^{\prime}, B^{\prime}, C^{\prime}$
are not necessarily the same as those in $A, B, C$. Hence we associate two "states" with a circuit: the state of the input wires and the state of the output wires. The state of the input wires at any given time is defined as the set of signals in the input wires at that time; the state of the output wires at any time is the set of signals in the output wires at that time. Recalling that the columns of the function-table basis give all


Fic. 11-20. Recursive circuit with no external inputs.


Fig. 11-21. Input-state diagram of circuitry:

$$
\begin{gathered}
A^{\prime}=\bar{A} \quad B^{\prime}=\bar{A} \cdot B+A \cdot \bar{B} \\
C^{\prime}=A \cdot B \cdot \bar{C}+(\bar{A}+\bar{B}) \cdot C
\end{gathered}
$$

possible states of the input wires, we can use the column number of the standard basis for a shorthand way of representing a state.

For example, suppose that the function table for a circuit were

| 0123 | 4567 |
| :---: | :---: |
| $\# A=0101$ | 0101 |
| $\# B=0011$ | 0011 |
| $\# C=0000$ | 1111 |
| 1234 | 5670 |
| $\# A^{\prime}=1010$ | 1010 |
| $\# B^{\prime}=0110$ | 0110 |
| $\# C^{\prime}=0001$ | 1110 |

Then we let 0 represent the state $\underset{0}{0}$, let 1 represent the state $\underset{0}{1}, 2$ the state $\frac{0}{0}, 3$ the state $\frac{1}{0}$, and so forth. Hence according to the function table the input state 0 corresponds to the output state 1 , the input state 1 corresponds to the output state 2 , input 2 corresponds to output 3, input 3 to output 4, etc.

Suppose that initially we set this circuit so that the input state is 0 (that is, $\underset{0}{\mathbf{0}} \mathbf{0}$ ) and then let it go. We can represent the successive input states as in Fig. 11-21. This is called an input-state diagram for a circuit.

There is another way to trace the successive input states of a circuit, using Boolean matrices. Here we suppose that the rows of the matrix are labeled by the input states, the columns by the output states. Then an element of the matrix is a unit, provided that its row and column are labeled by corresponding input-output states.

For example, consider the following function table:

$$
\begin{array}{r}
0123 \\
\# A=0101 \\
\# B=0011 \\
\hline \# A^{\prime}=1230 \\
\# B^{\prime}=0110
\end{array}
$$

Hence we have

$$
\text { (Input states) } \begin{gathered}
\begin{array}{c}
0 \\
0
\end{array} \\
0 \\
1 \\
2 \\
2
\end{gathered}\left(\begin{array}{lll}
0 & 1 & 0 \\
0 & 0 & 0 \\
0 & 0 & 1 \\
0 \\
0 & 0 & 0 \\
1 & 0 & 0 \\
1
\end{array}\right)
$$

Such a matrix is called the state matrix for the circuit. In the example $a_{01}=1$ because input state 0 corresponds to output state $1, a_{12}=1$ because input state 1 corresponds to output state 2 , and so forth.

Assuming, to be concrete, that the delay is $1 \mu \mathrm{sec}$, if this circuit is initially set at input state 0 , it will have input state 1 after $1 \mu \mathrm{sec}$. This fact can be read directly from the input-state matrix. Now, after $2 \mu \mathrm{sec}$, the input state will be 2 . If it was initially at input state 1 , after $2 \mu \mathrm{sec}$ it will be at input state 3 , and so forth. This information can be obtained by multiplying the input-state matrix by itself and reading the resulting matrix.

$$
\left.\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
0 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 \\
1 & 0 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
0 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 \\
1 & 0 & 0 & 0
\end{array}\right)=\begin{array}{cccc}
0 & 1 & 2 & 3 \\
0 & (\text { (output states } 2 \mu \text { sec later) } \\
2 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 \\
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0
\end{array}\right)
$$

Hence, given an initial input state corresponding to one of the rows, the input state after $2 \mu \mathrm{sec}$ can be taken from the matrix by observing the column number of the unit of that row. To find the states $3 \mu \mathrm{sec}$ later, simply multiply this matrix again by the original one on the right:

$$
\left.\left(\begin{array}{llll}
0 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 \\
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
0 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 \\
1 & 0 & 0 & 0
\end{array}\right)=\begin{array}{c}
0 \\
1
\end{array}\right)=\begin{array}{ccc}
0 \\
1 \\
2 & 0 & 0 \\
\hline
\end{array}\left(\begin{array}{c}
1 \\
1
\end{array} 0\right.
$$

The result is read the same way, etc.
Hence, to find the input-state matrix that gives the input state of a
circuit after $n$ delay-time periods, multiply successively $n$ times on the right by the initial input matrix.

For example, let us find the input-state matrix after two, three, four, and five delay-time periods for the circuit with the following function table:

$$
\begin{aligned}
& \# A=0101 \\
& \# B=0011 \\
& \# A^{\prime}=1011 \\
& \# B^{\prime}=0010
\end{aligned}
$$

We then have

$$
\begin{aligned}
& \left.\begin{array}{llll}
0 & 1 & 2 & 3 \\
0 \\
1 \\
2 & \left(\begin{array}{lll}
0 & 1 & 0 \\
1 & 0 & 0 \\
0 & 0 \\
0 & 0 & 0
\end{array}\right. & 1 \\
0 & 1 & 0 & 0
\end{array}\right) \quad \text { as original matrix } \\
& \left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 \\
0 & 1 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 \\
0 & 1 & 0 & 0
\end{array}\right)=\left(\begin{array}{llll}
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0 \\
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0
\end{array}\right) \quad \text { after } 1 \text { delay time } \\
& \left(\begin{array}{llll}
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0 \\
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 \\
0 & 1 & 0 & 0
\end{array}\right)=\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \quad \text { after } 2 \text { delay times } \\
& \left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 \\
0 & 1 & 0 & 0
\end{array}\right)=\left(\begin{array}{llll}
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0 \\
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0
\end{array}\right) \quad \text { after } 3 \text { delay times } \\
& \left(\begin{array}{llll}
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0 \\
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 \\
0 & 1 & 0 & 0
\end{array}\right)=\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \quad \text { after } 4 \text { delay times } \\
& \left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0
\end{array}\right) \otimes\left(\begin{array}{llll}
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 \\
0 & 1 & 0 & 0
\end{array}\right)=\left(\begin{array}{llll}
1 & 0 & 0 & 0 \\
0 & 1 & 0 & 0 \\
0 & 1 & 0 & 0 \\
1 & 0 & 0 & 0
\end{array}\right) \quad \text { after } 5 \text { delay times }
\end{aligned}
$$

The student should draw the input-state diagram for this function table and compare the results with the matrices.

## EXERCISES

Draw the input-state diagrams, and find the input-state matrix after two, three, four, five, six, seven, and eight delay-time periods of the circuits with the following function tables:
(a) $\# A=0101$
(b) $\# A=0101$
$\# B=0011$
$\# A^{\prime}=1010$
$\# B=0011$
$\# A^{\prime}=0110$
$\# B^{\prime}=0110$
$\# B^{\prime}=1000$

Sec. 11-12] Designation numbers and function circuits
(c) $\# A=01010101$
$\# B=00110011$
$\begin{array}{rlr}\# C & =0000 & 1111 \\ \# A^{\prime} & =1010 & 0111\end{array}$
$\# B^{\prime}=1100 \quad 0011$
$\# C^{\prime}=0011 \quad 0011$
(d) $\# A=0101 \quad 0101$
$\# B=00110011$
$\begin{array}{rll}\# C & =0000 & 1111 \\ \# A^{\prime} & =0011 & 1111\end{array}$
$\# B^{\prime}=00110111$
$\# C^{\prime}=1001 \quad 1101$

## 11-12. Additional Topics

a. Representations of Boolean Algebra. As we have pointed out in the previous chapter, the functions of Boolean algebra can be represented by areas of intersecting sets. Such diagrams are called Venn diagrams (attributed to Venn by Schroeder). Figure 11-22 is such a diagram for four variables.


Fig. 11-22. Four-variable Venn diagram.
A geometric representation of a Boolean algebra may be obtained by considering the columns of the basis as coordinates of points that form a hypercube. For two variables we obtain a square (see Fig. 11-23a). The vertices are the elementary products and the edges are the functions formed by the sum of the adjacent vertices. For three variables we obtain a cube, where now the faces are the sum of the adjacent vertices


Fig. 11-23. Two- and three-dimensional hypercubes. The numbers represent basis columns.
(or edges), and so forth (see Fig. 11-23b). In Fig. 11-23b we have labeled the edges; can you label the faces?

Another representation of a Boolean lattice diagram is illustrated in Fig. 11-24, for a two-elementary-element system. A point $Y$ on the lattice is said to include another point $X$ on the lattice if a continuous upward path can be found from $X$ to $Y$ along the lines drawn on the lattice diagram. For example, on our lattice, $\bar{A}+\bar{B}$ includes $A \cdot \bar{B} ; A+B$ includes $A$, and so forth. One point of the lattice is said to be below (above) another point if it is on a row below (above) the row of the other point. For example, on our lattice, $\bar{A} \cdot \bar{B}$ is below $\bar{B}, \bar{A}+\bar{B}$ is above $A \cdot \bar{B}+\bar{A} \cdot B$, etc.


Fig. 11-24. The lattice diagram (two variables).
The lattice is so constructed that the logical sum of two elements is the lowest point which includes both elements. For example, $\bar{A}+\bar{B}$ is the logical sum of $\bar{A}$ and $\bar{B}$, $A+B$ is the logical sum of $A \cdot \bar{B}$ and $B$, etc. The logical product of two elements is the highest point which is included by both elements. For example, $A \cdot B$ is the logical product of $A$ and $B ; A \cdot \bar{B}$ is the logical product of $A+B$ and $\bar{B}$. The numbers now represent designation numbers (not basis columns as shown in Fig. 11-23).
b. Chart Methods for Simplification of Boolean Functions. Besides the methods given in this chapter for finding the simplest sum-of-products form, there are some semisystematic, so-called chart methods of procedure. Consider the following fourvariable basis and designation numbers:

| $A$ | 0101 | 0101 | 0101 | 0101 |
| :--- | :--- | :--- | :--- | :--- |
| $B$ | 0011 | 0011 | 0011 | 0011 |
| $C$ | 0000 | 1111 | 0000 | 1111 |
| $D$ | 0000 | 0000 | 1111 | 1111 |
|  | 1100 | 1100 | 0011 | 1111 |

SEC. 11-12] DESIGNATION NUMBERS AND FUNCTION CIRCUITS
The work is arranged in a chart as follows:

|  | $A$ | 0 | 1 | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $C$ | $B$ | 0 | 0 | 1 | 1 |
| $C$ | $D$ |  |  |  |  |
| 0 | 0 | 1 | 1 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 0 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 |

The rows in the chart proper correspond to the successive groups of four positions of the designation number. In this form it is easier to see that the units in the bottom row correspond to all possible combinations of $A$ and $B$ and hence will be covered by $C \cdot D$. The four units in the upper left quarter correspond to all combinations of conditions on $A$ and $C$ and hence will be covered by $\bar{B} \cdot \bar{D}$; similarly the four units in the lower right quarter can be covered by $B \cdot D$ :


Thus the simplest sum of products becomes $C \cdot D+\bar{B} \cdot \bar{D}+B \cdot C$. This method is due to Veitch (see reference below). A variation due to Karnaugh (see reference below) rearranges the columns and rows so that the units of $A$ and $C$ become adjacent. For example, consider the designation number 0101011101011111 and the following chart:

|  |  | $A$ | 0 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $B$ | 0 | 0 | 1 | 1 |
| $C$ | $D$ | 0 |  |  |  |
| 0 | 0 | 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 1 | 0 | 1 | 1 | 0 |

From this it is seen that the simplest sum of products is $A+B \cdot C+C \cdot D$. Try this with a chart not having the rearranged rows and columns, and the advantages of the rearrangement will become clear. (Note that the rearranged chart is really just a Venn diagram.) For further information on these methods see the references below.
c. Decimal Method for Determining Included and Nonincluded Elementary Elements. First note that the elimination pairs for an $A_{i}$ are simply those pairs of (positions corresponding to) basis columns that are identical except in the $i$ th row; for example,

|  | 9 | $\mathbf{1 3}$ |
| :--- | :--- | :--- |
| $A_{1}$ | 1 | 1 |
| $A_{2}$ | 0 | 0 |
| $A_{8}$ | 0 | 1 |
| $A_{4}$ | 1 | 1 |

are an elimination pair for $A_{3}$.
Next observe that, if $p$ and $q$ are decimal representations of an elimination pair of positions for $A_{i}$, then we have $p+2^{i-1}=q$; for example, $9+2^{3-1}=9+4=13$ as desired. Finally note that it is an easy matter to determine whether a basis column has a unit or a zero in the $i$ th row directly from the decimal position number, for all we do is to divide it by $2^{i-1}$. If the integral part of the result is even, the column has a zero in the $i$ th row; if the integral part is odd, the column has a unit in the $i$ th row (why?). For example, for $i=3$ and the column in position 9 , we have $9 / 2^{3-1}=9 / 4=$ 214 ; since 2 is even, there is a 0 in the third row of this column. For $i=3$ and the column in position 13 we have $13 / 2^{3-1}=13 / 4=3 \frac{1}{4}$; since 3 is odd, there is a 1 in the third row of this column.

Now we are ready to present the decimal procedure in three steps. Consider, for example,

$$
\begin{array}{cccccccccccccccc} 
& 1 & & & 4 & 5 & 6 & 7 & & 9 & & & 12 & 13 & 14 & 15 \\
0 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & 0 & 1 & 0 & 0 & 1 & 1 & 1 & 1
\end{array}
$$

and $A_{3}$. The first step is to separate those positions having units in the designation number into two groups, corresponding to whether the position has a unit or a zero in the $i$ th row:

$$
\begin{array}{cc}
\text { Positions having zero } & \text { Positions having unit } \\
\text { in } 3 d \text { row } & \text { in } 3 d \text { row } \\
1,9 & 4,5,6,7,12,13,14,15
\end{array}
$$

Second, add $2^{i-1}$ to the positions having zero in the $i$ th row: $1+4=5,9+4=13$. Third, compare the adjusted numbers with the numbers of the positions having units in the $i$ th row: if the two groups of numbers are identical, neither $A_{i}$ nor $\bar{A}_{i}$ is included; if a number appears in the unit group that does not appear in the adjusted zero group, then $A_{i}$ is included; if a number appears in the adjusted zero group that does not appear in the unit group, then $\bar{A}_{i}$ is included. For our example we have the two groups:

Adjusted zero group

$$
5,13
$$

$$
4,5,6,7,12,13,14,15
$$

Since numbers appear in the unit group that do not appear in the adjusted zero group (but not the reverse), we have that $A_{3}$ (but not $\bar{A}_{3}$ ) is included. For $A_{1}$ these groups are ( $5,7,13,15$ ) and ( $1,5,7,9,13,15$ ), whence $A_{1}$ is included; for $A_{2}$ these groups are
$(3,6,7,11,14,15)$ and ( $6,7,14,15$ ), whence $\bar{A}_{2}$ is included; for $A_{4}$ these groups are ( $9,12,13,14,15$ ) and ( $9,12,13,14,15$ ), whence $A_{4}$ is not included.
d. Decimal Method for Simplification. $\dagger$ The work of finding the simplest sum-ofproducts form by the method of Sec. 11-6 can be shortened by considering the decimal numbers denoting basis columns instead of the columns themselves. Consider again the example of that section, the designation number

$\#$| 0 | 1 |  | 3 | 4 |  | 6 | 7 |  |  | 9 | 10 | 11 |  | 13 | 14 | 15 |
| ---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |  |

Instead of writing the columns in groups of ascending numbers of included units,

| 0 | 1 | 0 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 |

we merely write the groups of decimal numbers of those columns: $0 ; 1,4 ; 3,6,9,10$; $7,11,13,14 ; 15$. Note that if a column is to combine with another in the next adjacent group then the number in the latter group must be greater than the number in the former by a power of 2 . Hence we need list (in groups) for the combined result only the least number, and the difference, which corresponds to the power position in which the columns differ: $0-1$ for columns 0 and $1,0-4$ for columns 0 and 4, 1-2 for 1 and $3,1-8$ for 1 and $9,4-2$ for 4 and 6 (but not $4-1$ for 4 and 3 ), $3-4$ for 3 and 7, etc. Just as combined columns recombine only if they have $\Phi$ in the same positions, so these pairs combine only if they have common differences: thus 1-2 and 9-2 combine, and we write 1-2,8 (also $1-8$ and $3-8$ combine to form 1-2,8). The work for this example would be tabulated as in Table 11-3. No combinations are possible in the final row of the table, because no pairs have the same two differences.
The prime implicants are represented by the unchecked numbers of Table 11-3: namely, $0-1 ; 0-4 ; 4-2 ; 1-2,8 ; 3-4,8 ; 6-1,8 ; 9-2,4 ; 10-1,4$. The prime-implicant chart

Table 11-3. Work for the Decimal Method

(see Table 11-1) is formed by adding to each least number all combinations of its associated differences. To find the expression for one of these combination numbers, we omit the variables whose power positions correspond to the differences and bar those variables whose powers do not add to make the first number, to the left of the dash. Thus $9-2,4$ corresponds to $A \cdot D$ (since $B$ and $C$ are deleted and $1+8=9$ ) and 4-2 corresponds to $\bar{A} \cdot C \cdot \bar{D}$ (since $B$ is deleted and $0+4+0=4$ ).
$\dagger$ This method was developed by James Bruce Wilson.

## e. References on Simplification of Boolean Functions

Abhyankar, S.: Minimal "Sum of Products of Sums" Expressions of Boolean Functions, IRE Trans. on Electronic Computers, vol. EC-7, no. 4, pp. 268-276, December, 1958.
Harris, B.: An Algorithm for Determining Minimal Representation of a Logic Function, IRE Trans. on Electronic Computers, vol. EC-6, no. 2, pp. 103-108, June, 1957.

Karnaugh, G.: The Map Method for Synthesis of Combinational Logic Circuits, Trans. AIEE, pt. I, Communs. and Electronics, vol. 72, pp. 593-599, November, 1953.
Ledley, R. S.: Mathematical Foundations and Computational Methods for a Digital Logic Machine, J. Operations Research Soc. Am., vol. 2, no. 3, pp. 249-279, August, 1954.
McCluskey, E. J., Jr.: Minimization of Boolean Functions, Bell System Tech. J., vol. 35, pp. 1-28, November, 1956.
Quine, W. V.: A Way to Simplify Truth Functions, Am. Math. Monthly, vol. 62, pp. 627-631, November, 1955.
Roth, J. P.: Algebraic Topological Methods for the Synthesis of Switching System I, Trans. Am. Math. Soc., vol. 88, no. 2, pp. 301-326, July, 1958.
Veitch, E. W.: A Chart Method for Simplifying Truth Functions, Proc. Assoc. Computing Machinery, May, 1952, pp. 127-133.
f. Switching Circuits and References. The and, or, and not gates that we have been considering are unidirectional-i.e., the signal is propagated in the forward direction only. In fact this is the only reason for having a special or gate, for otherwise the


Fig. 11-25. Switching circuit and transmission functions.
same result could be obtained with a simple soldered joint. However, there are circuits that can be described in terms of Boolean algebra, in which the signal can propagate in both forward and backward directions; these are called switching circuits. The usual implementation of switching circuits is with relays, although in special cases transistors can produce the same effect. It will suffice for our purposes to indicate switching circuits in terms of simple open or closed switches, as in the circuit of Fig. 11-25. Each switch is denoted by a Boolean variable, where a bar over the variable indicates an open switch, no bar a closed switch. The transmission function between two terminals indicates the switch conditions under which signal transmission can take place between these terminals, and is a Boolean function. Thus in the figure there will be transmission between $A$ and $B$ only when either switch $x$ is closed,
or both switches $y$ and $z$ are closed; thus the transmission function, denoted by $T_{A B}$, is given by $T_{A B}=x+y \cdot z$.

Although many of the problems of gating circuits and switching circuits are analogous, their characteristics can differ greatly. The first use of Boolean algebra in electrical engineering was made by C. E. Shannon in his well-known paper A Symbolic Analysis of Relay and Switching Circuits (Trans. AIEE, vol. 57, pp. 713-723, 1938). More recently F. E. Hohn and L. R. Schissler applied Boolean matrices to these problems in their paper Boolean Matrices and the Design of Combinational Relay Switching Circuits (Bell System T'ech. J., vol. 34, pp. 177-202, 1955). Their use of matrix methods is different, however, from those to be considered in Chap. 13 of this text, where we develop and apply the theory of Boolean matrices to gating circuits. Further reading on the design of switching circuits can be found in the works below:

Caldwell, S. H.: "Switching Circuits and Logical Design," John Wiley \& Sons, Inc., New York, 1958.
Higonnet, R. A., and R. A. Grea: "Logical Design of Electrical Circuits," McGrawHill Book Company, Inc., New York, 1958.
Huffman, D. A.: The Design and Use of Hazard-free Switching Networks, J. Assoc. Computing Machinery, vol. 4, pp. 47-62, January, 1957; The Synthesis of Sequential Switching Networks, J. Franklin Inst., vol. 257, nos. 2, 3, pp. 161-190, 275-303, March, April, 1954.
Humphrey, W. S., Jr.: "Switching Circuits," McGraw-Hill Book Company, Inc., New York, 1958.
Keister, W., A. E. Ritchie, and S. H. Washburn: "The Design of Switching Circuits," D. Van Nostrand Company, Inc., Princeton, N.J., 1951.

Mealy, G. H.: A Method for Synthesizing Sequential Circuits, Bell System Tech. J., vol. 34, pp. 1045-1080, September, 1955.

# ELEMENTARY COMPUTATIONAL METHODS IN CIRCUIT DESIGN 

## 12-1. Introduction

The material of this chapter and Chaps. 13 and 14 is based on the original research of the author. It is here presented for the first time in a complete and continuous development.

The previous two chapters have discussed (1) the method of writing the Boolean function for a circuit diagram and conversely drawing the circuit diagram that corresponds to a Boolean function, and (2) the method of writing the designation number for a Boolean function and conversely determining a Boolean function corresponding to a designation number. The present chapter deals with computational methods that involve designation numbers and illustrates applications of these methods to circuit design.

Three main topics are considered in this chapter. First the concept of constraints and the related concepts of logical dependence and independence are introduced and applied to circuit design. Next methods are given for solving Boolean equations, and applications of these methods to circuit design are discussed. Finally the concept of absolute simplest form is given, and applications are discussed. In each case the computational method is presented separately so that when applications to circuit design are given the student can concentrate solely on the engineering aspects of the problem.

## 12-2. Constraints

The Problem. Up to now we have been considering systems of independent elementary elements. That is, for elementary elements with the basis given above, the truth value of each elementary element is independent of the truth value of any other elementary element. It often happens, however, that this is not the case; the truth value of an elementary element may depend on the truth values of the other elementary elements for a particular problem. Such a dependence is given in terms of a combined element which is to remain true for this problem. For example, in a problem we might always have that $A \rightarrow B$. The effect of such a constraint is to limit the possible combinations of truth values that $A$ and $B$ can take simultaneously. If $A \rightarrow B$ is to hold, then $B$ cannot be false when $A$ is true; i.e., the combination of truth values $A$ true, $B$ false cannot occur.

Summarizing, a constraint is a logical relation between the elementary elements (i.e., a combined element) which is to be considered as tautologically true (i.e., always true) because of the stated or intrinsic circumstances of the problem. Put another way, constraints are factually true combined elements which are to remain true throughout a problem and therefore, with respect to this problem, can be considered as tautologies. In this section will be given a systematic computational method that automatically guarantees the maintenance of any desired constraints throughout the solution of a problem, so that all advantages produced by the constraints can be obtained in a straightforward manner.

In terms of digital-computer circuitry a constraint is a relation between the input-wire signals. The effect of constraints is to limit the number of input states; i.e., some simultaneous combinations of voltages on the wires are forbidden by the constraints. For example, suppose that a circuit had three input wires $A, B$, and $C$ such that no two of the wires could both have 1 -volt signals simultaneously, and it never occurs that all three of the wires have 0 -volt signals simultaneously. These constraints can be written as follows: $A \cdot B=0, A \cdot C=0, B \cdot C=0$, and $\bar{A} \cdot \bar{B} \cdot \bar{C}=0$ (where we recall that $A$ means that "wire $A$ has a 1 -volt signal" is true, etc.; see Chap. 10).

We have remarked that, when the usual basis is considered as a circuit function table, for $n$ input wires there are $2^{n}$ columns in the basis (or table), one column for each of the $2^{n}$ possible input states. With constraints, however, some of these $2^{n}$ states are forbidden. Hence it seems plausible that in order to take account of the constraints during a problem we should simply cross off those columns in the basis which represent forbidden states of the particular problem-forming a new, reduced, constrained basis. Then we should proceed as described in the previous chapters, except that all computational methods should be performed with respect to this constrained basis. This is the method for taking account of constraints.

The first problem that arises is: Given a set of constraints as Boolean functions, which columns of the basis are to be crossed off to form the constrained basis? Conversely, if we are given the columns to be crossed off or the constrained basis, what is the Boolean form of the constraints? The next problem is: How are the computational methods of the previous chapter performed with respect to a constrained basis?

Determining the Constrained Basis. Let us consider the first of these problems, to find the constrained basis, given the constraints. Suppose that $f_{1}(A, B, C, \ldots), f_{2}(A, B, C, \ldots), \ldots, f_{n}(A, B, C, \ldots$. $)$ are constraints which are all to be tautologically true simultaneously. We form the logical product of the designation numbers of the constraints,

$$
\prod_{j=1}^{n} \# f_{j}(A, B, C, \ldots)=f_{1}(A, B, C, \ldots) \cdot f_{2} \cdot f_{3} \cdots \cdot f_{n}
$$

It can be seen that the positions of the zeros in the resulting number
correspond to input states that can never occur if the constraints are all to remain true. Hence the constrained basis is formed by crossing off those columns of the usual basis that correspond to the positions of the zeros of the product number.

For example, consider the designation numbers of the constraints of the above example,

$$
\begin{array}{rll}
\#(A \cdot B=0) & =1110 & 1110 \\
\#(A \cdot C=0) & =1111 & 1010 \\
\#(B \cdot C=0) & =1111 & 1100 \\
\#(\bar{A} \cdot \bar{B} \cdot \bar{C}=0) & =\underline{0111} & 1111 \\
\text { Product } & \begin{array}{l}
0110 \\
0
\end{array} & 1000 \\
56
\end{array}
$$

Crossing off columns $0,3,5,6$, and 7 of the usual basis, we find for the constrained basis

$$
\begin{aligned}
& \# A=100 \\
& \# B=010 \\
& \# C=001
\end{aligned}
$$

Conversely, given a constrained basis, the explicit form of the constraints can be determined as a Boolean function. We shall give this procedure by means of an example. Suppose that the constrained basis is

$$
\begin{array}{ll}
\# A=0101 & 01 \\
\# B=0011 & 00 \\
\# C=0000 & 11
\end{array}
$$

The columns of this constrained basis correspond to the columns in positions $0,1,2,3,4$, and 5 of the standard basis. Hence we know that the designation number of the constraint must have units in these positions, 012345
and zeros elsewhere: 11111100 . With respect to the (unconstrained) standard basis this is the designation number of $\bar{B}+\bar{C}$, which is the desired constraint. Note that $\bar{B}+\bar{C}$ can equivalently be written as $\bar{B}+\bar{C}=I$ or $B \cdot C=0$. In finding a constraint from a constrained basis only a single constraint, corresponding to the final product of constraints, will appear, as was the case in our example.

Designation Numbers with Respect to a Constrained Basis. As stated above, when constraints exist in a problem the computational methods for that problem are to be carried out with respect to the constrained basis. Hence we must be able (1) to find the designation number of a Boolean function with respect to the constrained basis and conversely (2) to find the Boolean function corresponding to a given designation number (in any of the various forms considered in Chap. 11) with respect to the constrained basis. These computations are identical with those discussed in Chap. 11 except that all procedures are with respect to the constrained basis. However, for clarity we shall illustrate these procedures.

For example, consider the following constrained basis:

$$
\begin{array}{lll}
\# A & 0101 & 01 \\
\# B & 0011 & 00 \\
\# C & 0000 & 11
\end{array}
$$

To find $\#(\bar{A}+B \cdot C)$ with respect to this basis, we have

$$
\begin{aligned}
\# B & =0011 \\
\# C & =0000 \\
\#(B \cdot C) & =0000 \\
\# \bar{A} & =1010 \\
\#(\bar{A}+B \cdot C) & =1010 \\
\hline & 10
\end{aligned}
$$

Note that in this case it is simply $\# \vec{A}$.
For the converse problem of finding the Boolean function of a given designation number with respect to a constrained basis, the designation number can be given in two different ways: either (1) with the same number of positions as columns of the constrained basis, in which case it is assumed that the positions of the designation number correspond to the columns of the constrained basis, or (2) with $2^{n}$ positions, for $n$ elementary elements. In this second case the positions of the given designation numbers that correspond to the missing columns of the constrained basis are crossed off, and the second case is thereby reduced to the first case. For instance, suppose that it were desired to find the Boolean function corresponding to 10101011 with respect to the constrained basis given in the above example. Columns 6 and 7 of the standard basis are missing in this constrained basis; hence we cross off positions 6 and 7 of our number: 101010 拉.

The methods given in Chap. 11 for finding the simplest sum-ofproducts form can easily be adapted to take constraints into consideration. Every constrained basis column (i.e., eliminated column) can be used freely if it combines with nonconstrained columns corresponding to the units of the designation number. However, positions corresponding to constrained columns do not necessarily have to be covered by a prime implicant (as do the unit positions of the constrained designation number). In other words, the constrained positions can be thought of as units or zeros, whichever helps best to simplify the function.

For example, consider 111101 with respect to the constrained basis of the above example. By our first simplification method we have

|  |  |  |  | Constrained columns displayed for possible use |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | $\checkmark \checkmark$ | $\checkmark \checkmark$ |  |  |
| 0 | 10 | 11 |  | 0 0 1 |
| 0 | 01 | 10 |  | 1 |
| 0 | 00 | 01 |  | 11 1 |
| $\checkmark$ | $\checkmark \checkmark \checkmark$ |  |  |  |
| ¢0 | $11 \Phi 0$ | 11 | (Formed by |  |
| 0¢ | $\Phi 011$ | 11 | - combination | ion with |
| 00 | $0 \Phi 0 \pm$ | $\begin{array}{r}10 \\ \hline 1 \\ 4 \\ \hline\end{array}$ | (constrained | ed columns |
| $\pm$ | $1 \Phi$ |  |  |  |
| $\Phi$ | \$1 |  |  |  |
| 0 | ¢ $\mathbf{6}$ |  |  |  |

The table of prime implicants (omitting columns 6 and 7) becomes

|  | 0 | 1 | 2 | 3 | 5 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $\bar{C}$ | 0 | 1 | 2 | 3 |  |
| $A$ |  | 1 |  | 3 | 5 |
| $B$ |  |  | 2 | 3 |  |

whence $\bar{C}$ and $A$ are essential prime implicants whose sum covers the unit positions of the constrained designation number; thus

$$
111101=\#(A+\bar{C})
$$

The second method given in Chap. 11 for finding the simplest sum of products can likewise be adapted to handle constrained designation numbers. Consider again the number 111101 as an example:

| 0 | 1 | 2 | 3 | 5 | 6 | 7 | $C$ 4 | $B$ 2 | $A$ 1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| x |  | 2 | 1 |  |  |  | 0 | \$ | $\pm$ | $\bar{C}$ |
|  | 4 |  | 2 | x |  | 2 | $\Phi$ | $\Phi$ | 1 | $A$ |
| Constrained positions |  |  |  |  |  |  |  |  |  |  |

Note that we had to make use of constrained column 7 in order to form all combinations with $B$ (power 2) in the second line of the illustration.

The methods for going from the constrained designation number to other Boolean function forms, e.g., the first and second canonical forms, follow easily.

Constrained Boolean Algebra. An important point arises from the last example. Note that, with respect to the constrained basis given above, many strange relations hold; for example,

$$
A=A \cdot(\bar{B}+\bar{C}) \quad A+B=A \cdot \bar{B}+B \cdot \bar{C}+A \cdot C
$$

Such relations obviously do not hold with respect to the standard unconstrained basis. In other words, with respect to a constrained basis, we obtain a constrained Boolean algebra which is different from the unconstrained Boolean algebra described in Chap. 10. That is, additional relations hold in a constrained Boolean algebra that do not hold in the unconstrained algebra-but all relations that hold in the unconstrained algebra also hold in the constrained algebra. In general these additional relations in the constrained algebra often allow Boolean functions to be further simplified; that is, $A \cdot(\bar{B}+\bar{C})$ becomes just $A$, and $A \cdot \bar{B}+B \cdot \bar{C}+A \cdot C$ becomes $A+B$ with respect to the constrained basis of the above example. This of course means that in designing a circuit any knowledge of constraints should be used to greatest advantage for further simplifying the design. However, it is not always possible to simplify a function further; for instance, $\bar{A} \cdot \bar{C}+A \cdot C$ cannot be put into simpler form with respect to the constrained basis of the above example.

## EXERCISES

Find the constrained basis for the following sets of constraints:

$$
\begin{aligned}
& \text { Answer } \\
& \# A=010 \\
& \# B=001 \\
& \# A=0101 \\
& \# B=0011 \\
& \# B \\
& \# C=0000
\end{aligned}
$$

(a) $A \cdot B=0$
(b) $B \cdot C=0$
(c) $\bar{A}+B \cdot C=0$

$$
\# A=11
$$

$A \cdot C=0$

$$
\# B=01
$$

$$
\# C=00
$$

(d) $A \rightarrow C$

$$
\# A=0001
$$

$C \rightarrow B$

$$
\# B=0111
$$

$$
\# C=0011
$$

(e) $A \cdot(B \cdot \bar{C}+\bar{B} \cdot C)=0$

$$
\# A=0100 \quad 000
$$

$$
\# B=0010 \quad 111
$$

$$
\# C=0001 \quad 101
$$

$$
\# D=0000 \quad 011
$$

Find the constraints corresponding to the following constrained bases:
(f) $\# A=010$

## Answer

$\# B=001$
(g) $\# A=111$
$\# B=010$
$\# C=001$
(h) $\# A=0001$
$\bar{A} \cdot \bar{C}+B \cdot C=I$
$\# B=0111$
$\# C=0011$
With respect to the constrained basis given in the example above, find the designation numbers of:

## Answer

(i) $A \cdot \bar{B}+\bar{C} \quad 111101$
(j) $A \cdot(\bar{B}+\bar{C}) \quad 010101$
(k) $A \cdot B \cdot C+\bar{A} \cdot \bar{B} \cdot \bar{C} \quad 1000 \quad 00$
(l) $A \cdot(B+\bar{C})+\bar{A} \cdot(\bar{B}+C) \quad 1101 \quad 10$

With respect to the constrained basis given in the example above, find the simplest sum-of-products form of:

Answer
(m) 010101
( $n$ ) 011101
A
(o) 101001
$A+B$
(p) 01010100
(q) 01110101
(r) 10100101
$\bar{A} \cdot \bar{C}+A \cdot C$
A
$A+B$
$\bar{A} \cdot \bar{C}+A \cdot C$

## 12-3. Logical Dependence and Independence

Logical Independence. Boolean functions are logically independent (with respect to each other) if they can take on all possible combinations of truth values. There are $2^{n}$ possible combinations of truth values that $n$ Boolean functions can have (since each can take either of two truth values). Hence, in order to test the independence of $n$ Boolean functions, we need examine only the combinations of truth values that can occur: if all $2^{n}$ are possible, then they are independent; otherwise they are not. This can be done by means of the designation numbers for the Boolean functions. The procedure is illustrated by means of an example.

Suppose that we desire to know whether or not the functions of $A \cdot B+\bar{A} \cdot \bar{B}$ and $\bar{B}$ are independent. Write their designation numbers on successive rows,

$$
\begin{aligned}
\#(A \cdot B+\bar{A} \cdot \bar{B}) & =1001 \\
\# \bar{B} & =1100
\end{aligned}
$$

The columns represent all possible combinations of truth values. Since all four column combinations are there, we can say that $A \cdot B+\bar{A} \cdot \bar{B}$ and $\bar{B}$ are independent.

As another example, consider $A \cdot B+\bar{B} \cdot \bar{C}$ and $\bar{A} \cdot \bar{B}+B \cdot C$. We write

$$
\begin{array}{lll}
\#(A \cdot B+\bar{B} \cdot \bar{C})=1101 & 0001 \\
\#(\bar{A} \cdot \bar{B}+B \cdot C)=1000 & 1011
\end{array}
$$

Here $1,1,0$, and ${ }_{0}^{0}$ all appear; so the functions are, indeed, independent.
Consider next the three functions $A \cdot B+\bar{A} \cdot \bar{B}, \bar{B}$, and $A \cdot \bar{B}+\bar{A} \cdot B$. Write

$$
\begin{aligned}
\#(A \cdot B+\bar{A} \cdot \bar{B}) & =1001 \\
\# \bar{B} & =1100 \\
\#(A \cdot \bar{B}+\bar{A} \cdot B) & =0110
\end{aligned}
$$

Here we need $2^{3}=8$ possible combinations in order that the three functions be independent. But only four columns appear; hence the functions are not independent.

Logical Dependence. Boolean functions that are not logically independent are said to be logically dependent. This means that there must be some logical relations between them that can be expressed as a combined element. For instance, we know that $A \cdot B$ and $A+B$ are logically dependent because clearly $A \cdot B \rightarrow(A+B)$. Given a set of $n$ Boolean functions that are logically dependent, the explicit form of this dependence can be found by means of the designation numbers, in two steps. This first step is to write their designation numbers in successive rows. In this array of designation numbers cross off columns so that no two identical columns remain. Since the functions are dependent, there will be fewer than $2^{n}$ columns remaining. Put these columns in their standard order, and consider this resulting array as a constrained basis.

The second step is to find the constraint in the same manner as in the previous section, remembering that the rows are labeled by the given functions (and not elementary elements). For example, consider the functions $\bar{B} \cdot \bar{C}+\bar{A} \cdot C, \bar{A} \cdot \bar{C}+\bar{B} \cdot C$, and $\bar{B}$. Let us denote these by $f_{1}, f_{2}$, and $f_{3}$, respectively. Then we have
$\# f_{1}=1100$
$\# f_{2}=1010$
$\# f_{3}=1100$
and on rearrangement in standard order we obtain the constrained basis:

| $\#$ | 012 | 567 |
| :--- | :--- | :--- |
| $\# f_{1}=$ | 010 | 101 |
| $\# f_{2}=$ | 001 | 011 |
| $\# f_{3}=$ | 000 | 111 |

Hence the designation number of the constraint is 11100111 . This designation number is to be evaluated with respect to the following standard (unconstrained) basis (see Sec. 12-2):

$$
\begin{array}{ll}
\# f_{1}=0101 & 0101 \\
\# f_{2}=0011 & 0011 \\
\# f_{3}=0000 & 1111
\end{array}
$$

whence we have $11100111=\#\left(f_{1}+\bar{f}_{2}\right) \cdot f_{3}+\left(f_{1}+f_{2}\right) \cdot f_{3}$. Hence the logical dependence between $f_{1}, f_{2}$, and $f_{3}$ is given by

$$
\#\left(\bar{f}_{1}+\bar{f}_{2}\right) \cdot \bar{f}_{3}+\left(f_{1}+f_{2}\right) \cdot f_{3}=I
$$

as can be easily verified by substituting for $f_{1}, f_{2}$, and $f_{3}$ their corresponding functions in terms of $A, B$, and $C$.

## EXERCISES

Are the following sets of functions independent?

## Answer

$A \cdot B+\bar{A} \cdot \bar{B}$
$A \cdot \bar{B}+\bar{A} \cdot B$$\quad$ No
(b) $\bar{A} \quad$ Yes
(c) $\bar{B}$

Yes
$\bar{A}$
$(A \cdot B+\bar{A} \cdot \bar{B}) \cdot \bar{C}+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot C$
(d) $\begin{aligned} & \bar{B} \cdot \bar{C}+\bar{A} \cdot C \\ & \bar{A} \cdot \bar{C}+\bar{B} \cdot C\end{aligned}$

Yes
$(A+\bar{B}) \cdot \bar{C}+A \cdot \bar{B} \cdot C$
$\begin{array}{ll}\text { (e) } & \bar{B} \cdot \bar{C}+\bar{A} \cdot C \\ & \bar{A} \cdot \bar{C}+\bar{B} \cdot C \\ & \bar{B}\end{array}$

Find the logical dependence between the following sets of functions:
Answer
(f) $f_{1}=A \cdot B+\bar{A} \cdot \bar{B}$
$f_{1}=\bar{f}_{2}$ (that is, $\left.f_{1} \cdot \bar{f}_{2}+\bar{f}_{1} \cdot f_{2}=I\right)$
$f_{2}=A \cdot \bar{B}+\bar{A} \cdot B$
(g) $f_{1}=\bar{A} \cdot B$
$f_{1}=\tilde{f}_{2}$
$f_{2}=A+\bar{B}$
(h) $f_{1}=\bar{A} \cdot B$
$f_{2}=\bar{A}+B$
$f_{1} \rightarrow f_{2}$ (that is, $\left.\bar{f}_{1}+f_{2}=I\right)$

## 12-4. Constraints in Circuit Design

Simplification by Constraints. If some input states of a circuit are forbidden (i.e., it is known that these states will never occur), or if a logical relation (or dependence) is known to exist between the input wires of a circuit, then the circuit can be designed in terms of a constrained Boolean algebra. In other words, the computation may be performed with respect to the constrained basis.

There are important advantages in recognizing constraints in the inputs to a circuit. For as we mentioned in Sec. 12-2, Boolean functions, and hence the corresponding circuits, can often be further simplified in the constrained system. In this section illustrations will be given of the use of the computational methods associated with constraints in the design of circuits.

For example, suppose that it is desired to design a circuit with two input wires such that a 1 -volt signal output will exist whenever there are either 0 -volt signals on both wires $A$ and $B$ or else 1 -volt signals on both


Fig. 12-1. Circuit for $Z=A \cdot B+\bar{A} \cdot \bar{B}$. $A$ and $B$. Hence, if $Z$ represents the output, we have for the function table

$$
\begin{aligned}
& \# A=0101 \\
& \# B=0011 \\
& \# Z=1001=\#(A \cdot B+\bar{A} \cdot \bar{B})
\end{aligned}
$$

Hence the circuit appears as in Fig. 12-1.

Now suppose, in addition, that it is known that wire $B$ will have a unit signal whenever $A$ has one; i.e., if $A$ has a unit signal, then $B$ has one, or $A \rightarrow B$. Since $\#(A \rightarrow B)=1011$, the constrained basis becomes

$$
\begin{aligned}
& \# A=001 \\
& \# B=011 \\
& \# Z=101=\#(A+\bar{B})
\end{aligned}
$$

whence the circuit design appears as in Fig.


Fig. 12-2. Circuit for $Z=A+\bar{B}$. 12-2.

Hence the introduction of the constraint enabled a significant simplification in the circuit design.

Examples. As another example, suppose that it is desired to design a counter, with three input and three output wires, that counts: $1,2,3$, $4,5,1,2,3, \ldots$. . The function table for such a counter becomes

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# B=0011 & 0011 \\
\# C=0000 & 1111 \\
\hline \# A^{\prime}=010 & 11 \\
\# B^{\prime}=110 & 00 \\
\# C^{\prime}=001 & 10
\end{array}
$$

The statement of the problem does not specify the output states corresponding to input states 0,6 , and 7 . In fact, if the counter is initially set at input state 1 , and if it is de-


Fig. 12-3. Counter that counts 1, 2, 3, 4, $5,1,2,3, \ldots$. signed correctly, input states 0,6 , and 7 will never occur. Hence a constrained basis can be used,

$$
\begin{array}{ll}
\# A=101 & 01 \\
\# B=011 & 00 \\
\# C=000 & 11 \\
\hline \# A^{\prime}=010 & 11=\#(\bar{A}+C) \\
\# B^{\prime}=110 & 00=\#(\bar{A}+\bar{B}) \cdot \bar{C} \\
\# C^{\prime}=001 & 10=\#(A \cdot B+\bar{A} \cdot \bar{B})
\end{array}
$$

and the circuit is as in Fig. 12-3.
It is interesting to find out what would happen in this circuit if the


Fig. 12-4. State diagram of counter of Fig. $12-3$ with initial erroneous input 0,6 , or 7 .
initial input state were erroneously 0,6 , or 7 . To determine this, we simply list the designation numbers (with respect to the standard unconstrained base),

$$
\begin{array}{rlr}
\#(\bar{A}+C) & =1010 & 1111 \\
\#(\bar{A}+\bar{B}) \cdot \bar{C} & =1110 & 0000 \\
\#(A \cdot B+\bar{A} \cdot \bar{B}) & =1001 & 1001
\end{array}
$$

whence the state diagram becomes as in Fig. 12-4. Thus there is no difficulty, as all three states return to the loop.

Consider next a four-input circuit, two wires of which represent one 2-bit binary number $N$ and the other two wires of which represent another binary number $M$. The problem is to design this circuit so that the result will be $N-M$, where it is known beforehand that $N \geq M$; that is,
a negative number will never result. The function table for this circuit becomes

| $N_{1}$ | 0101 | 0101 | 0101 | 0101 |
| :--- | ---: | ---: | ---: | ---: |
| $N_{2}$ | 0011 | 0011 | 0011 | 0011 |
| $M_{1}$ | 0000 | 1111 | 0000 | 1111 |
| $M_{2}$ | 0000 | 0000 | 1111 | 1111 |
| $Z_{1}$ | 0101 | 010 | 01 | 0 |
| $Z_{2}$ | 0011 | 001 | 00 | 0 |

where input states $4,8,9,12,13$, and 14 can never occur according to the statement of the problem. Hence a constrained basis is used,

| $N_{1}$ | 0101 | 101 | 01 | 1 |
| :--- | :--- | :--- | :--- | :--- |
| $N_{2}$ | 0011 | 011 | 11 | 1 |
| $M_{1}$ | 0000 | 111 | 00 | 1 |
| $M_{2}$ | 0000 | 000 | 11 | 1 |
| $Z_{1}$ | 0101 | 010 | 01 | 0 |
| $Z_{2}$ | 0011 | 001 | 00 | $0=\#\left(N_{1} \cdot \bar{M}_{1}+\bar{N}_{1} \cdot M_{1}\right)$ |
| $\left.Z_{1}+\bar{M}_{1}\right) \cdot N_{2} \cdot \bar{M}_{2}$ |  |  |  |  |

and the circuit becomes as in Fig. 12-5.
As another example, suppose that it is desired to design a circuit that will have a 1-volt output signal whenever at least one, and no more than


Fig. 12-5. Circuit forming $N-M(N \geq M)$.
two, of the three input wires have 1-volt signals. Calling the inputs $U, V$, and $W$ and the output $Z$, we have for the function table

| $U$ | 0101 | 0101 |
| :--- | :--- | :--- |
| $V$ | 0011 | 0011 |
| $W$ | 0000 | 1111 |
| $Z$ | 0111 | 1110 |$=U \cdot \bar{V}+\bar{U} \cdot V+U \cdot \bar{W}+\bar{U} \cdot W$

Now suppose that $U, V$, and $W$ are themselves outputs of a certain circuit: $U=\bar{B} \cdot \bar{C}+\bar{A} \cdot C, V=\bar{A} \cdot \bar{C}+\bar{B} \cdot C$, and $W=\bar{B}$. The question is: Should $Z$ be formed as the above function, or can $Z$ be simplified owing
to our additional knowledge of $U, V$, and $W$ ? To answer this question, we must determine whether $U, V$, and $W$ are independent or whether they are dependent. It turns out that they are dependent (see Exercise $e$ of Sec. 12-3). Thus the next step is to find explicitly this dependence,

$$
\begin{aligned}
& \# U=\#(\bar{B} \cdot \bar{C}+\bar{A} \cdot C)=1100 \quad 1010 \\
& \# V=\#(\bar{A} \cdot \bar{C}+\bar{B} \cdot C)=1010 \quad 1100 \\
& \# W=\quad \# \bar{B} \quad=1100 \quad 1100
\end{aligned}
$$

The method of Sec. 12-3 gives the designation number of the constraint between $U, V$, and $W$ as 11100111 . This means that the input states 3 and 4 cannot occur. We evaluate $Z$ with respect to the constrained basis,

$$
\begin{array}{lll}
U & 010 & 101 \\
V & 001 & 011 \\
W & 000 & 111 \\
\hline Z & 011 & 110
\end{array}=U \cdot \bar{V}+\bar{U} \cdot V
$$

which is simpler than the case above, where we knew nothing about the dependence between $U, V$, and $W$. Hence the circuit is simply as in Fig. 12-6.

## EXERCISES

(a) Design a circuit that computes $2 N-7$, where it is known that negative results will never occur and $N$ is a 3 -bit binary number.
(b) Design a circuit that computes $2 N-7$, where it is known that positive results will never occur and $N$ is a 3 -bit binary number.
(c) Design a counter that counts successively in even numbers from 0 through 14, then returns to 0 and repeats.
(d) Design a counter that counts successively in odd numbers from 1 through 15 and then returns to 1 and repeats.
(e) Design a circuit with four inputs $U, V, W$, and $X$ that produces a unit output only when the input state is a multiple of 3 . Assume that $U, V, W$, and $X$ are the outputs of the following circuits:

$$
\begin{aligned}
U & =A \cdot \bar{B}+\bar{A} \cdot C \\
V & =A \cdot B+B \cdot C+\bar{A} \cdot \bar{C}+\bar{B} \cdot \bar{C} \\
W & =(A+\bar{B}) \cdot(B+\bar{C}) \\
X & =A \cdot(B+\bar{C})+\bar{A} \cdot(\bar{B}+C)
\end{aligned}
$$

## 12-5. Linear Boolean Equations

Boolean Equations. Just as in physics the solutions to many problems are obtained by considering ordinary algebraic equations in one or more unknowns, so in circuit design solutions are obtained by considering Boolean algebraic equations. An example of a Boolean algebraic equation is $X \cdot(A+B)=A \cdot B \cdot C$, where $X$ is an as yet unknown Boolean function of $A, B$, and $C$. Boolean algebraic equations may be solved by means of the designation numbers.

For example, in order to find an $X$ that satisfies

$$
X \cdot(A+B)=A \cdot B \cdot C
$$

we observe that $\#(A \cdot B \cdot C)=00000001$ and that

$$
\#(A+B)=01110111
$$

Since $\#(A \cdot B \cdot C)$ must be identical to $\#[X \cdot(A+B)]$ if the equation is to hold true, $\# X$ must be of the form $\_000 \_001$, where the two blanks may be filled with either zeros or units. There are thus exactly four nonequivalent combined elements that satisfy this equation, corresponding to the four designation numbers 0000 0001, 10000001 , 0000 1001, and 1000 1001. It can be verified that they are $A \cdot B \cdot C$, $A \cdot B \cdot C+\bar{A} \cdot \bar{B} \cdot \bar{C}, C \cdot(A \cdot B+\bar{A} \cdot \bar{B})$, and $\bar{A} \cdot \bar{B}+A \cdot B \cdot C$.

Similarly we can solve an implication, for example,

$$
X \cdot(A+B+\bar{C}) \rightarrow A \cdot B+\bar{B} \cdot C
$$

Now $\#(A+B+\bar{C})=11110111$, while $\#(A \cdot B+\bar{B} \cdot C)=00011101$, whence $X$ must have the form $000_{-} 0_{0}$. There are therefore $2^{4}=16$ solutions, or nonequivalent $X$ 's, that satisfy this equation. These can be seen to be $0, A \cdot B \cdot \bar{C}, \bar{A} \cdot \bar{B} \cdot C, A \cdot \bar{B} \cdot C, A \cdot B \cdot C$, $A \cdot B \cdot \bar{C}+\bar{A} \cdot \bar{B} \cdot C, A(B \cdot \bar{C}+\bar{B} \cdot C), A \cdot B, \bar{B} \cdot C,(\bar{A} \cdot \bar{B}+A \cdot B) \cdot C$, $A \cdot C, A \cdot B \cdot \bar{C}+\bar{B} \cdot C, A \cdot B+\bar{A} \cdot \bar{B} \cdot C, A \cdot(B+C),(\bar{B}+A) \cdot C$, and $A \cdot B+\vec{B} \cdot C$.

Since in general there will be many solutions to such equations as those considered above, it is probable that solutions satisfying certain given conditions will usually be desired. For example, it might be desired to find only those solutions $X$ of the implication

$$
X \cdot(A+B+\bar{C}) \rightarrow A \cdot B+\bar{B} \cdot C
$$

which also imply $A \cdot B+\bar{A} \cdot \bar{B}$ and satisfy

$$
X+B \cdot \bar{C}+A \cdot B \cdot C=C \cdot(A+\bar{B})+B \cdot \bar{C}
$$

Since $\#(A \cdot B+\bar{A} \cdot \bar{B})=1001$ 1001, positions $1,2,5$, and 6 must be zero; and since

$$
\begin{aligned}
\#[C \cdot(A+\bar{B})+B \cdot \bar{C}] & =00111101 \\
\#(B \cdot \bar{C}+A \cdot \bar{B} \cdot C) & =00110100
\end{aligned}
$$

and
$X$ must have units in positions 4 and 7 and zeros in 0,1 , and 6. Thus $X$ must be of the form 000 _ 1001 , where only position 3 is arbitrary. (Notice that the conditions on $X$ must be consistent with respect to each other.) Hence, of the original 16 possibilities for $X$, only 2 are left, $00001001=\#[C \cdot(A \cdot B+\bar{A} \cdot \bar{B})]$ and $00011001=\#(A \cdot B+\bar{A} \cdot \bar{B} \cdot C)$. Of course there are equations that have no solution, for example,

$$
A+C+X \rightarrow A \cdot B+\bar{B} \cdot C
$$

Some Further Notation. At this point it is important to discuss some further notation. We have noted above that occasionally subscripts were used to distinguish among elementary elements, as in $A_{1}, A_{2}, \ldots$, $A_{n}$. Superscripts, on the other hand, will be used to denote position in a designation number. Hence $\# B^{i}$ represents the bit, 0 or 1 , in the ith position of $\# B$. For example, if $\# B=00110011$, then $\# B^{3}=1$, $\# B^{4}=0$, etc.

In this notation we can conveniently rewrite our well-known rules for logical addition, multiplication, and negation of designation numbers as follows:

$$
\begin{aligned}
\#(A+B)^{i} & =\# A^{i}+\# B^{i} & & \text { where } 1+1=1+0=0+1=1 \\
\#(A \cdot B)^{i} & =\# A^{i} \cdot \# B^{i} & & \text { where } 1 \cdot 0=0 \cdot 1=0 \cdot 0=0 \text { and } 1 \cdot 1=1 \\
\text { and } \# \overline{A^{i}} & =0,1 & & \text { when } \# A^{i}=1,0, \text { respectively }
\end{aligned}
$$

It is occasionally important to tell explicitly what the elementary elements of a basis are. Thus, if we wish to talk about a basis for A, B, and $C$, we would write $b[A, B, C]$, while for $U, V$, and $W$ we would write $b[U, V, W]$.

Our superscripts can be used again to denote a position-this time of a column of a basis. Hence $b[A, B, C]^{5}$ would represent the fifth column of the (standard) basis or

$$
\begin{aligned}
& 1 \\
& 0 \\
& 1
\end{aligned}
$$

Solution to Linear Equations. An equation of the type

$$
R+P \cdot X+Q \cdot \bar{X}=S
$$

where $R, P, Q$, and $S$ are known elements (elementary or combined) and $X$ is an unknown element (elementary or combined), is called a unilateral linear equation in a single unknown $X$. The solutions to this equation are combined elements which, when substituted for $X$ in the equation, make the equation true. The solutions are found in terms of designation numbers as follows (where $X^{i}$ represents the bit 0 or 1 in the $i$ th position of \# $X$ ) :

For the equation $R+P \cdot X+Q \cdot \bar{X}=S$ we can show that, in the designation number of $X$,

$$
\begin{array}{ll}
X^{i}=1 & \text { if } \overline{S^{i}} \cdot\left(\overline{R^{i}+P^{i}}\right)+S^{i} \cdot\left(R^{i}+P^{i}\right)=1 \\
X^{i}=0 & \text { if } \overline{S^{i}} \cdot\left(\overline{R^{i}+Q^{i}}\right)+S^{i} \cdot\left(R^{i}+Q^{i}\right)=1
\end{array}
$$

for $i$ taking the values of all positions. If both conditions are satisfied for a position, two solutions are possible for that position; if neither is satisfied for a position, no solution exists. These formulas can be easily verified as follows: Suppose that $S^{i}=1$ for some $i$; then if $X^{i}=1, \overline{X^{i}}=0$, and the unit of $S^{i}$ must be contributed by either $R^{i}$ or $P^{i} \cdot X^{i}$, whence
$S^{i} \cdot\left(R^{i}+P^{i}\right)=1$; but if $S^{i}=0$ and $X^{i}=1, \overline{X^{i}}=0$, then both $R^{i}$ and $P^{i}$ must be zero, or $\overline{S^{i}} \cdot \overline{R^{i}} \cdot \overline{P^{i}}=\overline{S^{i}} \cdot\left(\overline{R^{i}+P^{i}}\right)=1$. Similarly for $X^{i}=0, \overline{X^{i}}=1$.

As an example, consider the equation

$$
\bar{A} \cdot \bar{B} \cdot \bar{C}+B \cdot X+(A+\bar{C}) \cdot \bar{X}=A \cdot B+\bar{A} \cdot \bar{C}
$$

Here with respect to the usual basis

$$
\begin{array}{lll} 
& & \\
\# S & =\#(A \cdot B+\bar{A} \cdot \bar{C}) & =1011 \\
\# P= & 0001 \\
\# P & =0011 & 0011 \\
\# R= & \#(\bar{A} \cdot \bar{B} \cdot \bar{C}) & =1000 \\
\# Q & =0000 \\
\# Q(A \cdot \bar{C}) & =1111 & 0101
\end{array}
$$

Let us illustrate the use of the formulas for the specific cases of $i=5$. We have

$$
\begin{aligned}
\overline{S^{5}} \cdot\left(\overline{R^{5}+P^{5}}\right)+S^{5} \cdot\left(R^{5}+P^{5}\right) & =\overline{0} \cdot \overline{(0+0})+0 \cdot(0+0) \\
& =1 \cdot(1)+0 \cdot(0)=1
\end{aligned}
$$

and hence $X^{5}$ can be 1. Also,

$$
\begin{aligned}
\overline{S^{5}} \cdot\left(\overline{R^{5}+Q^{5}}\right)+S^{5} \cdot\left(R^{5}+Q^{5}\right) & =\overline{0} \cdot(\overline{0+1})+0 \cdot(0+1) \\
& =1 \cdot(0)+0 \cdot(1)=0
\end{aligned}
$$

and hence $X^{5}$ cannot be 0 . Thus 1 is written for the fifth position of the designation number of $X$.

Consider $i=4$. We have

$$
\begin{aligned}
\overline{S^{4}} \cdot\left(\overline{R^{4}+P^{4}}\right)+S^{4} \cdot\left(R^{4}+P^{4}\right) & =\overline{0} \cdot(\overline{0+0})+0 \cdot(0+0) \\
& =1 \cdot(1)+0 \cdot(0)=1 \\
\overline{S^{4}} \cdot\left(\overline{R^{4}+Q^{4}}\right)+S^{4} \cdot\left(R^{4}+Q^{4}\right) & =\overline{0} \cdot(\overline{0+0})+0 \cdot(0+0) \\
& =1 \cdot(1)+0 \cdot(0)=1
\end{aligned}
$$

Hence $X^{4}$ can be 0 or 1 (producing two different solutions). We shall denote this by writing $\Phi$ in the fourth position of the designation number for $X$.

Following this procedure for $i=0,1,2,3,4,5,6$, and 7 , we find $\# X=\Phi 1 \Phi \Phi \Phi 10 \Phi$. Hence there are $2^{5}=32$ solutions.

An equation of the type $R+P \cdot X=Q \cdot \bar{X}+S$ is called a bilateral equation in a single unknown $X$. The solutions for

$$
R+P \cdot X=Q \cdot \bar{X}+S
$$

are

$$
\begin{array}{ll}
X^{i}=1 & \text { if } \overline{S^{i}} \cdot\left(\overline{R^{i}+P^{i}}\right)+S^{i} \cdot\left(R^{i}+P^{i}\right)=1 \\
X^{i}=0 & \text { if } \overline{R^{i}} \cdot\left(\overline{S^{i}+Q^{i}}\right)+R^{i} \cdot\left(S^{i}+Q^{i}\right)=1
\end{array}
$$

for $i$ taking the values of all positions. If neither condition is satisfied for a position, no solution exists.

For example, consider the equation

$$
\begin{aligned}
&(B \cdot \bar{C}+A \cdot \bar{B} \cdot C)+(C+\bar{A} \cdot B) \cdot X \\
&=(\bar{A} \cdot \bar{C}+B \cdot \bar{C}+A \cdot \bar{B} \cdot C) \cdot \bar{X}+\bar{B} \cdot C
\end{aligned}
$$

Here

$$
\begin{array}{lcll}
\# S= & \#(\bar{B} \cdot C) & & =0000 \\
\hline & 1100 \\
\# P= & \#(C+\bar{A} \cdot B) & =0010 & 1111 \\
\# R= & \#(B \cdot \bar{C}+A \cdot \bar{B} \cdot C) & =0011 & 0100 \\
\# Q=\#(\bar{A} \cdot \bar{C}+B \cdot \bar{C}+A \cdot \bar{B} \cdot C) & =1011 & 0100
\end{array}
$$

and therefore $\# X=1 \Phi 001 \Phi 00$, with $2^{2}=4$ solutions.
Simultaneous Linear Equations. Consider now $m$ simultaneous equations with a single unknown of either the unilateral or the bilateral type or both. The following procedure will produce all solutions each of which satisfies all the $m$ equations. We first take the solutions of each equation and place them in a column beneath each other. To find those solutions which satisfy all the $m$ equations simultaneously, we consider each digital position separately and "multiply" the respective digits of various solutions according to the following table (where $\Phi$ is used as above):

| "Multiply" | 0 | 1 | $\Phi$ |
| :---: | :---: | :---: | :---: |
| 0 | 0 | None | 0 |
| 1 | None | 1 | 1 |
| $\Phi$ | 0 | 1 | $\Phi$ |

For example, let us find the solution which satisfies both the equations solved above:

$$
\begin{array}{rll}
\text { Solution to lst equation }=\Phi 1 \Phi \Phi & \Phi 10 \Phi \\
\text { Solution to 2d equation }=1 \Phi 00 & 1 \Phi 00 \\
\text { Desired result }=\text { "product" of solutions }=1100 & 1100=\# \bar{B}
\end{array}
$$

Hence $X=\bar{B}$ is the only solution that satisfies both the above equations.

## EXERCISES

(a) Solve the following equation for $X$ as a function of $A, B$, and $C$ :

$$
\bar{A} \cdot \bar{B} \cdot \bar{C}+X \cdot \bar{C} \cdot(A+B)+\bar{X} \cdot C \cdot(\bar{A}+\bar{B})=A \cdot \bar{C}+\bar{A} \cdot C-\bar{B} \cdot \bar{C}
$$

Solution. $A \cdot \bar{C},(A+B) \cdot \bar{C}, A \cdot(B+\bar{C}), A \cdot B+\bar{B} \cdot \bar{C}$.
(b) How many solutions are there to the following equation?

$$
X \cdot(A \cdot B \cdot C+\bar{A} \cdot \bar{B})=A \cdot B \cdot C+\bar{A} \cdot \bar{B} \cdot \bar{C} \quad \text { Ans. } 2^{5}=32
$$

(c) How many solutions are there to the following implication?

$$
A \cdot B+\bar{A} \cdot \bar{B} \cdot \bar{C} \rightarrow X \cdot(A \cdot B+B \cdot C+A \cdot C+\bar{B} \cdot \bar{C}) \quad \text { Ans. } 2^{5}=32
$$

(d) Find $X$ if

$$
X \cdot(A \cdot B \cdot C+\bar{A} \cdot \bar{B})=A \cdot B \cdot C+\bar{A} \cdot \bar{B} \cdot \bar{C}
$$

(e) Find $X$ if

$$
X \cdot \bar{C} \cdot(A+B)+\bar{A} \cdot C=\bar{X} \cdot \bar{C} \cdot(\bar{A}+\bar{B}) .
$$

( $f$ ) Solve the equations in (d) and (e) simultaneously.
Solution. $\# X=10000101=\#(\bar{A} \cdot \bar{B} \cdot \bar{C}+A \cdot C)$.

## 12-6. The General Method for Solution to Any Number of Simultaneous Equations in Any Number of Unknowns

Equivalence. The general method for obtaining all solutions to an equivalence in many unknowns is best illustrated by an example. Consider the equation

$$
\begin{equation*}
A+B \cdot X \cdot \bar{Y}+C \cdot Y=\bar{A} \cdot \bar{X} \cdot \bar{Y}+\bar{B} \cdot \bar{X}+(C+A \cdot B) \tag{12-1}
\end{equation*}
$$

Recall that in the solution of equivalence equations the fundamental principle is that the designation numbers of each side of the equation must be identical. The system to be given here is designed to facilitate the calculation of those designation numbers for the unknown elements $X$ and $Y$ which fulfill this condition. The designation numbers of the unknowns are calculated one position at a time so that this position becomes the same for the total designation number of each side of the equation.

The solutions for each position $i$ of the unknowns must be among the set: $\left(X^{i}, Y^{i}\right)=(0,0) ;(1,0) ;(0,1) ;(1,1)$. With the aid of the work sheet shown in Table 12-1 each of these pairs is substituted into the equation; if a pair makes both sides equal, it is admitted as a possible solution.

Table 12-1. Work Sheet


Result Array

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# X$ | 1,1 <br> $\# Y$ | 0,0 <br> 0,1 | 0,1 <br> 0,1 | $0,1,0,1$ <br> 1,1 | 0,1 <br> $0,0,1,1$ | $0,1,0,1$ <br> 1,1 | 1,$0 ; 1$ <br> $0,0,1,1$ <br> $0,1,1$ | $0,1,0,1$ <br> $0,0,1,1$ |

On the work sheet are put the designation numbers of the coefficient of each unknown and the value corresponding to that unknown computed with each of the possible pairs. Thus in our example the coefficient of $X \cdot \bar{Y}$ is $B, 00110011$. When the pair $(0,0)$ is substituted into $X \cdot \bar{Y}$, the result is zero; for ( 1,0 ), a unit; for ( 0,1 ), a zero; for ( 1,1 ), a zero. Each line is treated similarly; but observe that for terms not involving either unknown the tautological element $I$ is placed in the unknown column. To check the $i$ th position of both sides of the equation for a pair of solutions, the column corresponding to that solution is logically multiplied by the column of the coefficients corresponding to the $i$ th position. The results above and those below the line are added logically, and the two sums are compared. If the sums are the same, that pair of

$$
\begin{gathered}
\text { TABLE }^{12-2} \\
0 \cdot 1=0 \\
0 \cdot 0=0 \\
1 \cdot 1=1 \\
\hline 1 \cdot 0=0 \\
1 \cdot 1=1 \\
1 \cdot 1=1
\end{gathered}
$$

solutions is admissible for that position. Consider in our example the pair $(0,1)$ and the fourth position (see Table 12-2). Then

$$
0 \cdot 1+0 \cdot 0+1 \cdot 1=1
$$

as does

$$
1 \cdot 0+1 \cdot 1+1 \cdot 1=1
$$

Therefore the pair $(0,1)$ is admissible as a solution for the fourth position and is recorded in the result array. The pair ( 1,1 ) is also a solution for this position, but $(1,0)$ and $(0,0)$ are not. When this procedure is repeated for all combinations, we obtain the results as shown in Table 12-1. There are thus

$$
2 \times 2 \times 2 \times 4 \times 2 \times 4 \times 3 \times 4=3,072
$$

different nonequivalent pairs of solutions to the equivalence equation of the example. Note that all nonequivalent pairs of solutions have been obtained.

Simultaneous Equivalences. The general method for obtaining all solutions to any number of simultaneous equivalences in many unknowns is again best illustrated by an example.

Consider the two simultaneous equations

$$
\begin{gather*}
A+B \cdot X \cdot \bar{Y}+C \cdot Y=\bar{A} \cdot \bar{X} \cdot \bar{Y}+\bar{B} \cdot \bar{X}+(C+A \cdot B)  \tag{12-1}\\
B \cdot X \cdot Y+C \cdot(A+B) \cdot Y=\bar{B} \cdot \bar{X} \cdot \bar{Y} \tag{12-2}
\end{gather*}
$$

We want to find combined elements that when substituted for $X$ and $Y$ in the equations will make both true simultaneously. The method for obtaining these solutions is evidently to record in the table of results only

Table 12-3. Work Sheet

those position solutions which satisfy both the simultaneous equations. The procedure is analogous to that of the single equation (see Table 12-3). Now there remain $2 \times 1 \times 1 \times 3 \times 2 \times 1 \times 1 \times 2=24$ nonequivalent pairs of solutions to both these equations.
Simultaneous Equivalences and Implications. The solution to an implication in several unknowns is obtained in the way described above for an equivalence, except that, for the implication $L \rightarrow R$, it is not necessary that $R$ and $L$ have identical numbers; but $R$ must have a unit at least wherever $L$ has a unit. Thus for implications one follows the whole procedure described above, except that for any digital position the result is not recorded only when there is a calculated unit above the line corresponding to a calculated zero below (here we assume $L$ above the line and $R$ below).

The extension of these results to simultaneous implications as well as to mixed systems of simultaneous equivalences and implications is immediate. For example, consider the following mixed system of simultaneous statements:

$$
\begin{align*}
& A+B \cdot X \cdot \bar{Y}+C \cdot Y=\bar{A} \cdot \bar{X} \cdot \bar{Y}+\bar{B} \cdot \bar{X}+(C+A \cdot B) \\
&(12-1)  \tag{12-2}\\
& A \cdot X \cdot Y+C \cdot(A+B) \cdot Y=\bar{B} \cdot \bar{X} \cdot \bar{Y}  \tag{12-3}\\
& A \cdot(X+Y)+A \cdot B \cdot(X+\bar{Y}) \rightarrow X \cdot Y+A \cdot C
\end{align*}
$$

Table 12-4. Work Sheet


Result Array

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# X$ | 1,1 | 0 | 0 | 0 | 0,1 | 1 | 1 | 0,1 |
| $\# Y$ | 0,1 | 1 | 1 | 1 | 1,1 | 0 | 0 | 0,0 |

The work leading to the results is shown in Table 12-4. Note that a dashed line is used to denote implication. There remain only

$$
2 \times 1 \times 1 \times 1 \times 2 \times 1 \times 1 \times 2=8
$$

pairs of nonequivalent solutions for this system of two equivalences and one implication. Written out explicitly, the eight pairs of solutions are

| $X$ | $=\bar{A} \cdot(B \cdot C+\bar{B} \cdot \bar{C})+A \cdot \bar{B} \cdot C$ | $X$ | $=C \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot \bar{C}$ |
| ---: | :--- | ---: | :--- |
| $Y$ | $=\bar{C} \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot C$ | $Y$ | $=\bar{C} \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot C$ |
| $X$ | $=\bar{A} \cdot(B \cdot C+\bar{B} \cdot \bar{C})+A \cdot \bar{B} \cdot C$ | $X$ | $=C \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot \bar{C}$ |
| $Y$ | $=\bar{C}+\bar{A} \cdot \bar{B}$ | $Y$ | $=\bar{C}+\bar{A} \cdot \bar{B}$ |
| $X$ | $=C \cdot(\bar{A}+\bar{B})+\bar{A} \cdot \bar{B}$ | $X$ | $=C+\bar{A} \cdot \bar{B}$ |
| $Y$ | $=\bar{C} \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot C$ | $Y$ | $=\bar{C} \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot C$ |
| $X$ | $=C \cdot(\bar{A}+\bar{B})+\bar{A} \cdot \bar{B}$ | $X$ | $=C+\bar{A} \cdot \bar{B}$ |
| $Y$ | $=\bar{C}+\bar{A} \cdot \bar{B}$ |  | $Y=\bar{C}+\bar{A} \cdot \bar{B}$ |

One can verify any of these pairs by direct substitution back into the original three statements.

## EXERCISES

Solve the following sets of simultaneous Boolean equations for the unknowns $X$ and $Y$ :
(a) $(A+B) \cdot X+A \cdot \bar{X} \cdot \bar{Y}=A, \bar{A} \cdot \bar{Y}+X=A+B, X \cdot Y \rightarrow B$.

Solution. $\quad X=A, Y=A \cdot B+\bar{A} \cdot \bar{B} ; X=A, Y=A+\bar{B}$.
Work Sheet for Exercise a


Result Array

| $i$ | 0 | 1 | 2 | 3 |
| :---: | :---: | :---: | :---: | :---: |
| $\# X$ | 0 | 1,1 | 0 | 1 |
| $\# Y$ | 1 | 0,1 | 0 | 1 |

$$
\begin{aligned}
& 0101=A \\
& 1001=A \cdot B+\bar{A} \cdot \bar{B} \\
& 0101=A \\
& 1101=A+\bar{B}
\end{aligned}
$$

(b) $X \cdot Y=A \cdot \bar{B}, A+B=\bar{A} \cdot Y+X,(A+B) \cdot X+A \cdot Y=A$.

Solution. $\quad X=A, Y=A \cdot \bar{B}+\bar{A} \cdot B$.
(c) $X \cdot Y=A \cdot \bar{B}, \bar{A} \cdot B=\bar{A} \cdot Y+X,(A+B) \cdot X+A \cdot Y=A$.

No solution. Why?
(d) $X \cdot(A+B)+Y \cdot(A+C)=(\bar{X} \cdot \bar{Y}+X \cdot Y) \cdot(\bar{A}+\bar{B}+\bar{C})$,

$$
X \cdot(A \cdot B+\bar{A} \cdot \bar{B}) \rightarrow Y+A \cdot B+C .
$$

There are four sets of solutions:

$$
\begin{array}{llrl}
X & =A \cdot \bar{C}+(\bar{A}+\bar{B}) \cdot C & X & =A \cdot \bar{C}+(\bar{A}+\bar{B}) \cdot C \\
Y & =\bar{C}+A \cdot \bar{B}+\bar{A} \cdot B & Y & =\bar{C}+(\bar{A}+\bar{B}) \cdot C \\
X & =(A+B) \cdot \bar{C}+(\bar{A}+\bar{B}) \cdot C & X & =(A+B) \cdot \bar{C}+(\bar{A}+\bar{B}) \cdot C \\
Y & =\bar{C}+A \cdot \bar{B}+\bar{A} \cdot B & Y & =\bar{C}+(\bar{A}+\bar{B}) \cdot C
\end{array}
$$

## 12-7. Solution to Equations in Circuit Design

Examples. In circuit design, problems that involve solutions of equations are often of an exploratory nature-for example, they may arise in the investigation of various alternative circuits. The method of solution to equations enables the design engineer to determine what additional circuitry will be needed if combinations of existing circuits are to be used to produce a given desired result. As in ordinary algebraic problems the formulation of the equations requires ingenuity in interpreting the physical situations in terms of mathematical concepts.

For example, suppose that the circuit shown in Fig. 12-7 had already been constructed. It is desired to have the output be

$$
Z=A \cdot B+A \cdot \bar{C}+B \cdot \bar{C}+\bar{B} \cdot C
$$

The problem is to design two circuits, with inputs $A, B$, and $C$, such that when their outputs are attached to input wires $X$ and $Y$, the desired $Z$ will be obtained. As the circuit now stands,

$$
Z=(A+B) \cdot X \cdot \bar{Y}+(\bar{A}+\bar{B}) \cdot Y
$$



Fig. 12-7. Circuit output of $Z=$ $(A+B) \cdot X \cdot \bar{Y}+(\bar{A}+\bar{B}) \cdot Y$.
and hence we want to find $X=X(A, B, C), Y=Y(A, B, C)$ such that

$$
(A+B) \cdot X \cdot \bar{Y}+(\bar{A}+\bar{B}) \cdot Y=A \cdot B+A \cdot \bar{C}+B \cdot \bar{C}+\bar{B} \cdot C
$$

Solving this equation by the method of the previous section, we obtain the result array:

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# X$ | 0,1 | $1,0,1$ | $1,0,1$ | 1 | 0,1 | $1,0,1$ | 0 | 1 |
| $\# Y$ | 0,0 | $0,1,1$ | $0,1,1$ | 0 | 1,1 | $0,1,1$ | 0 | 0 |

and hence there are $2 \cdot 3 \cdot 3 \cdot 1 \cdot 2 \cdot 3 \cdot 1 \cdot 1=108$ sets of solutions. The problem now reduces to choosing from these a simple solution. Note that we might choose

$$
\begin{array}{ll}
\# X=0101 & 0101 \\
\# Y=0 \Phi 10 & 1 \Phi 00
\end{array}
$$

where $X=A$. However, even though we would have $2 \times 2=4$ choices for $Y$, none of them is very simple.

From the result array it is easily determined by means of the elimination pairs that $Y$ must include $\bar{B}$ and $C$. Choosing the only $Y$ that does not involve $A$, we find $\# Y=0000 \quad 1100=\bar{B} \cdot C$. With this $Y$ we must have $\# X=\Phi 111 \Phi \Phi 01$, from which we can choose


Fig. 12-8. Circuits for $X=A+\bar{C}$, $Y=\bar{B} \cdot C$.

As another example, suppose that the circuit of Fig. 12-9 has already been constructed and that our problem is to design circuits with outputs $X$ and $Y$ such that $Z=\bar{A} \cdot B \cdot \bar{C}+(\bar{A}+B) \cdot C$ and such that neither


Fig. 12-9. Circuit for $Z=X \cdot[(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot \bar{C}]+Y$.
$X$ nor $Y$ will involve $A$. First note that

$$
S=(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot \bar{C}
$$

whence we wish to solve the following equation for $X$ and $Y$ in terms of $A, B$, and $C$ :

$$
\begin{array}{r}
X \cdot[(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C+(A \cdot \bar{B}+\bar{A} \cdot B) \cdot \bar{C}]+Y \\
=\bar{A} \cdot B \cdot \bar{C}+(\bar{A}+B) \cdot C
\end{array}
$$

Observing the result array with respect to the elimination pairs of $A$, we find the following set of solutions not involving $A$ :

$$
X=B+C \quad Y=B \cdot C
$$

As an example in simultaneous equations, suppose that the two circuits $Z_{1}$ and $Z_{2}$ shown in Fig. 12-10 are already constructed. It is desired to design two circuits such that, when their outputs are connected to $X$


Fig. 12-10. Circuits for $Z_{1}=X+\bar{Y}, Z_{2}=X \cdot Y+\bar{X} \cdot \bar{Y}$.
and $Y$ of $Z_{1}$, there will result $Z_{1}=A \cdot \bar{B}+\bar{A} \cdot B+C$ and, when connected to $Z_{2}$, there will result $Z_{2}=A \cdot \bar{B} \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C$. Here we are required to solve the two simultaneous equations

$$
\begin{aligned}
X+\bar{Y} & =A \cdot \bar{B}+\bar{A} \cdot B+C \\
X \cdot Y+\bar{X} \cdot \bar{Y} & =A \cdot \bar{B} \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C
\end{aligned}
$$

One simple result is $X=\bar{A} \cdot B+C$ and $Y=A \cdot B+\bar{A} \cdot \bar{B}$.

## EXERCISES

(a) Suppose that the circuit of Fig. 12-11 has already been constructed and that it is desired to have $Z=A \cdot B \cdot \bar{C}+(\bar{A} \cdot B+A \cdot \bar{B}) \cdot C$. The problem is to design


Frg. 12-11. (a) Circuit for Exercise a; (b) a simple solution.

(a)

(b)

Fig. 12-12. (a) Circuit for Exercise b; (b) a simple solution.


Fig. 12-13. Circuit for Exercise $c$.


Fig. 12-14. Circuits for Exercise d.
simple circuits which would each have inputs $A, B$, and $C$ such that, when their outputs are connected to $W, X$, and $Y$, the output of the given circuit is the desired $Z$. One solution is shown in the figure.
(b) Suppose that the circuit of Fig. 12-12 had already been constructed. Design simple circuits with outputs to be connected to $X$ and $Y$ to give $Z=(A+\bar{B}) \cdot \bar{C}+$ $(A+B) \cdot C$. One simple solution is shown in the figure.
(c) Suppose that a circuit had been constructed with output $S=(A \cdot B+\vec{A} \cdot \bar{B}) \cdot \vec{C}$ $+(A \cdot \bar{B}+\vec{A} \cdot B) \cdot C$. It is desired to transform this circuit as shown in Fig. 12-13 so that the output will be $Z=(A+\bar{B}) \cdot \bar{C}+(\bar{A}+\bar{B}) \cdot C$, as shown. The problem is to find simple circuits for $X$ and $Y$. One solution is $X=B$ and $Y=\bar{B}$.
(d) Suppose that the two circuits of Fig. 12-14 have already been constructed. Design three circuits such that, if their outputs are connected, respectively, to $U, V$, and $W$, then $Z_{1}=A \cdot \bar{B}+\bar{A} \cdot B+C$ and $Z_{2}=A \cdot \bar{B} \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C$. One set of solutions is $U=A \cdot(\bar{B}+\bar{C}), V=\bar{B} \cdot \bar{C}+A \cdot B$, and $W=B$.

## 12-8. The Absolute Simplest Form and Change of Variables

The Absolute Simplest Form. It can be shown that a designation number for $n$ elementary elements with $u$ units cannot be represented as a combined element with fewer than $n-k-1$ operations of the type $\cdot$ and + , where $k$ is the largest integer such that $2^{k}$ is a factor of $u$. An element with this minimum number of operations is called an absolute simplest form and can easily be systematically constructed. Some of them are given in Table 12-5.

A method for constructing an absolute simplest form, given $n$ and $u$, involves four steps as follows: (1) First write $u$ as a binary number. (2) Fill in zeros to the left of this binary number to make $n$ bits altogether. (3) Starting at the left, number these bits by $n, n-1, n-2$, . . . , 1. (4) Then, denoting the elementary elements by $A_{n}, A_{n-1}$, ..., $A_{1}$, an absolute simplest form is obtained by working successively from left to right and corresponding to the $i$ th bit placing " $A_{i}$. (" if the $i$ th bit is a zero and placing " $A_{i}+$ (" if the $i$ th bit is a unit. This process ends on the last (rightmost) unit of the binary number $u$.

For example, let us find an absolute simplest form for a designation number with ten units and five elementary elements, that is, $n=5$ and $u=10$ (decimal). Since $u=1010$ (binary), we affix one zero to the left and number the positions, obtaining

| 0 | 1 | 0 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- |
| 5 | 4 | 3 | 2 | 1 |

An absolute simplest form is then obtained as indicated,

| 0 | 1 | 0 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: |
| 5 | 4 | 3 | 2 | 1 |
| $A_{5} \cdot\left(A_{4}+\right.$ | $\left.\left(A_{3} \cdot\left(A_{2}\right)\right)\right)=A_{5} \cdot\left(A_{4}+A_{3} \cdot A_{2}\right)$ |  |  |  |

where the final expression is in terms of the more common use of parentheses.

As another example, let us construct an absolute simplest form for a designation number that contains 31,792 units in 17 variables. The

Table 12-5. Absolute Simplest Forms for $n$ Elementary Elements Whose Designation Numbers Contain $u$ Units

|  | $n=2$ | $n=3$ | $n=4$ | $n=5$ |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & u=1 \\ & u=2 \\ & u=3 \\ & u=4 \end{aligned}$ | $\left\lvert\, \begin{aligned} & A_{2} \cdot A_{1} \\ & A_{2} \\ & A_{2}+A_{1} \\ & I \end{aligned}\right.$ | $\begin{aligned} & A_{3} \cdot A_{2} \cdot A_{1} \\ & A_{3} \cdot A_{2} \\ & A_{3} \cdot\left(A_{2}+A_{1}\right) \\ & A_{3} \end{aligned}$ | $\begin{aligned} & A_{4} \cdot A_{3} \cdot A_{2} \cdot A_{1} \\ & A_{4} \cdot A_{3} \cdot A_{2} \\ & A_{4} \cdot A_{3} \cdot\left(A_{2}+A_{1}\right) \\ & A_{4} \cdot A_{3} \end{aligned}$ | $\begin{aligned} & A_{5} \cdot A_{4} \cdot A_{3} \cdot A_{2} \cdot A_{1} \\ & A_{5} \cdot A_{4} \cdot A_{3} \cdot A_{2} \\ & A_{5} \cdot A_{4} \cdot A_{3} \cdot\left(A_{2}+A_{1}\right) \\ & A_{5} \cdot A_{4} \cdot A_{3} \end{aligned}$ |
| $u=5$ |  | $A_{3}+A_{2} \cdot A_{1}$ | $A_{4} \cdot\left(A_{3}+A_{2} \cdot A_{1}\right)$ | $A_{5} \cdot A_{4} \cdot\left(A_{3}+A_{2} \cdot A_{1}\right)$ |
| $u=6$ |  | $A_{3}+A_{2}$ | $A_{4} \cdot\left(A_{3}+A_{2}\right)$ | $A_{5} \cdot A_{4} \cdot\left(A_{3}+A_{2}\right)$ |
| $u=7$ |  | $A_{3}+A_{2}+A_{1}$ | $A_{4} \cdot\left(A_{3}+A_{2}+A_{1}\right)$ | $A_{5} \cdot A_{4} \cdot\left(A_{3}+A_{2}+A_{1}\right)$ |
| $u=8$ |  | I | $A_{4}$ | $A_{5} \cdot A_{4}$ |
| $u=9$ |  |  | $A_{4}+A_{3} \cdot A_{2} \cdot A_{1}$ | $A_{5} \cdot\left(A_{4}+A_{3} \cdot A_{2} \cdot A_{1}\right)$ |
| $u=10$ |  |  | $A_{4}+A_{3} \cdot A_{2}$ | $A_{5} \cdot\left(A_{4}+A_{3} \cdot A_{2}\right)$ |
| $u=11$ |  |  | $A_{4}+A_{3} \cdot\left(A_{2}+A_{1}\right)$ | $A_{5} \cdot\left(A_{4}+A_{3} \cdot\left(A_{2}+A_{1}\right)\right)$ |
| $u=12$ |  |  | $A_{4}+A_{3}$ | $A_{5} \cdot\left(A_{4}+A_{3}\right)$ |
| $u=13$ |  |  | $A_{4}+A_{3}+A_{2} \cdot A_{1}$ | $A_{5} \cdot\left(A_{4}+A_{3}+A_{2} \cdot A_{1}\right)$ |
| $u=14$ |  |  | $A_{4}+A_{3}+A_{2}$ | $A_{5} \cdot\left(A_{4}+A_{3}+A_{2}\right)$ |
| $u=15$ |  |  | $A_{4}+A_{3}+A_{2}+A_{1}$ | $A_{5} \cdot\left(A_{4}+A_{3}+A_{2}+A_{1}\right)$ |
| $u=16$ |  |  |  |  |
| $u=17$ |  |  |  | $A_{5}+A_{4} \cdot A_{3} \cdot A_{2} \cdot A_{1}$ |
| $u=18$ |  |  |  | $A_{5}+A_{4} \cdot A_{3} \cdot A_{2}$ |
| $u=19$ |  |  |  | $A_{5}+A_{4} \cdot A_{3} \cdot\left(A_{2}+A_{1}\right)$ |
| $u=20$ |  |  |  | $A_{5}+A_{4} \cdot A_{3}$ |
| $u=21$ |  |  |  | $A_{5}+A_{4} \cdot\left(A_{3}+A_{2} \cdot A_{1}\right)$ |
| $u=22$ |  |  |  | $A_{5}+A_{4} \cdot\left(A_{3}+A_{2}\right)$ |
| $u=23$ |  |  |  | $A_{5}+A_{4} \cdot\left(A_{3}+A_{2}+A_{1}\right)$ |
| $u=24$ |  |  |  | $A_{5}+A_{4}$ |
| $u=25$ |  |  |  | $A_{5}+A_{4}+A_{3} \cdot A_{2} \cdot A_{1}$ |
| $u=26$ |  |  |  | $A_{5}+A_{4}+A_{3} \cdot A_{2}$ |
| $u=27$ |  |  |  | $A_{5}+A_{4}+A_{3} \cdot\left(A_{2}+A_{1}\right)$ |
| $u=28$ |  |  |  | $A_{5}+A_{4}+A_{3}$ |
| $u=29$ |  |  |  | $A_{5}+A_{4}+A_{3}+A_{2} \cdot A_{1}$ |
| $u=30$ |  |  |  | $A_{5}+A_{4}+A_{3}+A_{2}$ |
| $u=31$ |  |  |  | $A_{5}+A_{4}+A_{3}+A_{2}+A_{1}$ |
| $u=32$ |  |  |  |  |

binary representation of 31,792 , with two zeros affixed to the left, is

| 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
| 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |

Thus an absolute simplest form (removing unnecessary parentheses) will be

$$
\begin{aligned}
A_{17} \cdot A_{16} \cdot\left(A_{15}+A_{14}+A_{13}+A_{12}\right. & +A_{11} \\
& \left.+A_{10} \cdot A_{9} \cdot A_{8} \cdot A_{7} \cdot\left(A_{6}+A_{5}\right)\right)
\end{aligned}
$$

Corresponding to a given $n$ and $u$, there are in general many possible absolute simplest forms. For example, for $n=3, u=5$, we could have
as well as $A_{3}+A_{2} \cdot A_{1}$ the 24 nonequivalent functions given in Table 12-6. In fact it might be wise to say that the absolute simplest form in this case is $X_{3}+X_{2} \cdot X_{1}$, where $X_{1}$ can be $A_{1}$ or $\bar{A}_{1}, A_{2}$ or $\bar{A}_{2}$, or $A_{3}$ or $\bar{A}_{3}$ provided that the same symbol is not used for more than one $X_{i}$. Note, however, that, since the operations • and + are each commutative, not all possible combinations give nonequivalent functions.

Table 12-6. All 24 Possible Absolute Simplest Forms for $n=3, u=5$

| $A_{3}+A_{2} \cdot A_{1}$ | $A_{2}+A_{3} \cdot A_{1}$ | $A_{1}+A_{3} \cdot A_{2}$ |
| :--- | :--- | :--- |
| $\bar{A}_{3}+A_{2} \cdot A_{1}$ | $\bar{A}_{2}+A_{3} \cdot A_{1}$ | $\bar{A}_{1}+A_{3} \cdot A_{2}$ |
| $A_{3}+\bar{A}_{2} \cdot A_{1}$ | $A_{2}+\bar{A}_{3} \cdot A_{1}$ | $A_{1}+\bar{A}_{3} \cdot A_{2}$ |
| $A_{3}+A_{2} \cdot \bar{A}_{1}$ | $A_{2}+A_{3} \cdot \bar{A}_{1}$ | $A_{1}+A_{3} \cdot \bar{A}_{2}$ |
| $\bar{A}_{3}+\bar{A}_{2} \cdot A_{1}$ | $\bar{A}_{2}+\bar{A}_{3} \cdot A_{1}$ | $\bar{A}_{1}+\bar{A}_{3} \cdot A_{2}$ |
| $\bar{A}_{3}+A_{2} \cdot \bar{A}_{1}$ | $\bar{A}_{2}+A_{3} \cdot \bar{A}_{1}$ | $\bar{A}_{1}+A_{\bar{A}} \cdot \bar{A}_{2}$ |
| $A_{3}+\bar{A}_{2} \cdot \bar{A}_{1}$ | $A_{2}+\bar{A}_{3} \cdot \bar{A}_{1}$ | $A_{1}+\bar{A}_{3} \cdot \bar{A}_{2}$ |
| $\bar{A}_{3}+\bar{A}_{2} \cdot \bar{A}_{1}$ | $\bar{A}_{2}+\bar{A}_{3} \cdot \bar{A}_{1}$ | $\bar{A}_{1}+\bar{A}_{3} \cdot \bar{A}_{2}$ |

Change of Variables. The question naturally arises as to the value of absolute simplest forms. The answer to this concerns the concept of change of variables, which we shall now discuss. The concept of change of variables in Boolean algebra is similar to the concept of change of variables in ordinary algebra. If $A, B$, and $C$ are elementary elements, we perform a change of variables by letting

$$
A=A\left(A^{\prime}, B^{\prime}, C^{\prime}\right) \quad B=B\left(A^{\prime}, B^{\prime}, C^{\prime}\right) \quad C=C\left(A^{\prime}, B^{\prime}, C^{\prime}\right)
$$

where $A^{\prime}, B^{\prime}, C^{\prime}$ are new variables.
If $A, B$, and $C$ are independent, we must be sure that the new variables are independent, i.e., that no dependence between $A, B$, and $C$ is introduced by the particular Boolean functions chosen for $A\left(A^{\prime}, B^{\prime}, C^{\prime}\right)$, $B\left(A^{\prime}, B^{\prime}, C^{\prime}\right)$, and $C\left(A^{\prime}, B^{\prime}, C^{\prime}\right)$. For example, suppose that we wish to change from variables $A$ and $B$ to new variables $A^{\prime}$ and $B^{\prime}$ by the transformation $A=A^{\prime} \cdot B^{\prime}+\bar{A}^{\prime} \cdot \bar{B}^{\prime}, B=\bar{A}^{\prime}$. It can easily be seen with respect to the standard basis $b\left[A^{\prime}, B^{\prime}\right]$ that $A^{\prime} \cdot B^{\prime}+\bar{A}^{\prime} \cdot \bar{B}^{\prime}$ and $\bar{A}^{\prime}$ are independent; so the transformation is valid, i.e., keeps $A$ and $B$ independent. Hence all Boolean functions of $A$ and $B$ can now be written in terms of $A^{\prime}$ and $B^{\prime}$. For example, in the new variables
$A \cdot \bar{B}+\bar{A} \cdot B=\left(A^{\prime} \cdot B^{\prime}+\overline{A^{\prime}} \cdot \bar{B}^{\prime}\right) \cdot A^{\prime}+\left(\overline{A^{\prime} \cdot B^{\prime}+\overline{A^{\prime}} \cdot \bar{B}^{\prime}}\right) \cdot \bar{A}^{\prime}=B^{\prime}$
In addition the new (primed) variables can be found in terms of the old (unprimed) variables. In our case $A^{\prime}=\bar{B}, B^{\prime}=A \cdot \bar{B}+\bar{A} \cdot B$.

Now we can again consider the problem of the value of the absolute simplest form. For any combined element we can, by counting the units in its designation number, find its corresponding absolute simplest form. This form can always be obtained by making a change of variables; i.e., a particular change of variables can be made so that the given Boolean function will be transformed into its absolute simplest form in terms of the new variables. The need for such a technique in circuit design can be understood from the following consideration: First the circuit that
generates an absolute simplest form cannot be further simplified. In some cases there will be a saving in circuitry if a given function is formed by transforming to new variables and passing these through a circuit which generates the absolute simplest form. In fact it is often possible to find a single transformation that will put several output functions into their absolute simplest forms!

The procedure for determining that change of variables which transforms a Boolean function into its absolute simplest form is described in the next section.

## EXERCISES

(a) What is the least number of + and - operations required in the Boolean representation of a designation number for 30 elementary elements which has 24 units? (Ans. 30-3-1 = 26.) For 20 elementary elements and 16 units? (Ans. $20-4-1=15$.)
(b) Find the absolute simplest forms for $n=5$ and $u=0,1,2, \ldots, 32$.
(c) Find a single transformation that will take $A \cdot \bar{B}+\bar{A} \cdot C$ and $A \cdot B+$ $\bar{B} \cdot(\bar{A}+\bar{C})$ into absolute simplest form.

Hint: Solve the simultaneous equations

$$
\begin{aligned}
A \cdot \bar{B}+\bar{A} \cdot C & =C^{\prime} \\
A \cdot B+\bar{B} \cdot(\bar{A}+\bar{C}) & =A^{\prime} \cdot B^{\prime}+C^{\prime}
\end{aligned}
$$

for the "unknowns" $A, B$, and $C$ in terms of $A^{\prime}, B^{\prime}$, and $C^{\prime}$. One solution is $A=C^{\prime}$, $B=A^{\prime}+B^{\prime}+\bar{C}, C=C^{\prime}$. Show that a "change of variables" to the absolute simplest form does not exist in this case. That is, from the result array show that independent solutions do not exist.

## 12-9. Transformation to the Absolute Simplest Form

The Theory. Suppose that we had a combined element $X(A, B, C, \ldots)$ and we wished to know what change of variables $A=A\left(A^{\prime}, B^{\prime}, C^{\prime}, \ldots\right)$, $B=B\left(A^{\prime}, B^{\prime}, C^{\prime}, \ldots.\right), C=C\left(A^{\prime}, B^{\prime}, C^{\prime}, . ..\right)$, . . would transform $X(A, B, C, \ldots)$ into $Y\left(A^{\prime}, B^{\prime}, C^{\prime}, \ldots\right)$, that is,

$$
X(A, B, C, \ldots)=Y\left(A^{\prime}, B^{\prime}, C^{\prime}, \ldots\right)
$$

If a transformation R could be found such that

$$
\mathrm{R}[X(A, B, C, \ldots)]=Y(A, B, C, \ldots)
$$

with the additional properties that
and

$$
\begin{gathered}
\mathrm{R}[X+Y]=\mathrm{R}[X]+\mathrm{R}[Y] \quad \mathrm{R}[X \cdot Y]=\mathrm{R}[X] \cdot \mathrm{R}[Y] \\
\mathrm{R}[\bar{X}]=\frac{\mathrm{R}[X]}{\mathrm{R}[X]}
\end{gathered}
$$

then our problem would be solved. For then
or $\quad A^{\prime}=\mathrm{R}^{-1}[A] \quad B^{\prime}=\mathrm{R}^{-1}[B] \quad C^{\prime}=\mathrm{R}^{-1}[C] \quad$ etc.
whence $A=\mathrm{R}\left[A^{\prime}\right], B=\mathrm{R}\left[B^{\prime}\right], C=\mathrm{R}\left[C^{\prime}\right]$, etc.

Use of Permutation Matrices. The work is of course done with the designation numbers; R turns out to be a Boolean matrix such that \# $Y$ is $\# X$ multiplied by R. For example, suppose that it is desired to find the change of variables that will make $\bar{A}=A^{\prime} \cdot \bar{B}^{\prime}+\bar{A}^{\prime} \cdot B^{\prime}$, that is, $X=\bar{A}$ and $Y=A^{\prime} \cdot \bar{B}^{\prime}+\bar{A}^{\prime} \cdot B^{\prime} . \quad$ Since $\# X=1010$ and $\# Y=0110$, we may take

$$
\left.\mathbf{R}=\left(\begin{array}{c}
0100 \\
0001 \\
0010 \\
1000
\end{array}\right), \begin{array}{c}
0123 \\
\text { since }(1010)
\end{array}\right) \otimes\left(\begin{array}{c}
0100 \\
0001 \\
0010 \\
1000
\end{array}\right)=\left(\begin{array}{c}
0123 \\
(0110)
\end{array}\right.
$$

(See Sec. 11-11 for a description of Boolean matrix multiplication. Note that since 1010 is a row, we must multiply by a matrix on the right, as indicated, in order to obtain another row.) Such a matrix is called a permutation matrix, since it has the effect simply of permuting the positions of the designation number it multiplies. Here the unit in position 0 is carried into position 1, the zero in position 1 is carried into position 3, the unit in position 2 is carried into position 2 , and the zero in position 3 is carried into position 0 .

This is in fact the manner in which the matrix $R$ is derived for a problem. Decide for each position of $\# X$ into what position its bit should be carried so that the result will look like $\# Y$. Then, if position $k$ is to be carried into position $h$, the matrix element $R_{k h}=1$, otherwise zero. Note that in the above example we could as well have had position 0 carried into position 2, position 1 into position 0 , position 2 into position 1 , and position 3 into position 3 . In this case $R_{02}=1, R_{10}=1, R_{21}=1$, and $R_{33}=1$, whence

$$
\mathbf{R}=\left(\begin{array}{l}
0010 \\
1000 \\
0100 \\
0001
\end{array}\right)
$$

Checking,

$$
(1010) \otimes\left(\begin{array}{l}
0010 \\
1000 \\
0100 \\
0001
\end{array}\right)=(0110)
$$

Now that we have found $R$, we can determine the change of variables as follows:

$$
\# A=\mathbf{R}\left[\# A^{\prime}\right]=(0101) \otimes\left(\begin{array}{l}
0010 \\
1000 \\
0100 \\
0001
\end{array}\right)=(1001)
$$

whence, with respect to $b\left[A^{\prime}, B^{\prime}\right], 1001=\#\left(A^{\prime} \cdot B^{\prime}+\bar{A}^{\prime} \cdot \bar{B}^{\prime}\right)$. Also,

$$
\# B=\mathrm{R}\left[\# B^{\prime}\right]=(0011) \otimes\left(\begin{array}{l}
0010 \\
1000 \\
0100 \\
0001
\end{array}\right)=(0101)=\# A^{\prime}
$$

Hence $A=A^{\prime} \cdot B^{\prime}+\bar{A}^{\prime} \cdot \bar{B}^{\prime}$ and $B=A^{\prime}$ is the desired change of variables. To check this, note that

$$
\bar{A}=\left(\overline{A^{\prime} \cdot B^{\prime}+\overline{A^{\prime}} \cdot \bar{B}^{\prime}}\right)=A^{\prime} \cdot \bar{B}^{\prime}+\overline{A^{\prime}} \cdot B^{\prime}
$$

as desired.
The inverse change of variables, that is, $A^{\prime}=A^{\prime}(A, B, C, \ldots)$, $B^{\prime}=B^{\prime}(A, B, C, \ldots),. C^{\prime}=C^{\prime}(A, B, C, \ldots), \ldots$ can be found from $A^{\prime}=\mathrm{R}^{-1}[A], B^{\prime}=\mathrm{R}^{-1}[B], C^{\prime}=\mathrm{R}^{-1}[C], \ldots$ Given the Boolean permutation matrix, the matrix $\mathrm{R}^{-1}$ is found by interchanging the rows and columns of R ; for example, if

$$
\mathbf{R}=\left(\begin{array}{l}
0010 \\
1000 \\
0100 \\
0001
\end{array}\right)
$$

then $\quad \mathbf{R}^{-1}=\left(\begin{array}{c}0100 \\ 0010 \\ 1000 \\ 0001\end{array}\right) \quad$ and $\quad \mathbf{R} \otimes \mathbf{R}^{-1}=\left(\begin{array}{c}1000 \\ 0100 \\ 0010 \\ 0001\end{array}\right)$
In our example, then,

$$
\begin{aligned}
& \# A^{\prime}=(0101) \otimes\left(\begin{array}{l}
0100 \\
0010 \\
1000 \\
0001
\end{array}\right)=(0011)=\# B \\
& \# B^{\prime}=(0011) \otimes\left(\begin{array}{l}
0100 \\
0010 \\
1000 \\
0001
\end{array}\right)=(1001)=\#(A \cdot B+\bar{A} \cdot \bar{B})
\end{aligned}
$$

To check that this is truly the inverse change of variables, note that

$$
\begin{aligned}
& A^{\prime} \cdot \bar{B}^{\prime}+\bar{A}^{\prime} \cdot B^{\prime}=B \cdot(\overline{A \cdot B+\bar{A} \cdot \bar{B}})+\bar{B} \cdot(A \cdot B+\bar{A} \cdot \bar{B}) \\
& \quad=B \cdot(A \cdot \bar{B}+\bar{A} \cdot B)+\bar{A} \cdot \bar{B}=\bar{A} \cdot B+\bar{A} \cdot \bar{B}=\bar{A}(B+\bar{B})=\bar{A}
\end{aligned}
$$

as desired.
Simultaneous Change of Variables. If we want a change of variables such that, in addition to $X(A, B, \ldots$. $)=Y\left(A^{\prime}, B^{\prime}\right.$, . . $)$, we also have $U(A, B, \ldots)=V\left(A^{\prime}, B^{\prime}, \ldots\right)$ and $W(A, B, \ldots)=T\left(A^{\prime}, B^{\prime}, \ldots\right)$, ..., then we write the designation numbers under each other,

$$
\begin{array}{ll}
\# X(A, B, \ldots) & \# Y\left(A^{\prime}, B^{\prime}, \ldots\right. \\
\# U(A, B, \ldots) & \# V\left(A^{\prime}, B^{\prime}, \ldots .\right) \\
\# W(A, B, . . .) & \# T\left(A^{\prime}, B^{\prime}, . . .\right)
\end{array}
$$

The transformation now must be designed to permute the columns of the right-hand array so that it will look like the left-hand array. For example, suppose that we desired to have a change of variables so that

$$
\begin{array}{rl}
\bar{A}+\bar{B}=A^{\prime}+B^{\prime} \text { and } \bar{A}=A^{\prime} \cdot \bar{B}^{\prime}+\bar{A}^{\prime} \cdot B^{\prime} \text {. Form } \\
0123 & 0123 \\
\#(\bar{A}+\bar{B})=1110 & 0111=\#\left(A^{\prime}+B^{\prime}\right) \\
\# \bar{A}=1010 & 0110=\#\left(A^{\prime} \cdot \bar{B}^{\prime}+\bar{A}^{\prime} \cdot B^{\prime}\right)
\end{array}
$$

The method for forming the permutation transformation matrix R is similar to the above. Decide for each column in the left-hand array into what column it should be carried so that the final array will look like the right-hand array. Then, if column $k$ is to be carried into column $h$, the element $R_{k h}=1$; otherwise it is zero. For example, we can have column 0 carried into column 2, column 1 into column 3, column 2 into column 1, and column 3 into column 0 . Then we would have $R_{02}=1$, $R_{13}=1, R_{21}=1$, and $R_{30}=1$ :

$$
R=\left(\begin{array}{l}
0010 \\
0001 \\
0100 \\
1000
\end{array}\right)
$$

Checking,

$$
\binom{1110}{1010} \otimes\left(\begin{array}{l}
0010 \\
0001 \\
0100 \\
1000
\end{array}\right)=\binom{0111}{0110}
$$

Hence the change of variables becomes

$$
\begin{aligned}
& \# A=\mathbf{R}\left[\# A^{\prime}\right]=(0101) \otimes\left(\begin{array}{l}
0010 \\
0001 \\
0000 \\
1000
\end{array}\right)=(1001)=\#\left(A^{\prime} \cdot B^{\prime}+\bar{A}^{\prime} \cdot \bar{B}^{\prime}\right) \\
& \# B=\mathbf{R}\left[\# B^{\prime}\right]=(0011) \otimes\left(\begin{array}{l}
0010 \\
0001 \\
0100 \\
1000
\end{array}\right)=(1100)=\#\left(\overline{B^{\prime}}\right)
\end{aligned}
$$

To check this, note that

$$
\begin{aligned}
\bar{A}+\bar{B} & =\left(\overline{A^{\prime} \cdot B^{\prime}+\bar{A}^{\prime} \cdot \bar{B}^{\prime}}\right)+\left(\overline{\bar{B}^{\prime}}\right)=A^{\prime} \cdot \bar{B}^{\prime}+\overline{A^{\prime}} \cdot B^{\prime}+B^{\prime} \\
& =A^{\prime} \cdot \bar{B}^{\prime}+B^{\prime}=A^{\prime}+B^{\prime} \\
\bar{A} & =\left(\overline{A^{\prime} \cdot B I+\bar{A}^{\prime} \cdot \bar{B}^{\prime}}\right)=A^{\prime} \cdot \bar{B}^{\prime}+\bar{A}^{\prime} \cdot B^{\prime}
\end{aligned}
$$

and
The inverse change of variables is found by considering $\mathrm{R}^{-1}=\left(\begin{array}{l}0001 \\ 0010 \\ 1000 \\ 0100\end{array}\right)$ :

$$
\begin{aligned}
& \# A^{\prime}=\mathrm{R}^{-1}[\# A]=(0101) \otimes\left(\begin{array}{l}
0001 \\
0010 \\
1000 \\
0100
\end{array}\right)=(0110)=\#(A \cdot \bar{B}+\bar{A} \cdot B) \\
& \# B^{\prime}=\mathrm{R}^{-1}[\# B]=(0011) \otimes\left(\begin{array}{l}
0001 \\
0010 \\
1000 \\
0100
\end{array}\right)=(1100)=\#(\bar{B})
\end{aligned}
$$

Change to Absolute Simplest Form. With the above computational procedures we are now able to generate transformations to the absolute simplest form. For example, consider $A \cdot(\bar{C}+B)+\bar{C} \cdot B+\bar{A} \cdot \bar{B} \cdot C$ with the designation number 0111 1001, where $n=3, u=5$. The absolute simplest form is $A^{\prime} \cdot B^{\prime}+C^{\prime}$, with designation number 00011111. Hence R could be

$$
\mathbf{R}=\left(\begin{array}{ll}
0100 & 0000 \\
0001 & 0000 \\
0000 & 0001 \\
0000 & 1000 \\
0000 & 0010 \\
0010 & 0000 \\
1000 & 0000 \\
0000 & 0100
\end{array}\right)
$$

whence the change of variables

$$
\begin{aligned}
& A=B^{\prime} \cdot \bar{C}^{\prime}+\bar{B}^{\prime} \cdot C^{\prime} \\
& B=\bar{A}^{\prime} \cdot \bar{B}^{\prime}+A^{\prime} \cdot C^{\prime} \\
& C=\bar{A}^{\prime} \cdot\left(B^{\prime}+\bar{C}^{\prime}\right)+A^{\prime} \cdot \bar{B}^{\prime} \cdot C^{\prime}
\end{aligned}
$$

will reduce the given element to its absolute simplest form. However, suppose that we also desire to have $A=A^{\prime}$ and $B=B^{\prime}$, as well as $A \cdot(\bar{C}+B)+\bar{C} \cdot \bar{B}+\bar{A} \cdot \bar{B} \cdot C=A^{\prime} \cdot B^{\prime}+C^{\prime}$. Under these conditions the transformation R becomes

$$
\mathbf{R}=\left(\begin{array}{ll}
1000 & 0000 \\
0000 & 0100 \\
0000 & 0010 \\
0001 & 0000 \\
0000 & 1000 \\
0100 & 0000 \\
0010 & 0000 \\
0000 & 0001
\end{array}\right)
$$

which gives as the required change of variables

$$
\begin{aligned}
& A=A^{\prime} \\
& B=B^{\prime} \\
& C=A^{\prime} \cdot\left(\bar{B}^{\prime} \cdot \bar{C}^{\prime}+B^{\prime} \cdot C^{\prime}\right)+\overline{A^{\prime}} \cdot\left(\bar{B}^{\prime} \cdot C^{\prime}+B^{\prime} \cdot \bar{C}^{\prime}\right)
\end{aligned}
$$

## EXERCISES

Find the inverse change of variables of:
(a) $A=B^{\prime} \cdot \bar{C}^{\prime}+\bar{B}^{\prime} \cdot C^{\prime}, B=\overline{A^{\prime}} \cdot \bar{B}^{\prime}+A^{\prime} \cdot C^{\prime}, C=\overline{A^{\prime}} \cdot\left(B^{\prime}+\overline{C^{\prime}}\right)+A^{\prime} \cdot \bar{B}^{\prime} \cdot C^{\prime}$.
(b) $A=A^{\prime}, B=B^{\prime}, C=A^{\prime} \cdot\left(\bar{B}^{\prime} \cdot \bar{C}^{\prime}+B^{\prime} \cdot C^{\prime}\right)+\overline{A^{\prime}} \cdot\left(\bar{B}^{\prime} \cdot C^{\prime}+B^{\prime} \cdot \bar{C}^{\prime}\right)$.

## 12-10. The Absolute Simplest Form in Circuit Design

As an example, suppose that it is desired to construct a circuit with the following four outputs:

$$
\begin{aligned}
& E_{1}=\bar{A}_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}+\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot A_{3} \\
& E_{2}=\left(A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right) \cdot \bar{A}_{3}+\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot A_{3} \\
& E_{3}=\vec{A}_{1}+A_{2} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3} \\
& E_{4}=\bar{A}_{1} \cdot \bar{A}_{2}+A_{3}:\left(\bar{A}_{1}+\bar{A}_{2}\right)+A_{1} \cdot A_{2} \cdot \bar{A}_{3}
\end{aligned}
$$

Here $n=3$, and for $E_{1}, u=3$; for $E_{2}, u=4$; for $E_{3}, u=6$; for $E_{4}$, $u=5$. We have for the respective absolute simplest forms

$$
\begin{array}{ll}
E_{1}=A_{3}^{\prime} \cdot\left(A_{2}^{\prime}+A_{1}^{\prime}\right) & E_{3}=A_{3}^{\prime}+A_{2}^{\prime} \\
E_{2}=A_{3}^{\prime} & E_{4}=A_{3}^{\prime}+A_{2}^{\prime} \cdot A_{1}^{\prime}
\end{array}
$$

The problem is to design the change of variable circuits whose outputs are $A_{1}^{\prime}, A_{2}^{\prime}$, and $A_{3}^{\prime}$ (that is, the inverse change of variables is explicitly needed: $A_{1}^{\prime}=\mathrm{R}^{-1}\left[A_{1}\right], A_{2}^{\prime}=\mathrm{R}^{-1}\left[A_{2}\right]$, and $A_{3}^{\prime}=\mathrm{R}^{-1}\left[A_{3}\right]$. One valid


Fig. 12-15. Change of variables and resulting absolute-simplest-form circuitry for a multiple-output circuit.
solution is
$\begin{array}{rl}\# A_{1}^{\prime}=1100 & 1100=\# \bar{A}_{2} \\ \# A_{2}^{\prime}=1010 & 1010=\# \bar{A}_{1} \\ \# A_{3}^{\prime}=1001 & 0110=\#\left(A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right) \cdot \\ & \bar{A}_{3} \\ & +\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot A_{3}\end{array}$
Here 9 operations are required to make $A_{1}^{\prime}, A_{2}^{\prime}$, and $A_{3}^{\prime}$ and 5 more to make $E_{1}, E_{2}, E_{3}$, and $E_{4}$, or a total of 14 altogether, as compared with the 25 operations required to make the $E_{i}$ directly from the $A_{i}$ (see Fig. 12-15).

## EXERCISES

(a) Supply the details for the above example.
(b) Suppose that it is desired to make a circuit with the following four output functions:

$$
\begin{aligned}
& E_{1}=\bar{A}_{1} \cdot \bar{A}_{3}+\left(A_{1}+\bar{A}_{2}\right) \cdot A_{3} \\
& E_{2}=\left(\bar{A}_{1}+\bar{A}_{2}\right) \cdot \bar{A}_{3}+\left(\bar{A}_{1}+A_{2}\right) \cdot A_{3} \\
& E_{3}=\bar{A}_{1} \cdot A_{2} \cdot \bar{A}_{3}+\left(A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right) \cdot A_{3} \\
& E_{4}=\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot \bar{A}_{3}+\left(A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right) \cdot A_{3}
\end{aligned}
$$

The problem is to design change-of-variable circuits that will simplify the generation of $E_{1}, E_{2}, E_{3}$, and $E_{4}$.

One solution is to choose $A_{1}^{\prime} \cdot A_{3}^{\prime}+A_{2}^{\prime}, A_{1}^{\prime}+A_{3}^{\prime},\left(A_{2}^{\prime}+A_{3}^{\prime}\right) \cdot A_{1}^{\prime}$, and $A_{1}^{\prime}$, respectively, as the absolute simplest forms of $E_{1}, E_{2}, E_{3}$, and $E_{4}$. Then we find

$$
\begin{aligned}
& A_{1}^{\prime}=\left(\bar{A}_{1} \cdot \bar{A}_{2}+A_{1} \cdot A_{2}\right) \cdot \bar{A}_{3}+\left(\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{2}\right) \cdot A_{3} \\
& A_{2}^{\prime}=\bar{A}_{1} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3} \\
& A_{3}^{\prime}=\bar{A}_{1} \cdot \bar{A}_{2}+A_{2} \cdot A_{3}
\end{aligned}
$$

Can you find a simpler change of variables?

## 12-11. Additional Topics

a. Solution of Equations by Matrices. In Table 12-2 we tested the pair $\left(x^{4}, y^{4}\right)=$ $(0,1)$ by multiplying column 4 of the coefficient table by the third column of the unknown table, summing both above and below the line, and comparing only the sums. Note that this is equivalent to matrix multiplication, if one column were transposed to be a row. Similarly it is easily seen that, if the table of coefficients above (or below) the line, considered as a matrix, is multiplied on the left by the transpose of the matrix of the table of its unknowns, then the product gives, in row $i$, column $j$, the result of multiplying unknown column $i$ by coefficient column $j$. Comparison of the products formed for the tables above and below the line (i.e., for the left- and right-hand sides of the equation) shows the allowable solutions for each column of the basis for $A, B, C$ (reading the $x, y$ pairs downward). A solution is allowable in an equivalence if in its corresponding position the two matrices have the same character, either both units or both zeros. A solution is allowable in an implication unless there is a unit in the corresponding position of the implier matrix (the tail of the arrow) and a zero in that position of the implicand matrix (the head of the arrow). For a set of equivalences and implications we can form a result matrix for each, with a unit in each position corresponding to an allowable solution, a zero otherwise; then those solutions which are allowable for all the equivalences and implications will have a unit in the corresponding position in every result matrix.

For example, consider the three simultaneous statements of Sec. 12-6,

$$
\begin{align*}
A+B \cdot X \cdot \bar{Y}+C \cdot Y & =\bar{A} \cdot \bar{X} \cdot \bar{Y}+\bar{B} \cdot \bar{X}+(C+A \cdot B) \\
B \cdot X \cdot Y+C \cdot(A+B) \cdot Y & =\bar{B} \cdot \bar{X} \cdot \bar{Y}  \tag{12-2}\\
A \cdot C \cdot(X+Y)+A \cdot B \cdot(X+\bar{Y}) & \rightarrow X \cdot Y+A \cdot C
\end{align*}
$$

Comparing with Table 12-4, we see that the matrices for Eq. (12-1) would be

$$
\begin{array}{ll}
\left(\begin{array}{l}
100 \\
110 \\
101 \\
101
\end{array}\right) \otimes\left(\begin{array}{ll}
0101 & 0101 \\
0011 & 0011 \\
0000 & 1111
\end{array}\right)=\left(\begin{array}{ll}
0101 & 0101 \\
0111 & 0111 \\
0101 & 111 \\
0101 & 1111
\end{array}\right) \quad \text { above the line } \\
\left(\begin{array}{l}
111 \\
001 \\
011 \\
001
\end{array}\right) \otimes\left(\begin{array}{ll}
1010 & 1010 \\
1100 & 1100 \\
0001 & 1111
\end{array}\right)=\left(\begin{array}{ll}
1111 & 1111 \\
0001 & 1111 \\
1101 & 1111 \\
0001 & 1111
\end{array}\right) \quad \text { below the line }
\end{array}
$$

Comparing these matrices for equality, we obtain the result matrix of allowable solutions:

$$
\left(\begin{array}{ll}
0101 & 0101 \\
1001 & 0111 \\
0111 & 1111 \\
1011 & 1111
\end{array}\right)
$$

[Recalling that the first row (row 0) corresponds to the column for $\left(x^{i}, y^{i}\right)=(0,0)$, row 1 to $\left(x^{i}, y^{i}\right)=(1,0)$, row 2 to $\left(x^{i}, y^{i}\right)=(0,1)$, and row 3 to $\left(x^{i}, y^{i}\right)=(1,1)$, we see that this solution matrix corresponds exactly to the result array of Table 12-1.] Similarly Eq. (12-2) gives the matrices
and

$$
\begin{gathered}
\left(\begin{array}{l}
00 \\
00 \\
01 \\
11
\end{array}\right) \otimes\left(\begin{array}{ll}
0011 & 0011 \\
0000 & 0111
\end{array}\right)=\left(\begin{array}{ll}
0000 & 0000 \\
0000 & 0000 \\
0000 & 0111 \\
0011 & 0111
\end{array}\right) \\
\left(\begin{array}{l}
1 \\
0 \\
0 \\
0
\end{array}\right) \otimes\left(\begin{array}{ll}
1100 & 1100
\end{array}\right)=\left(\begin{array}{ll}
1100 & 1100 \\
0000 & 0000 \\
0000 & 0000 \\
0000 & 0000
\end{array}\right) \\
\left(\begin{array}{ll}
0011 & 0011 \\
1111 & 1111 \\
1111 & 1000 \\
1100 & 1000
\end{array}\right)
\end{gathered}
$$

The result matrix is

Implication (12-3) gives the matrices
and

$$
\begin{aligned}
& \left(\begin{array}{l}
01 \\
11 \\
10 \\
11
\end{array}\right) \otimes\left(\begin{array}{ll}
0000 & 0101 \\
0001 & 0001
\end{array}\right)=\left(\begin{array}{ll}
0001 & 0001 \\
0001 & 0101 \\
0000 & 0101 \\
0001 & 0101
\end{array}\right) \\
& \left(\begin{array}{l}
01 \\
01 \\
01 \\
11
\end{array}\right) \otimes\left(\begin{array}{cc}
1111 & 1111 \\
0000 & 0101
\end{array}\right)=\left(\begin{array}{ll}
0000 & 0101 \\
0000 & 0101 \\
0000 & 0101 \\
1111 & 1111
\end{array}\right)
\end{aligned}
$$

The result matrix has zeros only where the upper product has a unit and the lower a zero:

$$
\left(\begin{array}{ll}
1110 & 1111 \\
1110 & 1111 \\
1111 & 1111 \\
1111 & 1111
\end{array}\right)
$$

Examining the three matrices for common units, we have the following compoundsolution matrix, which corresponds exactly to the result array of Table 12-4:

$$
\left(\begin{array}{ll}
0000 & 0001 \\
1000 & 0111 \\
0111 & 1000 \\
1100 & 1000
\end{array}\right)
$$

[More systematically the result matrices can beformed as in the equations \# ( $\mathrm{A}=\mathrm{B}$ ) $=\#(\mathbf{A} \cdot \mathbf{B}+\overline{\mathbf{A}} \cdot \overline{\mathbf{B}})$ and $\#(\mathbf{A} \rightarrow \mathbf{B})=\#(\overline{\mathbf{A}}+\mathbf{B})$, substituting the matrices for the letters on the right and performing the multiplication bit by bit, not row by column as in regular matrix multiplication. The compound solution is then the bit-by-bit product of the result matrices for each statement. The method presented here can of course be extended to any number of statements in any number of knowns and unknowns. If any column of the compound-solution matrix has all zeros and no units, then there is no solution to the problem, unless there

(a)

Fig. 12-16. Flip-flop representation and example of a circuit. exist some constraints on the knowns $A, B, C, \ldots$ which remove that column from their basis.]
b. Flip-Flop Problems. The use of flipflops for storage in recursive circuits frequently generates problems that involve the solution of equations. For example, consider a flip-flop with two states $Q$ and $\bar{Q}$ such that if it is in state $Q$ then an inputpulse signal $T$ will change its state to $\bar{Q}$ and if it is in state $\bar{Q}$ then an input-pulse signal $T$ will change its state to $Q$; otherwise the flip-flop will stay in its present state. If $Q^{\prime}$ is the final state, then (see Fig. 12-16a)

$$
Q^{\prime}=T \cdot \bar{Q}+\bar{T} \cdot Q
$$

(Can you develop this equation for $Q^{\prime}$ ?)
Now suppose that it is desired to make a recursive circuit with inputs $A, B$, and $C$, and with output $C^{\prime}$ connected to the input $C$, such that $C^{\prime}=A \cdot B+(A+B) \cdot C$. If we are to use the above flip-flop, the problem is to design the input pulse $T$ so that the output $Q^{\prime}$ is the desired $C^{\prime}$, that is, such that $Q^{\prime}=C^{\prime}=A \cdot B+(A+B) \cdot C$. Thus we desire to solve the equation

$$
A \cdot B+(A+B) \cdot C=T \cdot \bar{C}+\bar{T} \cdot C
$$

for the unknown $T$, where we have substituted $C$ for $Q$ (why?). The solution turns out to be $T=A \cdot B \cdot \bar{C}+\bar{A} \cdot \bar{B} \cdot C$ (see Fig. 12-16b).

Consider next a flip-flop with two inputs $R$ and $S$ such that an input pulse on $S$ will change the state of the flip-flop to $Q$, while an input pulse on $R$ will return the state to $\bar{Q}$. Both $R$ and $S$ cannot be pulsed at the same time (see Fig. 12-17a). The equa-
tions for this flip-flop are

$$
Q^{\prime}=S+\bar{R} \cdot Q \quad \text { and } \quad R \cdot S=0
$$

Suppose that we desired to make a circuit using two flip-flops, to have inputs $A, B$, and $C$ and two outputs (one from each flip-flop):
$C^{\prime}=A \cdot B+(A+B) \cdot C \quad$ and $\quad D^{\prime}=(A \cdot \bar{B}+\vec{A} \cdot B) \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C$
This set of equations must be solved:

$$
\begin{aligned}
A \cdot B+(A+B) \cdot C & =S_{C}+\bar{R}_{C} \cdot C & R_{C} \cdot S_{C}=0 \\
(\bar{A} \cdot B+A \cdot \bar{B}) \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C & =S_{D}+\bar{R}_{D} \cdot D & R_{D} \cdot S_{D}=0
\end{aligned}
$$

The solutions (see Fig. 12-17b) are

$$
\begin{array}{ll}
R_{C}=\bar{A} \cdot \bar{B} & R_{D}=(\bar{A} \cdot B+A \cdot \bar{B}) \cdot C+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot \bar{C} \\
S_{c}=A \cdot B & S_{D}=(\bar{A} \cdot B+A \cdot \bar{B}) \cdot \bar{C}+(A \cdot B+\bar{A} \cdot \bar{B}) \cdot C
\end{array}
$$

Many other kinds of flip-flops can be conceived. For example, suppose that in the $R-S$ flip-flop we let both $R$ and $S$ be pulsed at the same time and that this causes the


Fig. 12-17. Flip-flop representation and example of a circuit.
flip-flop to change state. Then the equation of the flip-flop would be

$$
Q^{\prime}=S \cdot \bar{Q}+\bar{R} \cdot Q
$$

c. Absolute Simplest Form and Symmetries of Boolean Functions. As far as circuit design is concerned, the labels assigned to the input variables are immaterial, and whether the input element is called $A_{i}$ or $\bar{A}_{i}$ is also immaterial. Thus only the Boolean functional form of the output of a circuit is important; all functions of the same form that differ by permutations or inversions of the variable labels represent the same circuit, so long as the substitutions are made consistently. For $n$ variables, $m$ of which must explicitly appear in the functional form, the number of circuits equivalent in the above sense becomes
which can be a very large number. The converse problem immediately suggests itself: How many nonequivalent (in the above sense) functional forms of $n$ variables are there? This problem was considered by D. Slepian in his On the Numbers of Symmetry Types of Boolean Functions of $n$ Variables, Can. J. Math., vol. 5, pp. 185-193, 1953, where it was shown that the results of J. A. Todd, The Groups of Symmetries of the Regular Polytopes, Proc. Cambridge Phil. Soc., vol. 27, pp. 212-231, 1931, could be applied.

We have observed such symmetries associated with the absolute simplest form above for $n$ variables and $u$ units in the designation number. This suggests the following extension of the above problem, also considered by Slepian: For $n$ variables and $u$ units how many different (in the above sense) functional forms are there? The absolute simplest form is evidently only one type of functional form.
d. Three-valued Logic. Until now we have considered circuits where only two signal levels can be distinguished, namely, 0 and 1 . Suppose that three values of signal levels can be distinguished, say 0,1 , and 2 . This leads to the consideration of three-valued logics. Since each input to a circuit can have three values, for a threeinput circuit there are $3 \times 3 \times 3$ possible input conditions, namely,

| $\# A_{1}=012$ | 012 | 012 | 012 | 012 | 012 | 012 | 012 | 012 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\# A_{2}=000$ | 111 | 222 | 000 | 111 | 222 | 000 | 111 | 222 |
| $\# A_{3}=000$ | 000 | 000 | 111 | 111 | 111 | 222 | 222 | 222 |

This array forms a basis in a three-valued logic. For $n$ variables there are $3^{n}$ columns in a basis. Our computational techniques in terms of designation numbers can then be directly extended as soon as we define the logical operations.

We wish to define a set of operations that will give us a complete Boolean algebra. A complete Boolean algebra is one in which all the $3^{\left(3^{n}\right)}$ possible designation numbers (i.e., Boolean functions) can be generated from the basis by means of the defined operations. There are many such sets of operations (just as there were many possible types of operations for the two-valued logic). We wish to choose a "simple" set that has "nice" algebraic properties. Analogous to our simple set + , $\cdot$, and - of twovalued logic we define a set of three-valued operations as follows:

$$
\begin{array}{llllll}
2+0=2 & 2+1=2 & 2+2=2 & 1+0=1 & 1+1=1 & 0+0=0 \\
2 \cdot 0=0 & 2 \cdot 1=1 \\
& 2 \cdot 2=2 & 1 \cdot 0=0 & 1 \cdot 1=1 & 0 \cdot 0=0 \\
\overline{0}=1 & \overline{1}=2 & \text { and } & \overline{2}=0
\end{array}
$$

To show that this set results in a complete Boolean algebra, we need merely show that designation numbers can be generated that are all 0 except for a single 1 in any position or with a single 2 in any position. To see this, we observe that for one variable $\# A=012, \# \bar{A}=120$, and $\bar{A}=201$, whence

$$
\left.\begin{array}{ll}
\# \bar{A} \cdot \bar{A}=100 & \#(\overline{A+\bar{A}})=200 \\
\# A \cdot \bar{A}=010 & \#(\overline{A+\bar{A}})=020 \\
\# A \cdot \bar{A}=001 & \#(\bar{A}+\bar{A}
\end{array}\right)=002
$$

With these relations in mind can you generate the designation numbers required above for three variables? [Hint: To generate, for instance, 000000200000 000000000000000 , we simply form $\#\left(\overline{A_{1}+\bar{A}_{1}}\right) \cdot \#\left(\overline{\bar{A}_{2}+\bar{A}_{2}}\right) \cdot \#\left(\overline{A_{3}+\bar{A}_{3}}\right)$.]

What algebraic properties does this Boolean algebra have? Can you define other sets of three-valued-logic operations that will result in a complete Boolean algebra? What algebraic properties do these algebras have?

Circuit design in three-valued logic is analogous to that in two-valued logic. For
example, let us design a three-valued serial adder (see Chap. 15) where the numbers are ternary, i.e., to the radix 3 . We have the following function table:

|  | $\# A=012$ | 012 | 012 | 012 | 012 | 012 | 012 | 012 | 01 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\# B=000$ | 111 | 222 | 000 | 111 | 222 | 000 | 111 | 22 |
|  | $\# C=000$ | 000 | 000 | 111 | 111 | 111 | 222 | 222 | 222 |
| Result | $\# R=012$ | 120 | 201 | 120 | 201 | 012 | 201 | 012 | 120 |
| Carry | $\# C^{\prime}=000$ | 001 | 011 | 001 | 011 | 111 | 011 | 11 |  |

Using a mongrel-form technique, we then find

$$
\left.\begin{array}{rl}
R= & {[A \cdot(\overline{B+\bar{B}})+\bar{A} \cdot(\overline{B+\bar{B}})+\bar{A} \cdot(\bar{B}+\bar{B}}
\end{array}\right] \cdot(\overline{C+\bar{C}}),
$$

Evidently our adder function table depended upon the interpretation of the values of signal levels 0,1 , and 2 as the ternary digits 0,1 , and 2 , respectively. Other interpretations will result in other functions for $R$ and $C^{\prime}$. Can you design a three-valued serial adder for the other algebras that you generated above? (Note that $C^{\prime}=2$ only when $C=2$. This would never happen in the real case, so that the basis may be constrained by the removal of its last third. How would this affect the forms of $R$ and $C^{\prime}$ above?)

Can you extend the computational techniques given in this chapter to analogous methods for our three-valued logic?
e. Generalized Concept of the Searching Problem in Terms of Boolean Algebra. Referring back to Sec. 7-2, the searching problem can be easily couched in terms of Boolean algebra. This is accomplished by observing that an item is uniquely defined (at least as far as the search is concerned) by the pattern of characteristics that are and are not associated with it. With three characteristics $A_{1}, A_{2}$, and $A_{3}$ a total of eight items $X_{0}, X_{1}, X_{2}, X_{3}, X_{4}, X_{5}, X_{6}$, and $X_{7}$ can be distinguished,
$\begin{array}{llll}X_{0}=\bar{A}_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3} & X_{1}=A_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3} & X_{2}=\bar{A}_{1} \cdot A_{2} \cdot \bar{A}_{3} & X_{3}=A_{1} \cdot A_{2} \cdot \bar{A}_{3} \\ X_{4}=\bar{A}_{1} \cdot \bar{A}_{2} \cdot A_{3} & X_{5}=A_{1} \cdot \bar{A}_{2} \cdot A_{3} & X_{6}=\bar{A}_{1} \cdot A_{2} \cdot A_{3} & X_{7}=A_{1} \cdot A_{2} \cdot A_{3}\end{array}$
Here, for example, $X_{5}=A_{1} \cdot \bar{A}_{2} \cdot A_{3}$ means that item $X_{5}$ is associated with characteristic $A_{1}$ and $A_{3}$ but not with $A_{2}$. If the basic symbols are chosen to be the characteristics, then the columns of the basis can represent items distinguishable by these characteristics, where a unit in a row of a column indicates that the item of that column is associated with the characteristic of that row and a zero means that it is not. Thus

$$
\begin{aligned}
& \# A_{1}=\begin{array}{llllllll}
0 & 1 & 0 & 1 & 0 & 1 & 0 & 1
\end{array} \\
& \# A_{2}=0 \begin{array}{llllllll}
0 & 0 & 1 & 1 & 0 & 0 & 1 & 1
\end{array} \\
& \# A_{3}=0 \begin{array}{llllllll}
0 & 0 & 0 & 0 & 1 & 1 & 1 & 1
\end{array}
\end{aligned}
$$

The simple searching problem is then solved as follows: To find all items associated with $A_{1} \cdot A_{2}$, simply form

$$
\# A_{1} \cdot A_{2}=
$$

whence $X_{3}$ and $X_{7}$ are the desired items. Of course there is not always an item associated with every combination of characteristics; in such a case the columns for which there is no associated item are omitted from the basis, i.e., a constrained basis is used. Thus Table 7-1 can be considered as a constrained basis.

With this interpretation the searching problem can be generalized as follows: Suppose that it is desired to find all items associated with characteristic $A_{1}$ and at least one of the characteristics $A_{2}$ or $A_{3}$, that is, associated with $A_{1} \cdot\left(A_{2}+A_{3}\right)$. We simply form $\# A_{1} \cdot\left(A_{2}+A_{3}\right)=00010101$, whence the answer is $X_{3}, X_{5}$, and $X_{7}$. As another illustration, consider Table 7-1 (page 217), and find all articles associated with nuclear theory or nuclear plans or both. Observing that
we have

$$
\begin{array}{rlll}
\text { Nuclear } & =4.3=0000 & 1001 & 0011 \\
\text { Theory } & =4.4=0010 & 0001 & 0011 \\
\text { Plans } & =6.2=0100 & 1001 & 1110
\end{array}
$$

Hence articles 2.1, 2.4, 3.3, and 3.4 by Nicholls, Seidle, Stockendal, and Tove are the final desired results. Summarizing, when it is desired to find all items specified by a Boolean function of the characteristics, the designation number of the function is formed; the positions of the units indicate the desired items.

One of the primary reasons for the advantages of the Tabledex method can be understood in terms of our Boolean algebraic interpretation of searching. When the search proceeds within a table, the problem has already been significantly reduced since in general only a small fraction of all the items are associated with a particular characteristic. In addition the constrained basis to which a table corresponds includes only rows corresponding to characteristics of a greater order than that of the table, thereby further reducing the basis and hence the searching problem. For example, from Table $7-1$ it is seen that the column-constrained and row-reduced basis with respect to Table 5.1 of Fig. $7-3 c$ on page 220 is

|  |  |  |  | તH | ๗్ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 5.2 |  |  |  |  | 1 |  |
| 3 |  |  |  |  | 0 | 0 |
| 6.1 |  |  |  | 0 | 0 | 0 |
| 2 |  |  |  | 1 | 1 |  |
| . 1 |  |  | 1 | 0 | 1 |  |

f. Sentential Examples. In the Additional Topics of Chap. 10 we discussed the logical interpretation of English. We shall now present examples of applications of our computational methods to word or sentential problems. It is of historical interest to note that many such problems were presented in E. Schroder's "Algebra der Logik," Teubner Verlagsgesellschaft, Leipzig, 1890, but he did not have the advantages of our computational methods. (Our first two examples are taken from R.S. Ledley, Mathematical Foundations and Computational Methods for a Digital Logic Machine, J. Operations Research Soc. Am., vol. 2, no. 3, pp. 249-274, August, 1954.)
First Example: Consistency, Redundancy. Suppose that an intelligence agency receives the following messages from fairly, though not completely, reliable sources, concerning fighter and bomber airplanes of the Lower Slobbovian air force:

1. A plane with jet engines and a short range is a bomber.
2. Conventional engine bombers have heavy armor.
3. Conventional engine fighters have a short range.
4. Long-range conventional engine planes have light armor.
5. Jet planes have heavy armor.
6. Heavy armored planes with a short range are fighters.
7. Either long-range planes or fighter planes have light armor.
8. Either conventional engine planes or short-range planes have heavy armor.

The intelligence agency now makes an analysis of these statements and in this connection desires the answers to the following questions:
$a$. Are these statements all consistent?
$b$. If not, suppose that there is a high probability that only one of them was incorrect; can a single statement be omitted so that the remaining ones are consistent, and if so, which statements are they?
c. Are any of the statements related?
d. Are any of the statements redundant, i.e., not necessary?
e. With various assumptions as to which is an incorrect statement, what conclusions can be drawn?

Solution. First note that only fighter and bomber airplanes are discussed by hypothesis and that an engine must be either jet or conventional; the opposite of long-range is short-range, and the opposite of light armor is heavy armor; and in addition, only airplanes, engines, range, and armor are discussed in the statements. Thus the eight statements can all be expressed in terms of the following four elementary elements (where "It" refers to "the plane"):

| $A=$ It is a fighter plane | $B=$ It has jet engines |
| :--- | :--- |
| $\bar{A}=$ It is a bomber plane | $\bar{B}=$ It has conventional engines |
| $C=$ It has a long range | $D=$ It has light armor |
| $\bar{C}=$ It has a short range | $\bar{D}=$ It has heavy armor |

Thus the first statement is: It has jet engines and it has a short range implies that it is a bomber. In symbols this is $B \cdot \bar{C} \rightarrow \bar{A}$. Now in terms of + and $\cdot$ this means: $\overline{B \cdot \bar{C}}+\bar{A}$. In terms of the regular basis extended to four elementary elements find $\#(\overline{B \cdot \bar{C}}+\bar{A})=111011111110$ 1111. Similarly we have for the whole set of statements

| 1. $B \cdot \bar{C} \rightarrow \bar{A}:$ | $\overline{B \cdot \bar{C}}+\bar{A}:$ | 1110 | 1111 | 1110 | 1111 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 2. $\bar{A} \cdot \bar{B} \rightarrow \bar{D}:$ | $\overline{\bar{A} \cdot \bar{B}}+\bar{D}:$ | 1111 | 1111 | 0111 | 0111 |
| 3. $A \cdot \bar{B} \rightarrow \bar{C}:$ | $\overline{A \cdot \bar{B}}+\bar{C}:$ | 1111 | 1011 | 1111 | 1011 |
| 4. $\bar{B} \cdot C \rightarrow D:$ | $\bar{B} \cdot C+D:$ | 1111 | 0011 | 1111 | 1111 |
| 5. $B \rightarrow \bar{D}:$ | $\bar{B}+\bar{D}:$ | 1111 | 1111 | 1100 | 1100 |
| 6. $\bar{D} \cdot \bar{C} \rightarrow A:$ | $\bar{D} \cdot \bar{C}+A:$ | 0101 | 1111 | 1111 | 1111 |
| 7. $A+C \rightarrow D:$ | $\overline{A+C}+D:$ | 1010 | 0000 | 1111 | 1111 |
| 8. $\bar{B}+\bar{C} \rightarrow \bar{D}:$ | $\bar{B}+\bar{C}+\bar{D}:$ | 1111 | 1111 | 0000 | 0011 |

Now we are ready to answer the questions. First, note that the product of all the designation numbers is \#0-in other words, always false. This means that the statements are not consistent and there must be a contradiction. So the answer to ( $a$ ) is "no." For the answer to (b) observe that, if any or all of statements $1,2,3$, and 4 were omitted, the remaining statements would still be contradictory. However, if any of statements $5,6,7$, and 8 were omitted, no contradiction would result; i.e., the product of the remaining statements would have some units. The answer to (b) is thus "yes: $5,6,7$, or 8 ." As far as (c) is concerned, if statements 7 and 8 are true, then $1,2,3$, and 4 are all implied true. It is easily seen that statement 8 alone implies statement 2 , while statement 7 alone implies statement 4 . Thus, of statements $1,2,3,4,7$, and 8 , only statements 7 and 8 need be stated, since statements $1,2,3$,
and 4 are redundant; this answers (d). It would be most reasonable for one of the two nonrelated statements 5 and 6 to be taken as incorrect. Suppose that from other considerations it was decided that statement 6 is incorrect. Thus we are left with statements $1,2,3,4,5,7$, and 8 , of which statements $1,2,3$, and 4 are redundant; so we are left with statements 5,7 , and 8 . Since these are all true at the same time, the product of their designation numbers, namely, 1010000000000000 , contains the most information. This is $\bar{A} \cdot \bar{C} \cdot \bar{D}$. Thus there is a type of airplane with the following characteristics: It is a bomber and has short range and heavy armor, which is not a particularly obvious observation to deduce from statements 5,7 , and 8 . If it is assumed that statement 5 is incorrect, we are left with statements 6,7 , and 8 -the product of which turns out to be $B \cdot C \cdot D:$ a jet with long range and light armor. These last two conclusions are the most general statements that can be made under the circumstances presented in the problem, in the sense that they imply the most possible other statements. For example, if $\bar{A} \cdot \bar{C} \cdot \bar{D}$ is true, $A$ is implied false, showing that statements 5,7 , and 8 imply no fighter airplanes.
Second Example: Change of Variables. Suppose that the army sent a military observer to observe the military tactics of the Blefuscudians during their war with the Lilliputians. The observer was to notice especially the relation between the physical circumstances of the battlefield and the infantry tactics used. After watching many battles the observer sent back his final report with four general observations:

1. In hilly terrain on clear days, localized infantry attacks were used in conjunction with long-range artillery, but no tanks.
2. On flat plains, at night or in bad weather, the Blefuscudians used short-range artillery but did not use a generalized infantry assault on a broad front that was supported by armored tanks.
3. In hilly terrain at night, or in bad weather in the daytime, armored tanks were used with localized attacks, or long-range artillery with an assault on a broad front was used.
4. In bad weather on flat terrain or at night, or in good weather in hilly country, either a localized attack was used or long-range artillery and tanks together with an assault on a broad front were resorted to by the Blefuscudians.

The problem is: From this report made by the military observer, what can the army learn about the effects on the Blefuscudians' infantry tactics of (a) flat terrain, (b) night fighting, and (c) bad weather? Conversely, under what physical circumstances will ( $d$ ) an assault on a broad front be made, ( $e$ ) long-range artillery be used, and ( $f$ ) armored tanks be used? Suppose that the battle is to take place on the plains, on a clear day, what ( $g$ ) will be the Blefuscudians' tactics?

To solve this problem, we first observe that terrain is either flat or hilly but not both, day is the opposite of night, good weather the opposite of bad weather. Also an infantry attack either is localized or is an assault on a broad front, only battles with infantry attacks being observed. In addition long-range and short-range artillery are opposites; the use of armored tanks and no armored tanks are opposites. Thus we symbolize the elementary elements by
$A=$ (The terrain was) flat
$B=$ (It was) night
$C=$ (The weather was) bad
$\bar{A}=$ (The terrain was) hilly
$\bar{B}=$ (It was) day
$\bar{C}=$ (The weather was) good

In the primed set of elementary elements we leave the completion of the sentences understood,

$$
\begin{array}{lll}
A^{\prime}=\text { an assault on a broad front } & B^{\prime}=\text { long-range artillery } & \frac{C^{\prime}}{}=\text { armored tanks } \\
\overline{A^{\prime}}=\text { localized attack } & \overline{B^{\prime}}=\text { short-range artillery } & \overline{C^{\prime}}=\text { no tanks }
\end{array}
$$

The four observations can now be symbolized thus:

1. $\bar{A} \cdot \bar{B} \cdot \bar{C}=\overline{A^{\prime}} \cdot B^{\prime} \cdot \overline{C^{\prime}}$
2. $\left.A \cdot(B+C)=\overline{B^{\prime}} \cdot \overline{\left(A^{\prime} \cdot C^{\prime}\right.}\right)$
3. $\bar{A} \cdot B+\bar{B} \cdot C=\overline{A^{\prime}} \cdot C^{\prime}+A^{\prime} \cdot B^{\prime}$
4. $C \cdot(A+B)+\bar{A} \cdot \bar{C}=\overline{A^{\prime}}+A^{\prime} \cdot B^{\prime} \cdot C^{\prime}$

Evidently the primed elementary elements are independent, and so we have a change-of-variables problem, where to determine the answers to questions $a, b$, and $c$ we solve for $A, B$, and $C$ in terms of $A^{\prime}, B^{\prime}$, and $C^{\prime}$, and for $A^{\prime}, B^{\prime}$, and $C^{\prime}$ in terms of $A, B$, and $C$. The results are
a. $A=\overline{B^{\prime}}$
b. $B=B^{\prime} \cdot C^{\prime}+\overline{B^{\prime}} \cdot \overline{C^{\prime}}$
c. $C=A^{\prime} \cdot B^{\prime}+\overline{A^{\prime}} \cdot \overline{B^{\prime}}$
d. $A^{\prime}=A \cdot \bar{C}+\bar{A} \cdot C$
e. $B^{\prime}=\bar{A}$
f. $C^{\prime}=A \cdot \bar{B}+\bar{A} \cdot B$

However, there is another set of results, where (a), (b), (e), and (f) are the same but (c) and (d) become

$$
\text { c. } C=\overline{A^{\prime}} \cdot\left(\overline{B^{\prime}}+C^{\prime}\right)+A^{\prime} \cdot B^{\prime} \cdot \overline{C^{\prime}} \quad \text { d. } A^{\prime}=\bar{C} \cdot(A+B)+\bar{A} \cdot \bar{B} \cdot C
$$

The meaning of the first set of results is as follows: On flat terrain short-range artillery is used with the attack. At night the infantry attack is made with either long-range artillery and armored tanks or short-range artillery and no tanks. In bad weather either an assault on a broad front supported by long-range artillery or localized attacks supported by short-range artillery are made. Infantry assaults on a broad front are made on flat terrain in good weather or on hilly terrain in bad weather. Long-range artillery is used in hilly country. Armored tanks are used on flat plains in the daytime or on hilly country at night. The second set of results should also be interpreted.

To answer question $g$, consider first the first set of results: $A \cdot \bar{B} \cdot \bar{C}=A^{\prime} \cdot \overline{B^{\prime}} \cdot C^{\prime}$, as can be easily demonstrated by the use of the designation numbers. Thus the Blefuscudians will use an infantry assault on a broad front supported by short-range artillery and armored tanks, according to the logical analysis of the military observer's report. Similarly the second set of results can be used to give an alternate procedure that might be used by the Blefuscudians, which is also a logical conclusion of the report. This complete analysis of the military observer's report would certainly be difficult to obtain by other means.

Third Example: Solution for Simultaneous Equivalence Equations. Suppose that there were two aircraft-identification towers on an island. For a few days the same enemy airplanes kept flying overhead. Recognition of the types of enemy airplanes observed was very difficult and led to some controversy between the two observer posts. It was thought, although it was far from certain, that there were four types of enemy airplanes. Call these types $A, B, X$, and $Y$ : it was fairly certain that types $A$ and $B$ existed. On three successive days the reports from each post read as follows:

Post 1
1st day: The planes were of both types $X$ and $Y$
2d day: The planes were of type $A$ or $B$, or both

3d day: The planes were of type $X$ and either type $A$ or $B$, or both; or else they were type $A$ and type $Y$

## Post 2

The planes were of type $A$ and not type $B$
The planes were of type $Y$ and not type $A$, or else they were of type $X$
The planes were of type $A$

The question is: Is it at all possible, purely on the basis of these reports, that airplanes of type $X$ and type $Y$ were really airplanes of types $A$ and $B$ ?

Solution. If we can solve successfully for $X$ and $Y$ in terms of $A$ and $B$, then the answer would be "yes." The equations are

$$
X \cdot Y=A \cdot \bar{B} \quad A+B=\bar{A} \cdot Y+X \quad(A+B) \cdot X+A \cdot Y=A
$$

The solution:
$X=A \quad$ that is, $X$ could have been type $A$
$Y=A \bar{B}+\bar{A} B \quad$ that is, $Y$ could have been either type $A$ or type $B$, but not both types

Now suppose that the data had been the same as above, except that on the second day post 1 said that the airplanes were of type $B$ and not type $A$. Would it then be possible, in the light of the observers' data, for the enemy to have only two types of airplanes?

Solution. The equations

$$
X \cdot Y=A \cdot \bar{B} \quad \bar{A} \cdot B=\bar{A} \cdot Y+X \quad(A+B) \cdot X+A \cdot Y=A
$$

do not have a solution, and therefore no assumption as to the identity of types $X$ and $Y$ with types $B$ and $A$ can be made consistent with the observers' reports.
Fourth Example: Solutions to Simultaneous Implications. The board of directors of a certain manufacturing firm had a meeting to decide on their future business policies in the light of their goals. They discussed the relationships between money spent on advertising, the price of the commodity they manufactured, the per cent of the salesmen's commissions, and a possible change-over to an improved design of their product, and also the effects various courses of action would have on the final total profit of the firm and on the quantity of the product sold. The goals of the firm were clearly decided upon: to make a large profit, which was their responsibility as the directors of the firm, and to sell large quantities of the article they manufactured, so as to keep the factory operating at its maximum possible capacity. They all agreed on the following five points:

1. If the policy is either to change to a better-designed pattern or to cut the advertising expenditures, or if they give high salesmen's commissions or raise the retail price of the commodity, and if only a small number of articles are sold, then the profits will be small.
2. If large sums are spent in advertising and there is no alteration of design, or if there is a change-over to a new design but the advertising allotment is cut, then there cannot be both a large sales volume and large profit.
3. If the firm makes a large profit or if its sales volume is high, then the retail price of the articles is low and the advertising expenditure must be high; or else the retail price must be low with a small advertising budget, and there must also be a change to a new improved design coupled with low salesmen's commissions.
4. If the retail price is low, if there is no cut in advertising, and if there are high salesmen's commissions, or if the price is low and the salesmen's commissions are low but there is a change to an improved product design, then a great quantity of items must be sold.
5. If there are large advertising expenditures with a change-over to a new and improved design, but the retail price is kept low and many articles are sold, then a high profit will result.

The problem is: With these general rules as a guide what must be the policy decision of the board so as to have a large profit, to sell many articles, and both to have a large profit and to sell many articles?

To solve this problem first note that the five statements are combinations of the following sentences or propositions:
$A$, spend large sums of money on advertising.
$B$, change over to a better product design.
$C$, have a high retail price.
$D$, have high salesmen's commissions.
$X$, make a large profit.
$Y$, have a large sales volume.
The five points can be symbolized in terms of these sentences:

1. $(B+\bar{A}+D+C) \cdot \bar{Y} \rightarrow \bar{X}$
2. $A \cdot \bar{B}+\bar{A} \cdot B \rightarrow \overline{X \cdot Y}$
3. $X+Y \rightarrow A \cdot \bar{C}+\bar{A} \cdot B \cdot \bar{C} \cdot \bar{D}$
4. $A \cdot \bar{C} \cdot D+B \cdot \bar{C} \cdot \bar{D} \rightarrow Y$
5. $A \cdot B \cdot \bar{C} \cdot Y \rightarrow X$

There are three pairs of solutions to this set of five implications:

$$
\begin{aligned}
& X=A \cdot \bar{C} \cdot(B+\bar{D}) \quad X=A \cdot B \cdot \bar{C} \quad X=A \cdot B \cdot \bar{C} \\
& Y=\bar{C} \cdot(A \cdot D+B \cdot \bar{D}) \quad Y=\bar{C} \cdot(A+B \cdot \bar{D}) \quad Y=\bar{C} \cdot(A \cdot D+B \cdot \bar{D})
\end{aligned}
$$

Two policies consistent with these five rules can be obtained from the first set of results:

A policy incorporating a large advertising campaign with low retail prices, and either a change-over to a better design or low salesmen's commissions, is necessary and sufficient to ensure large profits.

Low retail prices, and either a large amount of advertising together with high salesmen's commissions or a new design and low salesmen's commissions, are necessary and sufficient for a large sales volume.
(The second and third sets of results should also be interpreted.)
In order to achieve both goals of large profits and a large sales volume, it is necessary and sufficient to have a large advertising budget, low retail prices, and a change-over to a new design, according to the first set of results.

The second and third set of results indicate that a large profit implies a large sales volume, and a large profit is obtained through large advertising costs, low retail prices, and a change-over to a new design, which are the identical requirements indicated from the first solution above.
g. Additional aspects of the material presented in this chapter and Chaps. 13 and 14 can be found in the following references by R. S. Ledley: Mathematical Foundations and Computational Methods for a Digital Logic Machine, J. Operations Research Soc. Am., vol. 2, no. 3, pp. 249-274, August, 1954; Digital Computational Methods in Symbolic Logic, with Examples in Biochemistry, Proc. Natl. Acad. Sci. U.S., vol. 41, no. 7, pp. 498-511, July, 1955; Boolean Matrix Equations in Digital Circuit Design, IRE Trans. on Electronic Computers, vol. EC-8, no. 2, pp. 131-139, June, 1959.

## CHAPTER 13

## BOOLEAN MATRIX EQUATIONS AND THE FUNDAMENTAL FORMULAS

## 13-1. Introduction and Statement of the Problem

Computational Methods. The first chapter of Part 3 introduced Boolean algebra and logic and described how a Boolean function can be interpreted as a circuit design and how conversely a digital-circuit design can be interpreted as a Boolean function. However, the problem immediately arose that there are in general many circuit designs, some simpler, some more complicated, that produce equivalent results, since a Boolean function can be written in many different equivalent forms. Chapter 11 tackled this problem by introducing a numerical-computation method that systematically enabled the reduction of a Boolean function to certain standard equivalent forms. Chapter 12 continued to produce further applications of the digital computational methods: constraints, solution to Boolean equations, transformation to the absolute simplest form. These last two applications were relatively specific methods for handling certain important types of problems.

In this chapter and the next the computational methods are extended in a more general way. Many problems that arise in Boolean algebra of the kind we consider in circuit design can be formulated in terms of these methods. In fact the solution to equations and the change of variables become special cases of the methods described in these chapters. The applications presented in this textbook are of necessity very limited, but in general the realm of applicability of these computational methods in electronic circuit design is broad. We reemphasize that individual originality is required to make full use of these methods. Practical application of the methods in engineering research ultimately depends on the ingenuity and skill of the user.
Problems of These Chapters. The kind of digital-circuit-design problems solved by the methods presented in this and the next chapter can most easily be described by means of a generalized example. Figure 13-1 is a block diagram of a circuit that has been separated into the circuits $f_{1}, f_{2}$, and $F$. The inputs to circuit $f_{1}$ are the wires labeled $A_{1}, A_{2}$, and $A_{3}$. Its single output is labeled $f_{1}$, where of course the signals produced in $f_{1}$ represent some Boolean function of the signals in the inputs; that is, $f_{1}=f_{1}\left(A_{1}, A_{2}, A_{3}\right)$. Function $f_{2}$ is considered similarly. The circuit $F$ has as inputs the wires labeled $f_{1}, f_{2}, X_{1}$, and $X_{2}$ and as output the wire
labeled $F$. The signal produced by $F$ represents some Boolean function of the signals of its inputs, that is, $F=F\left(f_{1}, f_{2}, X_{1}, X_{2}\right)$. However, since $f_{1}=f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ and $f_{2}=f_{2}\left(A_{1}, A_{2}, A_{3}\right)$, we can evidently also describe the signals in $F$ as a Boolean function of $A_{1}, A_{2}, A_{3}, X_{1}$, and $X_{2}$. For clarity we write this as $E\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)$, where in a certain sense $F=E$.

Now that we have described our example, let us see what elementary problems of circuit design can arise here. First, suppose the circuits $f_{1}, f_{2}$, and $F$ have already been constructed. The problem might be to determine the result of wiring them together as in Fig. 13-1; that is, the problem would be to determine $E\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)$ (see Fig. 13-2a). Second, suppose that only the circuits $f_{1}$ and $f_{2}$ have been constructed and that it is desired to make another circuit $F$ using as inputs $f_{1}, f_{2}, X_{1}$, and $X_{2}$ such that


Fig. 13-1. Block diagram of circuits $f_{1}, f_{2}$, and $F$. the end result will be the given desired function $E\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)$. The problem here is to determine the circuit design for $F$ (see Fig. 13-2b). Third suppose that only the circuit $F$ has been constructed and that it is desired to make circuits $f_{1}$ and $f_{2}$ so that when wired to $F$ as in Fig. 13-1 the final result will be the given desired function $E\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)$. The problem in this case is to


Fig. 13-2. Elementary problems of circuit design.
design $f_{1}$ and $f_{2}$ (see Fig. 13-2c). The general mathematical formulations of these problems are as follows:

1. The function $F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right)$ is given explicitly, and the functions $f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ are each given explicitly; the problem is to find the unknown function

$$
E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)
$$

2. The function $E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ is given explicitly, and the functions $f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ are each given explicitly; the problem is to find the unknown function

$$
F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right)
$$

such that $E=F$.
3. Both the Boolean functions $E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ and $F\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ are given explicitly; the problem is to find unknown functions $f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ such that $E=F$.

The first problem presents no difficulty, for in order to find $E$ we merely substitute in $F$ the explicit expression for each $f_{j}$ of the $A_{i}$. The $E$ so determined is always such that $F=E$.

The second and third problems are more difficult to solve, and systematic methods for their solution involving the designation numbers


Fig. 13-3. Problem of type 1.
will be given in the next sections. A solution can always be found for the second problem; this is not so for the third problem. It may happen in certain instances that no solutions to the third problem exist. In such an event solutions exist only if certain constraints hold between $A_{1}, A_{2}, \ldots, A_{I}$. These constraints may then be obtained, as well as the solutions which are possible provided that these constraints occur.

Examples. An example of a problem of type 1 is as follows: Suppose that three circuits, each with inputs $A_{1}, A_{2}$, and $A_{3}$, have been constructed with outputs $A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}, \bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}$, and $A_{1} \cdot A_{2}$ $+\bar{A}_{2} \cdot A_{3}$, respectively. Also suppose that another circuit has been constructed with inputs $f_{1}, f_{2}, f_{3}, X_{1}$, and $X_{2}$ and with output $\bar{f}_{1} \cdot f_{3}+$ $X_{1} \cdot f_{1} \cdot \bar{f}_{2}+X_{2} \cdot f_{2} \cdot f_{3}$. The problem is this: If the output of each of the former three circuits were connected, respectively, to inputs $f_{1}, f_{2}$, and $f_{3}$, what would be the output of the latter circuit in terms of $A_{1}, A_{2}, A_{3}$, and $X_{1}$ and $X_{2}$ ? The answer is $A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$ (see Fig. 13-3).

As an example of the problem of type 2, suppose that three circuits,
each with inputs $A_{1}, A_{2}$, and $A_{3}$, have been constructed with outputs $f_{1}, f_{2}$, and $f_{3}$, such that $f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}, f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}$, and $f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}$. Suppose that it is desired to use these circuits in the construction of another circuit $F$, such that the output of $F$ is $E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$. The problem is this: How shall the outputs of the already constructed three circuits be gated so that $E$ will result; i.e., what is the design of the circuit $F$ that has inputs $f_{1}, f_{2}, f_{3}, X_{1}$, and $X_{2}$ and output $E$ ? It turns out that $F$ should be $\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot \bar{f}_{2}+X_{2} \cdot f_{2} \cdot \bar{f}_{3}$ (see Fig. 13-4).


As an example of a type 3 problem, suppose that it is desired to make a circuit $E$ with output

$$
A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)
$$

In addition suppose that a certain circuit $F$ has already been built which has inputs $f_{1}, f_{2}, f_{3}, X_{1}$, and $X_{2}$ and output

$$
F=\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot f_{2}+X_{2} \cdot f_{2} \cdot f_{3}
$$

The problem is this: What three circuits shall be constructed that have inputs $A_{1}, A_{2}$, and $A_{3}$ and outputs connected to inputs $f_{1}, f_{2}$, and $f_{3}$ of $F$, respectively, such that the output of the already constructed $F$ will be the desired output $E$ ?

It turns out that the three circuits should be
and

$$
\begin{array}{ll}
A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} & \text { connected to } f_{1} \\
\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} & \text { connected to } f_{2} \\
A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3} & \text { connected to } f_{3}
\end{array}
$$

(see Fig. 13-5).
As will be shown, there are many other kinds of digital-circuit-design problems that can be solved by the methods to be presented. However, these simple pictures serve to give the reader a general idea of the kind of problems that can be approached by means of the numerical computational methods given in these chapters.

Methods to Be Developed. In the methods that are the subject of this chapter and the next the computations are not always carried out in terms of the designation numbers. Rather, the designation numbers are turned into Boolean matrices; the computations involve these matrices. The resulting matrix is changed back into the designation numbers and the explicit Boolean function comprising the solution is


Fig. 13-5. Problem of type 3.
derived from its number. This process is summarized in Fig. 13-6. It is interesting to note that the computations involving the matrices make use of only three pairs of fundamental formulas.

In this chapter we shall be primarily concerned with the statement of the computational methods and the proofs of the formulas; in the next chapter we shall present applications of the methods. Although


Fig. 13-6. Summary of solution to circuit design.
the proofs of the formulas can substantially help in understanding the general approach to the applications, they are not a necessary part of the computational methods. Therefore, after Secs. 13-2 and 13-3, consideration of Secs. 13-4 through 13-6 may be postponed without loss of continuity until after Chap. 14 has been covered.

Prerequisite to the proofs of the fundamental formulas is a discussion
of the general Boolean matrix equation and its solution, given in Sec. 13-4. Then in Sec. 13-5 we apply the general solution to a special type of Boolean matrix equation, which is of considerable importance for our purposes. Finally, in Sec. 13-6 we develop the fundamental matrix equation that relates the Boolean matrix equations to the designation numbers of the circuit-design problem. Then proofs of the fundamental


13-2, 13-3 The fundamental formulas

Chapter 14 Applications
Fig. 13-7. Logical developmental relations among sections of Chap. 13.
formulas follow easily. Figure 13-7 summarizes the true logical developmental relations among the sections of this chapter.

## 13-2. Designation Numbers and Boolean Matrices

Functions to Matrices and Reverse. We shall see that the computational methods involve three Boolean matrices. One of these matrices is associated with $E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ and is denoted by ( $E_{k i}$ ); another is associated with $F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right)$ and is denoted by $\left(F_{k j}\right)$; and the third is associated with the set of functions

$$
f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)
$$

and is denoted by ( $R_{j i}$ ) (see Fig. 13-1).
The given functions of the problem are transformed into these matrices, the matrix for the desired function (or functions in the case of the $f$ 's) is derived from the given matrices, and the desired function is then explicitly obtained from its matrix. Going from the function to the matrix or from the matrix to the function involves the designation numbers. This section is devoted to the method for transforming function into matrix and back.

The Function E. The matrix ( $E_{k i}$ ) can be derived from the Boolean function $E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ in two steps: First form the designation number $\# E$ with respect to the basis

$$
b\left[A_{1}, A_{2}, \ldots, A_{I}, X_{1}, X_{2}, \ldots, X_{K}\right]
$$

For example, if $E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$, then with respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ we have

| \# $A_{1}=$ | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# $A_{2}=$ | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 |
| \# $A_{3}=$ | 0000 | 1111 | 0000 | 1111 | 0000 | 1111 | 0000 | 1111 |
| \# $X_{1}=$ | 0000 | 0000 | 1111 | 1111 | 0000 | 0000 | 1111 | 1111 |
| $\# X_{2}=$ | 0000 | 0000 | 0000 | 0000 | 1111 | 1111 | 1111 | 1111 |
| \# $E=$ | 0001 | 0001 | 0001 | 1101 | 0111 | 0011 | 0111 | 1111 |

And, second, separate the positions of the designation number \# $E$ into $2^{K}$ successive groups of positions, with $2^{I}$ positions in each group. Index the groups from left to right by $k\left(k=0,1,2, \ldots, 2^{K}-1\right)$ and the positions within each group by $i\left(i=0,1,2, \ldots, 2^{I}-1\right)$. Then the rows of the matrix $\left(E_{k i}\right)$ are simply these respective groups of positions. For our example, $K=2,2^{K}=4, I=3,2^{I}=8$, whence

| $\# E=$ | 0001 | 0001 | 0001 | 1101 | 0111 | 0011 | 0111 | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $i$ | 0123 | 4567 | 0123 | 4567 | 0123 | 4567 | 0123 | 4567 |
| $k$ | 0 | 1 |  | 2 |  | 3 |  |  |

and therefore

$$
\left(E_{k i}\right)=\begin{array}{r}
i \\
k
\end{array} \begin{array}{r}
0 \\
0 \\
1 \\
2 \\
2
\end{array}\left(\begin{array}{ll}
000123 & 4567 \\
0001 & 0001 \\
00111 & 1101 \\
0111 & 0011
\end{array}\right)
$$

What we are really doing is forming the successive rows of ( $E_{k i}$ ) corresponding to the successive subbases for $A_{1}, A_{2}, A_{3}$ by appropriately "folding" the \# $E$, as indicated by the boxes.

The converse process, from $\left(E_{k i}\right)$ to the explicit function $E$, is simply the reverse of the above procedure. Given $\left(E_{k i}\right)$, we can immediately form \# $E$. Then $E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ as an explicit Boolean function can be found in any form desired by means of the usual procedures with respect to $b\left[A_{1}, A_{2}, \ldots, A_{1}, X_{1}, X_{2}, \ldots, X_{K}\right]$.

The Function $F$. The matrix $\left(F_{k j}\right)$ is derived similarly by folding \# $F$, where of course the basis $b\left[f_{1}, f_{2}, \ldots, f_{J}, X_{1}, X_{2}, \ldots, X_{K}\right]$ is used in computing $\# F$. Thus groups of $\# F$ are indexed by $k(k=0,1,2, \ldots$, $\left.2^{K}-1\right)$ and the positions in each group by $j\left(j=0,1,2, \ldots, 2^{J}-1\right)$. The rows of the matrix $\left(F_{k j}\right)$ are simply these respective groups of positions. For example, if

$$
F=\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot f_{2}+X_{2} \cdot f_{2} \cdot f_{3}
$$

then with respect to $b\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$ we have

| $\# f_{1}=0101$ | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 | 0101 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{2}=0011$ | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 | 0011 |
| $\# f_{3}=0000$ | 1111 | 0000 | 1111 | 0000 | 1111 | 0000 | 1111 |
| $\# X_{1}=0000$ | 0000 | 1111 | 1111 | 0000 | 0000 | 1111 | 1111 |
| $\# X_{2}=0000$ | 0000 | 0000 | 0000 | 1111 | 1111 | 1111 | 1111 |
| $\# F=0000$ | 1010 | 0100 | 1110 | 0011 | 1010 | 0111 | 1110 |
| j 0123 | 4567 | 0123 | 4567 | 0123 | 4567 | 0123 | 4567 |
| $k \quad 0$ | 0 |  | 1 |  | 2 |  | 3 |
|  |  | $\left(F_{k j}\right)=$ | $\left(\begin{array}{l}0000 \\ 0100 \\ 0011 \\ 0111\end{array}\right.$ | 1010 1110 1010 1110 |  |  |  |

The converse process, finding $F$ as an explicit Boolean function given $\left(F_{k j}\right)$, is the reverse of the above procedure. First $\# F$ is formed, and from this the explicit Boolean function $F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right)$ is found with respect to basis $b\left[f_{1}, f_{2}, \ldots, f_{J}, X_{1}, X_{2}, \ldots, X_{K}\right]$.

The Set of Functions $f_{s}$. The matrix $\left(R_{j i}\right)$ is formed in quite a different manner from the other matrices. To describe the relation between the function set $f_{1}\left(A_{1}, \ldots, A_{I}\right), f_{2}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ and the matrix ( $R_{j i}$ ), we first form the set of designation numbers for $f_{1}, f_{2}, \ldots, f_{J}$, each with respect to $b\left[A_{1}, A_{2}, \ldots, A_{I}\right]$, and place these numbers in successive rows starting with $\# f_{1}$. For example, if

$$
\begin{aligned}
& f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} \\
& f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} \\
& f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}
\end{aligned}
$$

then with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$ we have

|  | $i$ | 0123 |
| ---: | :--- | ---: |
| $\# 567$ |  |  |
| $\# A_{1}$ | $=0101$ | 0101 |
| $\# A_{2}$ | $=0011$ | 0011 |
| $\# A_{3}$ | $=0000$ | 1111 |
| $\# f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ | $=0100$ | 1110 |
| $\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ | $=0111$ | 0010 |
| $\# f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ | $=0001$ | 1101 |
| $j$ | 0326 | 5534 |

Next index each column of $b\left[A_{1}, \ldots, A_{I}\right]$ by $i(i=0,1,2, \ldots$, $2^{I}-1$ ), and note below each column of the $f_{s}$ array of designation numbers the binary number formed by that column (considering the top bit the least significant, the bottom bit the most significant). Notice that, if we form the basis $b\left[f_{1}, f_{2}, \ldots, f_{J}\right]$ and index the columns by $j(j=0$, $\left.1,2, \ldots, 2^{J}-1\right)$, then the index of each column of the $f_{s}$ array is the same as the index of the similar column of $b\left[f_{1}, f_{2}, \ldots, f_{J}\right]$.

Now the elements of the Boolean matrix ( $R_{j i}$ ) can be determined. An element $R_{j i}$ of the matrix $\left(R_{j i}\right)$ is a unit if corresponding to the $i$ th column of $b\left[A_{1}, \ldots, A_{I}\right]$ there is a column of the $f_{s}$ array indexed by $j$; otherwise $R_{j i}$ is zero. In our example we have the following correspondences: $(j, i):(0,0),(3,1),(2,2),(6,3),(5,4),(5,5),(3,6)$, and $(4,7)$. The only unit elements of the matrix ( $R_{j i}$ ) are $R_{00}, R_{31}, R_{22}, R_{63}, R_{54}, R_{55}, R_{36}$, and $R_{47}$. We have for our example

$$
\begin{aligned}
& i 01234567 \\
& \left(R_{j i}\right)=\begin{array}{r}
j \\
\hline
\end{array} \begin{array}{r}
0 \\
1 \\
2 \\
3
\end{array}\left(\begin{array}{cc}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
5 & \\
6 & \\
7 & 0000 \\
0000 & 0001 \\
0001 & 1100 \\
0000 & 0000
\end{array}\right)
\end{aligned}
$$

Note that each column has just one unit but that this is not necessarily true of the rows.

The reverse process of generating $f_{1}\left(A_{1}, \ldots, A_{I}\right), f_{2}\left(A_{1}, \ldots, A_{I}\right)$, . . . , $f_{J}\left(A_{1}, \ldots, A_{I}\right)$ from any given $\left(R_{j i}\right)$ is not unique, in contrast to the other processes described in this section. Several sets of $f_{s}$ are often possible, while, on the other hand, it may happen that there are no sets $f_{s}$ corresponding to a given $\left(R_{j i}\right)$. Two bases are consulted in this process, namely, $b\left[f_{1}, \ldots, f_{J}\right]$ and $b\left[A_{1}, \ldots, A_{I}\right]$, both written in the usual pattern. The desired solution is computed by means of the result array, as yet empty, with $2^{I}$ columns and $J$ rows: the columns are indexed by $i$ in order from left to right, the rows by $f_{1}, \ldots, f_{J}$, from top to bottom. For those pairs of indices $j, i$ for which $R_{j i}=1$, we place the $j$ th column of $b\left[f_{1}, \ldots, f_{J}\right]$ in the $i$ th column of the result array. The rows of the result array thus filled are the designation numbers of the corresponding $f_{1}, \ldots, f_{J}$ with respect to the basis $b\left[A_{1}, \ldots, A_{I}\right]$ and hence give the desired explicit functions

$$
f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)
$$

For example, consider

$$
\begin{aligned}
& i 0123 \quad 4567
\end{aligned}
$$

Sec. 13-2] matrix equations and fundamental formulas
$b\left[f_{1}, f_{2}, f_{3}\right]$
j $0123 \quad 4567$
$\# f_{1}=01010101$
$\# f_{2}=00110011$
$\# f_{3}=0000 \quad 1111$

Result Array

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ | 0 | 1 | 0 | 0,1 | 1 | 1 | 1,1 | 0 |
| $\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ | 0 | 1 | 1 | 1,1 | 0 | 0 | 1,1 | 0 |
| $\# f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ | 0 | 0 | 0 | 1,1 | 1 | 1 | 0,1 | 1 |

whence there are four possible sets of solutions which with respect to the usual basis $b\left[A_{1}, A_{2}, A_{3}\right]$ are seen to be

$$
\begin{array}{ll}
f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} & f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}+A_{1} \cdot \bar{A}_{3} \\
f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} & f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} \\
f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3} & f_{3}=A_{1} \cdot A_{2}+A_{3} \\
f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} & f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}+A_{1} \cdot \bar{A}_{3} \\
f_{2}=\bar{A}_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{3} & f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} \\
f_{3}=A_{1} \cdot A_{2}+A_{3} & f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}
\end{array}
$$

If a column of $\left(R_{j i}\right)$ were all zeros, then the corresponding column of the result array would be left blank and no solutions would exist.

## EXERCISES

(a) Find the matrix ( $E_{k i}$ ) for $E=A_{1} \cdot \bar{A}_{2} \cdot X_{1}+\bar{A}_{1} \cdot A_{2} \cdot \bar{X}_{1}$.

Solution. $\quad\left(E_{k i}\right)=\binom{0010}{0100}$.
(b) If $\left(E_{k i}\right)=(0110)$, find $E$.

Solution. $\quad E=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}$.
(c) Find the matrix $\left(F_{k j}\right)$ for $F=\left[\left(f_{1}=X_{1}\right) \cdot\left(f_{2}=X_{2}\right)\right]$. [Hint: Recall that ( $f_{1}=X_{1}$ ) can be written as $f_{1} \cdot X_{1}+\bar{f}_{1} \cdot \bar{X}_{1}$.]

Solution. $\quad\left(\mathrm{F}_{k_{j}}\right)=\left(\begin{array}{l}1000 \\ 0100 \\ 0010 \\ 0001\end{array}\right)$.
(d) If $\left(F_{k j}\right)=\left(\begin{array}{l}01 \\ 10 \\ 10 \\ 01\end{array}\right)$, find $F$.

Solution. $F=\left(f_{1} \cdot \bar{X}_{1}+\bar{f}_{1} \cdot X_{1}\right) \cdot \bar{X}_{2}+\left(f_{1} \cdot X_{1}+\bar{f}_{1} \cdot \bar{X}_{1}\right) \cdot X_{2}$.
(e) Find the matrix $\left(R_{j i}\right)$ for

$$
\begin{aligned}
& f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} \\
& f_{2}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}
\end{aligned}
$$

Solution. $\quad\left(R_{i i}\right)=\left(\begin{array}{ll}1010 & 0000 \\ 0100 & 0010 \\ 0001 & 0001 \\ 0000 & 1100\end{array}\right)$.
$(f)$ If $\left(R_{i i}\right)=\binom{1100}{1010}$, find the set $f_{s}$.
Solution. None.
(g) If $\left(R_{i i}\right)=\left(\begin{array}{ll}1010 & 0000 \\ 0101 & 0010 \\ 0001 & 0101 \\ 0000 & 1100\end{array}\right)$, find the set or sets $f_{s}$.

13-3. Antecedences and Consequences, and the Fundamental Formulas
Antecedence and Consequence Solutions. In Sec. 13-1 (see Fig. 13-1) we described three types of problems; these can be summarized in terms of the set of functions $f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$, the functions $F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right), E\left(A_{1}, \ldots, A_{J}, X_{1}, \ldots, X_{K}\right)$, and the equivalence equation $\dagger$

$$
\begin{array}{r}
F\left(f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right), X_{1}, \ldots, X_{K}\right) \\
=E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right) \tag{13-1}
\end{array}
$$

For type 1 problems the function $F$ and the set of functions $f_{1}, \ldots, f_{J}$ are given, and the problem is to find a solution $E$ satisfying Eq. (13-1). In type 2 problems the function $E$ and the set of functions $f_{1}, \ldots, f_{J}$ are given, and the problem is to find a solution $F$ that satisfies Eq. (13-1). For type 3 problems the functions $F$ and $E$ are given, and the problem is to find the set of solutions $f_{1}, \ldots, f_{J}$ that satisfies Eq. (13-1).

It turns out, however, that it is more convenient to solve problems of types 2 and 3 in two parts, one involving the equation

$$
\begin{align*}
& F_{a}\left(f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right), X_{1}, \ldots, X_{K}\right) \\
& \rightarrow E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right) \tag{13-2}
\end{align*}
$$

and the other involving the equation
$E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$
$\rightarrow F_{c}\left(f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right), X_{1}, \ldots, X_{K}\right)$

For if a solution satisfies both Eqs. (13-2) and (13-3), then it satisfies Eq. (13-1) ; that is, if $F_{a}=F_{c}=F$, then $F=E$. Solutions of Eq. (13-2) are called antecedence solutions, and solutions of Eq. (13-3) are called consequence solutions.

The meaning of the antecedence and consequence solutions can be understood as follows: Recall that the function $E$ (that is, the final desired output of the circuit) gives those combinations of input conditions that are to result in zero and unit output signals. An antecedence solution represents a circuit design that will produce a zero output signal for at least all input conditions for which $E$ is to be zero; it may have a zero output signal for other input conditions as well. A consequence solution represents a circuit design that will produce a unit output signal for at least all input conditions for which $E$ is to be a unit; it may have a unit output signal for other input conditions as well. Thus antecedence and consequence solutions do not necessarily represent circuits that have
$\dagger$ Black diamonds indicate the more important formulas.
an output identical to $E$ but do represent circuits whose outputs are "close" to that of $E$.

For example, if the designation number of $E$ is 0110 , then the designation numbers of all possible antecedence solutions are 0100, 0010, and 0000, while the designation numbers of all possible consequence solutions are 1110,0111 , and 1111.

As is illustrated by this example, it is not very difficult to produce antecedence and consequence solutions to a given equation. The importance of antecedence and consequence solutions arises from the fact that circuit-design problems always require antecedence and consequence solutions of a specified form, or involving only certain specified input wires, or both.

For example, suppose that $E=\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot X_{1}$ and that it is desired to find antecedence solutions of the form $F_{a}=f_{1} \cdot f_{2} \cdot X_{1}$. Since $E$ and $F$ are given and we want to find $f_{1}, f_{2}$, this is a type 3 problem. First observe that with respect to $b\left[A_{1}, A_{2}, X_{1}\right]$ we find $\# E=00000110$. An antecedence solution will have fewer units than $\# E$ in its designation number, as, for example, $00000100=\# A_{1} \cdot \bar{A}_{2} \cdot X_{1}$. So, if we let $f_{1}=A_{1}$ and $f_{2}=\bar{A}_{2}$, we have found an antecedence solution, i.e.,

$$
F_{a}\left(f_{1}\left(A_{1}, A_{2}\right), f_{2}\left(A_{1}, A_{2}\right), X_{1}\right)=f_{1}\left(A_{1}, A_{2}\right) \cdot f_{2}\left(A_{1}, A_{2}\right) \cdot X_{1}=A_{1} \cdot \bar{A}_{2} \cdot X_{1}
$$ and $A_{1} \cdot \bar{A}_{2} \cdot X_{2} \rightarrow\left(A_{1} \cdot \bar{A}_{2}+\overline{A_{1}} \cdot A_{2}\right) \cdot X_{1}$ as desired.

As another example, suppose that $E=\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot X_{1}$ as above, that $f_{1}=A_{1}, f_{2}=\bar{A}_{2}$, and that we desire to find a consequence solution $F_{c}\left(f_{1}, f_{2}, X_{1}\right)$. Since $E, f_{1}$, and $f_{2}$ are given and we want to find $F_{c}$, this is a type 2 problem. Again $\# E=00000110$. A consequence solution will have more units than $\# E$ in its designation number-for example, $00000111=\#\left(A_{1}+A_{2}\right) \cdot X_{1}$. So, if we let

$$
F_{c}=\left(f_{1}+\tilde{f}_{2}\right) \cdot X_{1}
$$

we have found a consequence solution, for

$$
\begin{aligned}
F_{c}\left(f_{1}\left(A_{1}, A_{2}\right), f_{2}\left(A_{1}, A_{2}\right), X_{1}\right)=\left(f_{1}\left(A_{1}, A_{2}\right)+\bar{f}_{2}\left(A_{1}, A_{2}\right)\right) & \cdot X_{1} \\
& =\left(A_{1}+A_{2}\right) \cdot X_{1}
\end{aligned}
$$

and $\left(A_{1} \cdot \bar{A}_{2}+\overline{A_{1}} \cdot A_{2}\right) \cdot X_{1} \rightarrow\left(A_{1}+A_{2}\right) \cdot X_{1}$ as desired.
Note that the trial-and-error methods of these examples is far from desirable. We shall now present the fundamental formulas that enable the systematic computation of antecedence and consequence solutions.

The Fundamental Formulas. The formulas are given in terms of the Boolean matrices developed in the previous section. There are six fundamental formulas, an antecedence formula and a consequence formula for each of the three types of problems. Observe that in terms of the matrices the problems of types 1,2 , and 3 can be distinguished as follows:

For type 1 the matrices $\left(F_{k j}\right)$ and ( $R_{j i}$ ) are given, and the problem is to determine ( $E_{k i}$ ).

For type 2 the matrices $\left(E_{k i}\right)$ and ( $R_{j i}$ ) are given, and the problem is to determine $\left(F_{k j}\right)$.

For type 3 the matrices $\left(E_{k i}\right)$ and ( $F_{k j}$ ) are given, and the problem is to determine ( $R_{j i}$ ).

Let us first recall (see Additional Topics, Sec. 13-7) that, if ( $M_{p q}$ ) is a Boolean matrix, then ( $\bar{M}_{p q}$ ) is the matrix formed by changing all zero elements of ( $M_{p q}$ ) to units and all unit elements of ( $M_{p q}$ ) to zeros. Also ( $M_{q p}$ ), the matrix formed by interchanging the rows and columns of $\left(M_{p q}\right)$, is called the transpose of $\left(M_{p q}\right)$. For example, if $\left(M_{p q}\right)=\binom{01}{01}$, then $\left(\bar{M}_{p q}\right)=\binom{10}{10}$ and $\left(M_{q p}\right)=\binom{00}{11}$. Also remember from Sec. 11-11 that Boolean matrix multiplication, indicated by $\otimes$, is identical to ordinary matrix multiplication, except that the logical sum and logical product replace the ordinary sum and product.
We now present the formulas that enable antecedence and consequence solutions to be determined for each of the above types of problems, where the subscripts $a$ and $c$ are used to distinguish between the determination of matrices corresponding to antecedence or consequence solutions:

|  | Antecedence | Consequence |
| :--- | :---: | :---: |
| Type 1 | $\left(F_{k j}\right) \otimes\left(R_{j i}\right)=\left(E_{k i}\right)$ | $\left(\bar{F}_{k j}\right) \otimes\left(R_{j i}\right)=\left(\bar{E}_{k i}\right)$ |
| Type 2 | $\left(R_{j i}\right) \otimes\left(\bar{E}_{i k}\right)=\left(\bar{F}_{j k}\right)_{a}$ | $\left(R_{j i}\right) \otimes\left(E_{i k}\right)=\left(F_{j k}\right)_{c}$ |
| Type 3 | $\left(F_{j k}\right) \otimes\left(\bar{E}_{k i}\right)=\left(\bar{R}_{j i}\right)_{a}$ | $\left(\bar{F}_{j k}\right) \otimes\left(E_{k i}\right)=\left(\bar{R}_{j i}\right)_{c}$ |

Properties of the Solutions. As will be shown in the succeeding sections, the solutions have the following properties:
type 1 problems. In problems of type 1 the antecedence and consequence solutions $E$ are the same (and hence there was no necessity for using subscripts $a$ and $c$ ); the formulas give two ways of determining $E$. In this case we always have $F=E$. The principal application of the formulas for type 1 is as a quick method for performing substitutions: we are given $F\left(f_{1}, \ldots, f_{J}, X_{1}, X_{2}, \ldots, X_{K}\right)$, and then the $E\left(A_{1}, \ldots, A_{T}, X_{1}, \ldots, X_{K}\right)$ determined by the formula is the result of substituting the given functions $f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ into $F$.
type 2 problems. A solution to problems of type 2 is in the form of a single function. Most often there are multiple solutions; i.e., there are many functions which are each good solutions. There is always at least one antecedence or consequence solution. Suppose that $F_{1}, F_{2}$, $\ldots, F_{N}$ are the multiple solutions for an antecedence problem of type 2; then $F_{n} \rightarrow E(n=1,2, \ldots, N)$. A surprising property of such a list of multiple antecedence solutions is that one of these solutions is implied by all the rest; i.e., there exists an $F_{m}$ among the solutions such that $F_{n} \rightarrow F_{m}$ for all $n$. We call this the solution "closest" to $E$, because $F_{m} \rightarrow E$, but for all other solutions $F_{n} \rightarrow F_{m} \rightarrow E$.

Similarly suppose that $F_{1}, F_{2}, \ldots, F_{N}$ are the multiple solutions for
a consequence problem of type 2 ; then $E \rightarrow F_{n}(n=1,2, \ldots, N)$. Again, there always exists a closest solution to $E$; that is, there exists some solution $F_{m}$ such that $F_{m}$ implies all other solutions: $E \rightarrow F_{m} \rightarrow F_{n}$ for all $n$. These closest solutions can easily be picked out and are usually the most useful.

An important application of the formulas for problems of type 2 is as an alternative method for determining any constraints between given functions. Use for ( $E_{i k}$ ) the single-column matrix (column vector) of $2^{I}$ rows every element of which is a unit, and determine ( $R_{j i}$ ) as usual from the given functions $f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ between which the constraint is being determined. A solution $F\left(f_{1}, \ldots, f_{J}\right)$ that is both an antecedence and consequence solution is the desired constraint. If no solution exists that is both an antecedence and consequence solution, then the functions $f_{1}, \ldots, f_{J}$ are independent (see Sec. 14-2).
type 3 problems. The solutions to problems of type 3 are in the form of a set of functions. It is possible to have multiple solutions, i.e., many sets of functions which are perfectly good solutions, analogous to multiple solutions to algebraic equations. Occasionally one of these sets of solutions contains a function $f=I$ or $f=0$, that is, $\# f=$ all units, or $\# f=$ all zeros; these are trivial solutions. It is also possible that no solution exists. As we have indicated above, when no solution exists conditions can be determined under which solutions will exist. These conditions are given in terms of constraints between the $A_{1}, A_{2}, \ldots$, $A_{I}$. The general method for determining these constraints is to compute the Boolean row vector or single-row matrix ( $C_{i}$ ) from the formula

$$
\left(V_{j}\right) \otimes\left(R_{j i}\right)=\left(C_{i}\right)
$$

where $\left(V_{j}\right)$ is a row vector consisting of all units. Then $\left(C_{i}\right)$ is the designation number of the desired constraints or conditions for the existence of solutions, referred to $b\left[A_{1}, \ldots, A_{T}\right]$. In order to impose this constraint, new bases constrained by the condition must now replace $b\left[A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right]$ and $b\left[A_{1}, \ldots, A_{I}\right]$, and the solution is found as described above except that the range of $i$ is from 0 to $u-1$, where $u$ is the number of units in ( $C_{i}$ ).

As mentioned in Sec. 13-1, the reader may go directly to Chap. 14 for immediate examples of applications of these formulas.

## EXERCISES

(a) If $E=\bar{A}_{2} \cdot X_{1}+\bar{A}_{1} \cdot \bar{X}_{1}, f_{1}=A_{1} \cdot \bar{A}_{2}$, and $f_{2}=\bar{A}_{1} \cdot A_{2}$, find both antecedence and consequence solutions $F_{a}\left(f_{1}, f_{2}, X_{1}\right)$ and $F_{c}\left(f_{1}, f_{2}, X_{1}\right)$. Show that $F_{a} \rightarrow E$ and $E \rightarrow F_{c}$. (HINT: Substitute for $f_{1}$ and $f_{2}$ in terms of $A_{1}$ and $A_{2}$ in the functions $F_{a}$ and $F_{c}$, find their designation numbers, and compare with the designation number of $E$.)
(b) If $E=\bar{A}_{2} \cdot X_{1}+\bar{A}_{1} \cdot \bar{X}_{1}$ and $F=\left(f_{1}+f_{2}\right) \cdot X_{1}+f_{1} \cdot f_{2} \cdot \bar{X}_{1}$, find the sets of antecedence and consequence solutions $f_{s}$.
(c) From Exercise $b$ choose the set of antecedence solutions $\# f_{1}=1000, \# f_{2}=1100$,
and show that for antecedence $F_{a} \rightarrow E$, using the formula of type 1 . Choose the set of consequence solutions $\# f_{1}=1010, \# f_{2}=1110$, and show that $E \rightarrow F_{c}$, using the formula of type 1 .

## 13-4. Solution to the General Boolean Matrix Equation $\dagger$

The General Boolean Matrix Equation. Consider the matrix equation

$$
\begin{equation*}
\left(a_{i j}\right) \otimes\left(x_{j k}\right)=\left(b_{i k}\right) \tag{13-5}
\end{equation*}
$$

where $\left(a_{i j}\right),\left(x_{j k}\right)$, and $\left(b_{i k}\right)$ are Boolean matrices. Suppose that ( $a_{i j}$ ) and $\left(b_{i k}\right)$ are known and that the problem is to determine the Boolean matrix $\left(x_{j k}\right)$ that satisfies this equation. This is similar to the problem of the solution of ordinary matrix equations, but the conditions for the existence of a solution and the character of the solutions when they exist differ greatly. For example, consider the following Boolean matrix equation:

$$
\left(\begin{array}{ll}
1000 & 0100 \\
0010 & 0001 \\
1010 & 0111 \\
1001 & 1000
\end{array}\right) \otimes\left(x_{j k}\right)=\left(\begin{array}{l}
1110 \\
1011 \\
1111 \\
0110
\end{array}\right)
$$

As can be readily checked, each of the following is a solution:
$\left(\begin{array}{l}0110 \\ 1111 \\ 1011 \\ 0110 \\ 0110 \\ 1110 \\ 1111 \\ 1011\end{array}\right) \quad\left(\begin{array}{l}0110 \\ 0000 \\ 1011 \\ 0000 \\ 0 \\ 0000 \\ 1000 \\ 0000 \\ 0000\end{array}\right) \quad\left(\begin{array}{l}0010 \\ 0000 \\ 0000 \\ 0100 \\ 000 \\ 1100 \\ 0000 \\ 1011\end{array}\right) \quad\left(\begin{array}{l}0000 \\ 0000 \\ 0010 \\ 0000 \\ 0110 \\ 1110 \\ 0000 \\ 1001\end{array}\right)$

In fact there are more than $2{ }^{17}$ possible solutions to this equation. On the other hand, the equation

$$
\left(\begin{array}{ll}
1010 & 1100 \\
0110 & 0011 \\
1010 & 0111 \\
1001 & 0110
\end{array}\right) \otimes\left(x_{j k}\right)=\left(\begin{array}{c}
0010 \\
1101 \\
0000 \\
1001
\end{array}\right)
$$

has only one solution, namely,
$\left(\begin{array}{l}0000 \\ 1101 \\ 0000 \\ 1001 \\ 0010 \\ 0000 \\ 0000 \\ 0000\end{array}\right)$
$\dagger$ The sections that follow presuppose the reader's familiarity with the operations and properties of Boolean matrices given in the Additional Topics of this chapter (Sec. 13-7).

Sec. 13-4] matrix equations and fundamental formulas
and the equation

$$
\left(\begin{array}{ll}
1010 & 0100 \\
0110 & 0011 \\
1010 & 0111 \\
1001 & 0110
\end{array}\right) \otimes\left(x_{j k}\right)=\left(\begin{array}{l}
0010 \\
1101 \\
1111 \\
1001
\end{array}\right)
$$

has no solution.
Solution to the Equation. We shall show below that a necessary and sufficient condition that a solution to Eq. (13-5) exists is that $\dagger$

$$
\begin{equation*}
\left(a_{i j}\right) \otimes \overline{\left(\left(a_{i j}\right)^{T} \otimes\left(\overline{b_{i k}}\right)\right)}=\left(b_{i k}\right) \tag{13-6}
\end{equation*}
$$

Similarly a necessary and sufficient condition for a solution to exist for

$$
\begin{equation*}
\left(x_{k j}\right) \otimes\left(a_{j i}\right)=\left(b_{k i}\right) \tag{13-7}
\end{equation*}
$$

is that

$$
\begin{equation*}
\overline{\left(\left(\overline{b_{k i}}\right) \otimes\left(a_{j i}\right)^{T}\right)} \otimes\left(a_{j i}\right)=\left(b_{k i}\right) \tag{13-8}
\end{equation*}
$$

Evidently, if condition (13-6) holds, then

$$
\begin{equation*}
\left(x_{j k}^{\prime}\right)=\overline{\left(a_{i j}\right)^{T} \otimes\left(\overline{b_{i k}}\right)} \tag{13-9}
\end{equation*}
$$

is a solution to Eq. (13-5) (this, by the way, proves sufficiency). In fact such an $\left(x_{j k}^{\prime}\right)$ is a very special solution, for as we shall see, if another solution $\left(x_{j k}\right)$ to Eq. (13-5) exists, then $\left(x_{j k}\right) \rightarrow\left(x_{j k}^{\prime}\right)$. That is, $\left(x_{j k}^{\prime}\right)$ is implied by all other solutions; we shall therefore say that it is the least upper bound of solutions to Eq. (13-5). Analogous results are true for Eq. (13-7), for which any solution $\left(x_{k j}\right) \rightarrow\left(x_{k j}^{\prime}\right)$, where

$$
\begin{equation*}
\left(x_{k j}^{\prime}\right)=\overline{\left(\overline{b_{k i}}\right) \otimes\left(a_{j i}\right)^{T}} \tag{13-10}
\end{equation*}
$$

Proofs. Proof of the necessity of condition (13-6) [or (13-8)], i.e., that if a solution exists then Eq. (13-9) [or (13-10)] gives one, is based on the following considerations: Recall that from the definition of Boolean matrix multiplication, given in Sec. 11-11, Eq. (13-5) is equivalent to the set of ( $I$ times $K$ ) equations

$$
\begin{equation*}
\sum_{j} a_{i j} \cdot x_{j k}=b_{i k} \tag{13-11}
\end{equation*}
$$

where $\sum_{j}$ indicates that the logical summation is to be taken of all the logical products over the range of $j$. From these equations it is clear that each column of $\left(x_{j k}\right)$ depends only on the matrix $\left(a_{i j}\right)$ and the corresponding column of $\left(b_{i k}\right)$ and is independent of the other columns of $\left(b_{i k}\right)$. Hence, if the existence condition can be shown to hold for each column of Eq. (13-5), it holds for the entire matrix. Similarly Eq.
$\dagger$ The superscript $T$ denotes transposition, i.e., for example, $\left(a_{i j}\right)^{T}=\left(a_{i i}\right)$-see Sec 13-7.
(13-7) is equivalent to the set of equations

$$
\begin{equation*}
\sum_{j} x_{k j} \cdot a_{j i}=b_{k i} \tag{13-12}
\end{equation*}
$$

from which it is seen that the rows are independent of each other.
We consider as an example the first column of Eq. (13-5) (that is, $k=0$ ). This column must satisfy the following subset of Eq. (13-11):

$$
\begin{equation*}
\sum_{j} a_{i j} \cdot x_{j 0}=b_{i 0} \tag{13-13}
\end{equation*}
$$

Let us assume that a solution exists; then consider those $i$ for which $b_{i 0}=0$. In such an $i$ th row, for each $j$ such that $a_{i j}=1$, the corresponding $x_{j 0}$ must be zero in order that $\sum_{j} a_{i j} \cdot x_{j 0}=0$. For each $j$ such that $a_{i j}=0$ the corresponding $x_{j 0}$ can be either 1 or 0 . Next consider those $i$ for which $b_{i 0}=1$ : here there must be at least one value for $j$ for which both $a_{i j}=1$ and $x_{j 0}=1$. By the assumption that a solution exists it will be obtained if we make $x_{j 0}=1$ for all $j$ except those $j$ where $b_{i 0}=0$ and where $a_{i j}=1$ for at least one value of $i$ require that $x_{j 0}=0$. Let us denote this set of $x_{j 0}$ by $\left(x_{i 0}^{\prime}\right)$.

The condition that $x_{j 0}^{\prime}=0$ can be expressed as $\left(b_{i 0}+\bar{a}_{i j}\right)=0$ for at least one $i$. In other words, $\prod\left(b_{i 0}+\bar{a}_{i j}\right)=0$, or equivalently

$$
\sum_{i} \bar{b}_{i 0} \cdot a_{i j}=1
$$

Since otherwise $x_{j 0}^{\prime}=1$, we can set $\bar{x}_{j 0}^{\prime}=\sum_{i} \bar{b}_{i 0} \cdot a_{i j}$. This is equivalent to the matrix equation

$$
\begin{equation*}
\left(x_{j 0}^{\prime}\right)=\overline{\left(a_{i j}\right)^{T} \otimes\left(\overline{b_{i 0}}\right)} \tag{13-14}
\end{equation*}
$$

Equation (13-9) follows by extension. Equation (13-10) follows by similar reasoning.
We have shown that if there is any solution to Eq. (13-13) then $x_{j 0}^{\prime}$ is also a solution; we shall now show that if $x_{j 0}$ satisfies Eq. (13-13) then $x_{j 0} \rightarrow x_{j 0}^{\prime}$. For suppose there exists a solution to Eq. (13-13), say ( $z_{j 0}$ ). Clearly $z_{j 0}=1$ cannot occur for any $j$ for which $x_{j 0}^{\prime}=0$, by the definition of $\left(z_{j 0}\right)$, and therefore $z_{j 0} \rightarrow x_{j 0}^{\prime}$. [Note that we say that $\left(M_{j k}\right) \rightarrow\left(N_{j k}\right)$ when $M_{j k} \rightarrow N_{j k}$ for each $k$ and $j$.]

The matrices $\left(x_{j k}^{\prime \prime}\right)$ and ( $x_{k j}^{\prime}$ ) have a property of great importance in the cases where Eqs. (13-5) and (13-7) have no solution. Observe that in any case we have formed ( $x_{j 0}^{\prime}$ ) such that $\left(a_{i j}\right) \otimes\left(x_{j 0}^{\prime}\right)$ has zeros at least wherever $\left(b_{i 0}\right)$ has zeros. Therefore $\left(a_{i j}\right) \otimes\left(x_{j 0}^{\prime}\right) \rightarrow\left(b_{i 0}\right)$. By extension it follows that

$$
\begin{equation*}
\left(a_{i j}\right) \otimes\left(x_{j k}^{\prime}\right) \rightarrow\left(b_{i k}\right) \tag{13-15}
\end{equation*}
$$

even when no solution ( $x_{j k}$ ) exists for Eq. (13-5). Similarly, for the problems represented by Eq. (13-7),

$$
\begin{equation*}
\left(x_{k j}^{\prime}\right) \otimes\left(a_{j i}\right) \rightarrow\left(b_{k i}\right) \tag{13-16}
\end{equation*}
$$

For example, consider $\binom{11}{00} \otimes\left(x_{j k}\right)=\binom{10}{11}$; since $\left(x_{j k}^{\prime}\right)=\binom{10}{10}$, we find $\binom{11}{00} \otimes\binom{10}{10}=\binom{10}{00} \rightarrow\binom{10}{11}$.

Character of Solutions to the Equation. We have shown above that $\left(x_{k j}^{\prime}\right)$ is the least upper bound to solutions to Eq. (13-5), if any solutions exist. However, there is in general no unique greatest lower bound. For example, consider the equation

$$
\binom{101}{011} \otimes\left(x_{j k}\right)=\binom{10}{11}
$$

There are 5 solutions to this equation, which are shown in Fig. 13-8. In this case there are 2 lowest solutions (dark parentheses), i.e., solutions


Fig. 13-8. Five solutions to the equation $\binom{101}{011} \otimes\left(x_{j k}\right)=\binom{10}{11}$.
that are implied by no other solutions. In the example shown above with the over $2^{17}$ solutions there are 72 lowest solutions. The lowest solutions have an interesting property: if $\left(y_{j k}\right)$ is any lowest solution of Eq. (13-5), then all matrices ( $w_{j k}$ ) such that

$$
\begin{equation*}
\left(y_{j k}\right) \rightarrow\left(w_{j k}\right) \rightarrow\left(x_{j k}^{\prime}\right) \tag{13-17}
\end{equation*}
$$

are also solutions. In fact the totality of solutions for a Boolean matrix equation is found as follows: Compute $\left(x_{j k}^{\prime}\right)$; then find all the lowest solutions; finally for each lowest solution generate all solutions ( $w_{j k}$ ). The solution ( $x_{j k}^{\prime}$ ) is found by means of the above formulas; and we shall discuss below how to find the lowest solutions $\left(y_{j k}\right)$. To find the solutions $\left(w_{j k}\right)$, simply start from the corresponding lowest solution ( $y_{j k}$ ), and replace those zeros of $\left(y_{j k}\right)$ that do not correspond to zeros of $\left(x_{j k}^{\prime}\right)$
with units, one at a time, two at a time, and so forth. Of course analogous remarks hold for ( $x_{k j}^{\prime}$ ) corresponding to Eq. (13-7), that is,

$$
\begin{equation*}
\left(y_{k j}\right) \rightarrow\left(w_{k j}\right) \rightarrow\left(x_{k j}^{\prime}\right) \tag{13-18}
\end{equation*}
$$

For the example equation above

$$
\left(x_{j k}^{\prime}\right)=\overline{\left.\binom{101}{011}^{T} \otimes \overline{(10}\right)}=\overline{\left(\begin{array}{l}
10 \\
01 \\
11
\end{array}\right) \otimes\binom{01}{00}}=\left(\begin{array}{l}
\overline{01} \\
00 \\
01
\end{array}\right)=\left(\begin{array}{l}
10 \\
11 \\
10
\end{array}\right)
$$

Since $\left(a_{i j}\right) \otimes\left(x_{j k}^{\prime}\right)=\binom{010}{011} \otimes\left(\begin{array}{l}10 \\ 11 \\ 10\end{array}\right)=\binom{10}{11}=\left(b_{i k}\right)$, a solution exists. It will be shown below that there are two lowest solutions, namely, $\left(\begin{array}{l}00 \\ 01 \\ 10\end{array}\right)$ and $\left(\begin{array}{l}10 \\ 11 \\ 00\end{array}\right)$. Hence we have for $\left(w_{j k}\right)$ the matrices

$$
\left(\begin{array}{l}
00 \\
01 \\
10
\end{array}\right) \quad\left(\begin{array}{l}
10 \\
01 \\
10
\end{array}\right) \quad\left(\begin{array}{l}
00 \\
11 \\
10
\end{array}\right) \quad\left(\begin{array}{l}
10 \\
11 \\
00
\end{array}\right) \quad\left(\begin{array}{l}
10 \\
11 \\
10
\end{array}\right)
$$

There are only these five different solutions, as shown in Fig. 13-8.
Computing the Lowest Solutions. $\dagger$ The problem of computing all solutions, if any solution exists, now reduces to the determination of the lowest solutions $\left(y_{j k}\right)$. Here the method is only semisystematic. Let us present the method by means of an example. Consider the equation

$$
\left(\begin{array}{ll}
1000 & 0100 \\
0010 & 0001 \\
1010 & 0111 \\
1001 & 1000
\end{array}\right) \otimes\left(x_{j k}\right)=\left(\begin{array}{l}
1110 \\
1011 \\
1111 \\
0110
\end{array}\right) \quad \text { whence }\left(x_{i k}^{\prime}\right)=\left(\begin{array}{l}
0110 \\
1111 \\
1011 \\
0110 \\
0110 \\
1110 \\
1111 \\
1011
\end{array}\right)
$$

The possible columns of the matrix $\left(y_{j k}\right)$ are determined one at a time in three steps. Let us start with $\left(y_{j 0}\right)$. (1) Form the array composed of only those rows of ( $a_{i j}$ ) which correspond to units of the column $\left(b_{i 0}\right)$. In our example these are rows 0,1 , and 2 . (2) Copy under this array as a row the $\left(x_{j 0}^{\prime}\right)$ column of $\left(x_{j k}^{\prime}\right)$. Then cross off those columns of the array corresponding to the zeros of $\left(x_{j 0}^{\prime}\right)$, thus:

$\dagger$ A systematic method for finding all solutions will be found in Sec. 13-7, Additional Topics.
(3) The final step is semisystematic and is concerned only with the remaining columns of the array, that is, $1,2,5,6$, and 7 . The goal is to choose columns whose logical sum is all units, i.e., whose logical sum yields the three units of column ( $b_{i 0}$ ). For example, choose columns 2 and 5. Then one possibility for $\left(y_{j 0}\right)$ is a column with units in rows 2 and 5. However, the process of deriving columns for ( $y_{j 0}$ ) in this manner must proceed in the following order: First try to choose a single column of the array that is all units. Next try for pairs of columns of the array whose logical sum is all units; then for triplets of columns; etc. Each such choice determines a possible column for $\left(y_{j 0}\right)$ that has units only in rows corresponding to the columns of the array included in the choice. However, to ensure the lowest solutions the successive choices must adhere to the following rule: The present choice must include at least one column of the array not included in each of the previous choices and must not include a column of the array that is included in each of the previous choices. When this can no longer be done, all possible columns for ( $y_{i 0}$ ) have been found. Thus the possible columns are chosen so that each produces column $\left(b_{i 0}\right)$ in the multiplication but so that no $\left(y_{i 0}\right)$ implies any other. The process is repeated for $\left(y_{i 1}\right),\left(y_{i 2}\right)$, etc.

For our illustration, to determine possible columns for ( $y_{j 0}$ ) first note that no single column of the array has all units. So try for pairs. First choose array columns 2 and 5 . Take array columns 5 and 7 as the second choice, which differs appropriately from the first choice, array columns 2 and 5. No more pair choices exist, nor are there any triplet choices. (We need not look for quadruplet choices, since the array has only three rows.) Hence ( $y_{i 0}$ ) can be either

| 0 | 0 |  | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- |
| 1 | 0 |  | 1 | 0 |
| $2 \rightarrow$ | 1 |  | 2 | 0 |
| 3 | 0 | or | 3 | 0 |
| 4 | 0 |  | 4 | 0 |
| $5 \rightarrow$ | 1 |  | $5 \rightarrow$ | 1 |
| 6 | 0 |  | 6 | 0 |
| 7 | 0 |  | $7 \rightarrow$ | 1 |

Similarly for our example we find


Hence, to determine all the $\left(y_{j k}\right)$, we take all combinations of the two possibilities for column 0 , the three for column 1 , the six for column 2 ,
and the two for column 3 , to make altogether $2 \times 3 \times 6 \times 2=72$ lowest matrices $\left(y_{j k}\right)$, that is,
$\left(\begin{array}{l}0110 \\ 0000 \\ 1011 \\ 0000 \\ 0000 \\ 1000 \\ 0000 \\ 0000\end{array}\right) \quad\left(\begin{array}{l}0110 \\ 0000 \\ 0011 \\ 0000 \\ 0 \\ 0000 \\ 1000 \\ 0000 \\ 1000\end{array}\right) \quad\left(\begin{array}{l}0010 \\ 0000 \\ 1011 \\ 0100 \\ 0000 \\ 1100 \\ 0000 \\ 0000\end{array}\right) \quad\left(\begin{array}{l}0010 \\ 0000 \\ 0011 \\ 0100 \\ 0000 \\ 1100 \\ 0000 \\ 1000\end{array}\right)$
and so forth.

## EXERCISES

(a) Find all solutions of $\binom{101}{011} \otimes\left(x_{i k}\right)=\binom{10}{11}$.
(b) Find all solutions of $\binom{1001}{0101} \otimes\left(x_{j k}\right)=\binom{10}{11}$, and graph their implications as in Fig. 13-8.
(c) Find the least-upper-bound solution and all lowest solutions of

$$
\left(\begin{array}{ll}
1101 & 0000 \\
0100 & 1011 \\
1001 & 1000 \\
0010 & 0111
\end{array}\right) \otimes\left(x_{j k}\right)=\left(\begin{array}{l}
1011 \\
1111 \\
1101 \\
1001
\end{array}\right)
$$

(d) Find the least-upper-bound solution and all lowest solutions of

$$
\left(x_{k j}\right) \otimes\left(\begin{array}{l}
10 \\
01 \\
00 \\
11
\end{array}\right)=\binom{11}{01}
$$

## 13-5. Solution to the Unitary Matrix Equation

The Unitary Matrix Equation. The matrix equation

$$
\begin{equation*}
\left(a_{k j}\right) \otimes\left(U_{j i}\right)=\left(b_{k i}\right) \tag{13-19}
\end{equation*}
$$

where $\left(U_{j i}\right)$ is a matrix that has precisely 1 unit in each column, $\dagger$ is called a unitary (or pseudopermutation) matrix equation and is of particular importance for our purposes. The effect of multiplying a matrix on the right by $\left(U_{j i}\right)$ is to permute the columns of that matrix; if element $U_{j i}=1$, then column $j$ will go into column $i$. For example, let

$$
\left(U_{j i}\right)=\left(\begin{array}{l}
0001 \\
0000 \\
1000 \\
0110
\end{array}\right) \quad \text { then }\left(\begin{array}{l}
1100 \\
1010 \\
0011 \\
1100
\end{array}\right) \otimes\left(\begin{array}{l}
0001 \\
0000 \\
1000 \\
0110
\end{array}\right)=\left(\begin{array}{l}
0001 \\
1001 \\
1110 \\
0001
\end{array}\right)
$$

$\dagger$ To avoid confusion, we shall not include in our discussion matrices having just 1 unit in each row. Such a matrix permutes the rows of another matrix which it multiplies on the left. Our work can be generalized to these matrices by applying the relation on tranposes of products (see Exercise e).
where column 0 went to column 3, column 2 to column 0 , and column 3 to column 1 and also to column 2. It is clear that if a matrix is complemented and its columns permuted the result is the same as if its columns were permuted first and then complemented; thus

$$
\begin{equation*}
\overline{\left(a_{k j}\right) \otimes\left(U_{j i}\right)}=\left(\overline{\left.a_{k j}\right)} \otimes\left(U_{j i}\right)\right. \tag{13-20}
\end{equation*}
$$

In general there may arise three types of equations associated with Eq. (13-19) involving unitary matrices, corresponding (1) to ( $b_{k i}$ ) unknown, (2) to ( $a_{k j}$ ) unknown, and (3) to ( $U_{j i}$ ) unknown except for its unitary nature.

Solutions to Type 1 Equations. For an equation of the first type a matrix $\left(a_{k j}\right)$ and a unitary matrix $\left(U_{j i}\right)$ are known, and a matrix $\left(b_{k i}\right)$ is sought which satisfies Eq. (13-19). Here the solution is obvious: $\left(b_{k i}\right)$ is obtained directly by multiplication. Obviously ( $b_{k i}$ ) so obtained is unique. We note also that by applying Eq. (13-20) we obtain

$$
\begin{equation*}
\left(\overline{a_{k j}}\right) \otimes\left(U_{j i}\right)=\left(\overline{b_{k i}}\right) \tag{13-21}
\end{equation*}
$$

Solutions to Type 2 Equations. For an equation of the second type a matrix ( $b_{k i}$ ) and a unitary matrix ( $U_{j i}$ ) are known, and a matrix $\left(a_{k j}\right)$ is sought which satisfies Eq. (13-19). This is an equation of the type illustrated by Eq. (13-7), and we obtain from Eq. (13-10) the least upper bound of solutions,

$$
\begin{equation*}
\left(a_{k j}^{\prime}\right)=\overline{\left(\overline{b_{k i}}\right) \otimes\left(U_{j i}\right)^{T}} \tag{13-22}
\end{equation*}
$$

Complementing and applying the relation that the transpose of a product of matrices is the product of the transposes of the factors taken in reverse order, we obtain

$$
\begin{equation*}
\overline{\left(\overline{a_{j k}^{\prime}}\right)}=\left(U_{j i}\right) \otimes\left(\overline{b_{i k}}\right) \tag{13-23}
\end{equation*}
$$

where $\left(b_{i k}\right)=\left(b_{k i}\right)^{T}$, etc. (In what follows we usually indicate a transpose by this method of transposing the indices.)
A consequence of Eq. (13-20) is that the set of solutions for type 2 equations, if any exist, will have a greatest lower bound as well as a least upper bound. We see that Eq. (13-21) must hold for every solution ( $a_{k j}$ ) to Eq. (13-19). If we now consider Eq. (13-21) as an equation of the second type in $\left(\overline{a_{k j}}\right)$ as the unknown, we can solve for a least upper bound for ( $\overline{a_{k j}}$ ), namely,

Complementing and transposing, we have

$$
\begin{equation*}
\left(a_{j k}^{*}\right)=\left(U_{j i}\right) \otimes\left(b_{i k}\right) \tag{13-24}
\end{equation*}
$$

Since $\left(\overline{a_{j k}^{*}}\right)$ is the least upper bound of $\left(\overline{a_{j k}}\right)$, then $\left(a_{j k}^{*}\right)$ is the greatest lower bound of ( $a_{j k}$ ) and hence is the unique lowest solution to the equation of type 2. The totality of matrices $\left(a_{j k}\right)$ such that

$$
\begin{equation*}
\left(a_{j k}^{*}\right) \rightarrow\left(a_{j k}\right) \rightarrow\left(a_{j k}^{\prime}\right) \tag{13-25}
\end{equation*}
$$

are all the solutions to Eq. (13-19), considered as a type 2 equation (see Exercise $d$ below).

Solutions to Type 3 Equations. For an equation of the third type matrices ( $a_{k j}$ ) and ( $b_{k i}$ ) are known, and a unitary matrix ( $U_{j i}$ ) is sought that will satisfy Eq. (13-19). This is an equation of the type illustrated by Eq. (13-5), and we obtain from Eq. (13-9) the least upper bound of solutions [such that $\left(U_{j i}\right) \rightarrow\left(x_{j i}^{\prime}\right)$ ],

$$
\begin{equation*}
\left(x_{j i}^{\prime}\right)=\overline{\left(a_{j k}\right) \otimes\left(\overline{b_{k i}}\right)} \tag{13-26}
\end{equation*}
$$

From Eq. (13-15) we see that $\left(a_{k j}\right) \otimes\left(x_{j i}^{\prime}\right) \rightarrow\left(b_{k i}\right)$. If $\left(U_{j i}\right) \rightarrow\left(x_{j i}^{\prime}\right)$, it follows (see Sec. 11-11) that

$$
\begin{equation*}
\left(a_{k j}\right) \otimes\left(U_{j i}\right) \rightarrow\left(b_{k i}\right) \tag{13-27}
\end{equation*}
$$

Consider now Eq. (13-21) as an equation of type 3. The least upper bound to solutions to this equation [such that $\left(U_{j i}\right) \rightarrow\left(x_{j i}^{*}\right)$ ] is

$$
\begin{equation*}
\left(x_{j i}^{*}\right)=\overline{\left(\overline{a_{j k}}\right) \otimes\left(b_{k i}\right)} \tag{13-28}
\end{equation*}
$$

Again from Eq. (13-15) it follows that, if $\left(U_{j i}\right) \rightarrow\left(x_{j i}^{*}\right)$, then

$$
\begin{equation*}
\left(\overline{a_{k j}}\right) \otimes\left(U_{j i}\right) \rightarrow\left(\overline{b_{k i}}\right) \tag{13-29}
\end{equation*}
$$

Remembering that, if $P \rightarrow Q, \bar{Q} \rightarrow \bar{P}$, we obtain

$$
\left(b_{k i}\right) \rightarrow \overline{\left.\overline{\left(a_{k j}\right)}\right) \otimes\left(U_{j i}\right)}
$$

If $\left(U_{j i}\right)$ is unitary, Eq. (13-20) gives

$$
\begin{equation*}
\left(b_{k i}\right) \rightarrow\left(a_{k j}\right) \otimes\left(U_{j i}\right) \tag{13-30}
\end{equation*}
$$

Hence, by implications (13-27) and (13-30), every unitary matrix ( $U_{j i}$ ) such that $\left(U_{j i}\right) \rightarrow\left(x_{j i}^{\prime}\right)$ and $\left(U_{j i}\right) \rightarrow\left(x_{j i}^{*}\right)$, that is, such that

$$
\begin{equation*}
\left(U_{j i}\right) \rightarrow\left(x_{j i}^{\prime}\right) \cdot\left(x_{j i}^{*}\right) \tag{13-31}
\end{equation*}
$$

satisfies Eq. (13-19), namely, $\left(a_{k j}\right) \otimes\left(U_{j i}\right)=\left(b_{k i}\right)$, as desired (recalling that $P \rightarrow Q$ and $Q \rightarrow P$ if and only if $P=Q$ ).

Conditions for Existence of Solutions. From the nature of the type 1 equations it is obvious that a unique solution always exists, which may be found from either Eq. (13-19) or Eq. (13-21), which are equivalent. In type 2 and 3 equations, however, no solutions need exist, and if a solution does exist, it need not be unique.

In the type 3 equations, even though there may be matrices that satisfy Eq. (13-19), none of these may be unitary; i.e., none may also satisfy Eq. (13-21). Recalling that the function of the unitary matrix $\left(U_{j i}\right)$ in Eq. (13-19) is to permute the columns of $\left(a_{k j}\right)$ into the columns of $\left(b_{k i}\right)$, with perhaps omissions and duplications, it is obvious that a solution of an equation of type 3 will exist only if for every column of $\left(b_{k i}\right)$ there is an identical column of $\left(a_{k j}\right)$, though the reverse need not hold.

For example, in the equation

$$
\left(\begin{array}{l}
0001 \\
0011 \\
0111 \\
1111
\end{array}\right) \otimes\left(U_{j i}\right)=\left(\begin{array}{l}
1000 \\
1100 \\
1110 \\
1111
\end{array}\right)
$$

$\left(U_{j i}\right)$ is obviously $\left(\begin{array}{l}0001 \\ 0010 \\ 0100 \\ 1000\end{array}\right) ;$ but $\left(\begin{array}{l}0001 \\ 0011 \\ 0110 \\ 1110\end{array}\right) \otimes\left(U_{j i}\right)=\left(\begin{array}{l}1000 \\ 1100 \\ 1110 \\ 1111\end{array}\right)$ has no unitary
solution, even though $\left(U_{j i}\right)=\left(\begin{array}{l}0001 \\ 1010 \\ 0100 \\ 1000\end{array}\right)$ (among others) will satisfy it.
In the type 2 equations, if $\left(U_{j i}\right)$ is a true permutation matrix, having 1 unit in each column and 1 unit in each row, then we see immediately that Eq. (13-20) can be applied to Eq. (13-22) to give
or

$$
\begin{aligned}
& \left.\left(a_{k j}^{\prime}\right)=\overline{\left(\overline{b_{k i}}\right.}\right) \otimes\left(U_{j i}\right)^{T}=\left(b_{k i}\right) \otimes\left(U_{j i}\right)^{T} \\
& \left(a_{j k}^{\prime}\right)=\left(U_{j i}\right) \otimes\left(b_{i k}\right)
\end{aligned}
$$

Comparing this with Eq. (13-24), we see that implication (13-25) reduces to an equality. Thus we see that, if $\left(U_{j i}\right)$ is a true permutation matrix, then Eq. (13-19) has a unique solution for $\left(a_{j k}\right)=\left(a_{k j}\right)^{T}$, given by Eq. (13-24). For example, for the equation

$$
\begin{aligned}
&\left(a_{k j}\right) \otimes\left(\begin{array}{l}
0100 \\
0001 \\
1000 \\
0010
\end{array}\right)=\left(\begin{array}{l}
1000 \\
1100 \\
1110 \\
1111
\end{array}\right) \\
&\left(a_{j k}\right)=\left(a_{j k}^{\prime}\right)=\left(a_{i k}^{*}\right)=\left(\begin{array}{c}
0100 \\
0001 \\
1000 \\
0010
\end{array}\right) \otimes\left(\begin{array}{l}
1111 \\
0111 \\
0011 \\
0001
\end{array}\right)=\left(\begin{array}{l}
0111 \\
0001 \\
1111 \\
0011
\end{array}\right) \quad \text { or } \quad\left(a_{k j}\right)=\left(\begin{array}{c}
0010 \\
1010 \\
1011 \\
1111
\end{array}\right)
\end{aligned}
$$

If ( $U_{j i}$ ) is not a true permutation matrix, then, as we have defined it, it will have some columns which are duplicates of others. In any product $\left(a_{k j}\right) \otimes\left(U_{j i}\right)=\left(b_{k i}\right)$ the columns of $\left(b_{k i}\right)$ will show the same duplications as those of $\left(U_{j i}\right)$. An equation of type 2 involving such a $\left(U_{j i}\right)$ can have no solution unless this condition on the duplication of the columns of $\left(b_{k i}\right)$ holds. It is obvious that, since ( $U_{j i}$ ) merely rearranges the columns of ( $a_{k j}$ ) in forming ( $b_{k i}$ ), a solution ( $a_{k j}$ ) can always be formed by rearranging the columns of $\left(b_{k i}\right)$, provided only that $\left(b_{k i}\right)$ has the same duplications of columns as does $\left(U_{j i}\right)$. Further, if the $j$ th row of $\left(U_{j i}\right)$ is all zeros, then the $j$ th column of $\left(a_{k j}\right)$ never appears in $\left(b_{k i}\right)$ so that this column of $\left(a_{k j}\right)$ is entirely arbitrary in the solution of a type 2 equation. For example, the equation

$$
\left(a_{k i}\right) \otimes\left(\begin{array}{l}
0001 \\
1010 \\
0000 \\
0100
\end{array}\right)=\left(\begin{array}{l}
0000 \\
0001 \\
0101 \\
1111
\end{array}\right)
$$

has a solution,

$$
\left(a_{k j}\right)=\left(\begin{array}{l}
00 \Phi 0 \\
10 \Phi 0 \\
10 \Phi 1 \\
11 \Phi 1
\end{array}\right)
$$

(where the $\Phi$ symbols indicate that the third column is arbitrary), while the equation

$$
\left(a_{k j}\right) \otimes\left(\begin{array}{l}
0001 \\
1010 \\
0000 \\
0100
\end{array}\right)=\left(\begin{array}{l}
0000 \\
0001 \\
1001 \\
1111
\end{array}\right)
$$

has no solution.

## EXERCISES

Find all solutions for the following equations:
(a) $\left(x_{k_{j}}\right) \otimes\left(\begin{array}{l}0100 \\ 1001 \\ 0000 \\ 0010\end{array}\right)=\left(\begin{array}{l}1011 \\ 1001 \\ 1101\end{array}\right)$.

## Solution

$$
\begin{aligned}
& \left(x_{k j}^{\prime}\right)=\overline{\left(\begin{array}{l}
0100 \\
0110 \\
0010
\end{array}\right) \otimes\left(\begin{array}{l}
0100 \\
1000 \\
0001 \\
0100
\end{array}\right)}=\overline{\left(\begin{array}{l}
1000 \\
1001 \\
0001
\end{array}\right)}=\left(\begin{array}{l}
0111 \\
0110 \\
1110
\end{array}\right) \\
& \left(x_{k j}^{*}\right)=\left(\begin{array}{l}
1011 \\
1001 \\
1101
\end{array}\right) \otimes\left(\begin{array}{l}
0100 \\
1000 \\
0001 \\
0100
\end{array}\right)=\left(\begin{array}{l}
0101 \\
0100 \\
1100
\end{array}\right)
\end{aligned}
$$

Hence the solutions are

(b) $\binom{1011}{0100} \otimes\left(x_{j k}\right)=\binom{10}{11}$.
(c) $\left(x_{k i}\right) \otimes\binom{0100}{1011}=\binom{1011}{1100}$.
(d) $\left(x_{k j}\right) \otimes\left(\begin{array}{l}0100 \\ 0001 \\ 0000 \\ 1010\end{array}\right)=\left(\begin{array}{l}0001 \\ 0001 \\ 0101 \\ 1011\end{array}\right)$.
(e) Derive equations corresponding to the numbered equations of this section for the matrix equation $\left(V_{k_{i}}\right) \otimes\left(a_{j i}\right)=\left(b_{k i}\right)$, where $\left(V_{k_{i}}\right)$ is a matrix having just 1 unit in each row (cf. footnote on page 434).

## 13-6. Derivation of the Fundamental Matrix Equation and the Fundamental Formulas

The Pseudopermutation Transformation. The derivations of the fundamental formulas are based on the antecedence formula for problems of type 1 , which is

$$
\begin{equation*}
\left(F_{k j}\right) \otimes\left(R_{j i}\right)=\left(E_{k i}\right) \tag{13-32}
\end{equation*}
$$

For this reason Eq. (13-32) is called the fundamental matrix equation relating Boolean matrices with digital-circuit design. To see how this formula arises, let us first consider $F$ to be of the form $F=F\left(f_{1}, f_{2}, f_{3}\right)$, where we have omitted the $X_{1}, \ldots, X_{K}$ of the more general formulation. In this case the formula for type 1 reduced to $\left(F_{0 j}\right) \otimes\left(R_{j i}\right)=\left(E_{0 i}\right)$, where ( $F_{0 j}$ ) and ( $E_{0 i}$ ) are matrices with only one row. More specifically they are the designation numbers themselves; that is, $\left(F_{0 j}\right)=\# F$, and $\left(E_{0 i}\right)=\# E$. Then we want to show that $\# F \otimes\left(R_{j i}\right)=\# E$.

This equation follows clearly from two simple observations. The first observation is merely a restatement of the meaning of a designation number with respect to the standard basis. Whenever the signal values (that is, 1 or 0 ) in the input wires to a circuit correspond to column $p$ of the basis, then the signal value ( 1 or 0 ) in the output wire is the value of the $p$ th position of the designation number of the output wire. For example, if $F=\bar{f}_{1} \cdot \bar{f}_{2}+f_{1} \cdot f_{3}$, then we have with respect to $b\left[f_{1}, f_{2}, f_{3}\right]$

| $j$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}=$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\# f_{2}=$ |  |  |  |  |  |  |  |  |
| $\# f_{3}=$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| $\# F$ | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |
| $\#$ | 1 | 0 | 0 | 0 | 1 | 0 | 1 |  |

Then if the input values correspond to column zero of the basis, i.e., $\begin{aligned} & \mathbf{0} \\ & \mathbf{0},\end{aligned}$ then the output value on wire $F$ will be a unit, and so forth.

The second observation is essentially the same, except that we are considering more than one output wire, i.e., more than one circuit with the same inputs. For example, let $f_{1}=A_{2}+\bar{A}_{3}, f_{2}=\left(A_{1}+A_{2}\right) \cdot \bar{A}_{3}$, and $f_{3}=A_{1} \cdot A_{2}+\left(A_{1}+A_{2}\right) \cdot A_{3}$. Then we have with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$ the array for $f_{1}, f_{2}, f_{3}$ shown in Fig. 13-9. In this case, for example, if the input values of $A_{1}, A_{2}, A_{3}$ correspond to column 4 of $b\left[A_{1}, A_{2}, A_{3}\right]$, i.e., to $\underset{1}{0}$, then the set of output values of $f_{1}, f_{2}$, and $f_{3}$ will be found in position 4 of each of $\# f_{1}, \# f_{2}$, and $\# f_{3}$, namely, ${\underset{0}{0} \text {. In other }}_{0}^{0}$. words, column 4 of $b\left[A_{1}, A_{2}, A_{3}\right]$ corresponds to column 0 of $b\left[f_{1}, f_{2}, f_{3}\right]$. To find the value of the fourth position of the $\# F$ with respect to $b\left[A_{1}\right.$, $\left.A_{2}, A_{3}\right]$, observe that column 4 of $b\left[A_{1}, A_{2}, A_{3}\right]$ corresponds to column 0 of $b\left[f_{1}, f_{2}, f_{3}\right]$, which in our example corresponds to a unit in the zeroth
position of $\# F$ with respect to $b\left[f_{1}, f_{2}, f_{3}\right]$. Hence we conclude that the value of the fourth position of $\# F$ with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$ (that is, the fourth position of $\# E$ ) is a unit.

Summarizing, \#E (that is, \#F with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$ ) can be found from $\# F$ (with respect to $b\left[f_{1}, f_{2}, f_{3}\right]$ ) by rearranging the positions of $\# F$. For our example we have found above that the value of position 0 now becomes the value of position 4 in the rearrangement. Similarly the rest of the positions are rearranged as in Fig. 13-10. Observe that


Fig. 13-9. Array for $f_{1}, f_{2}$, and $f_{3}$.


Fig. 13-10. Rearrangement of the positions of $\# F$.
such a rearrangement can be made with a unitary or pseudopermutation matrix [which we call ( $R_{j i}$ )], having just 1 unit in each column (see Secs. $11-10$ and $13-5$ ). For our example we have

$$
\# F \otimes\left(R_{j i}\right)=\left(\begin{array}{ll}
1100 & 0101
\end{array}\right) \otimes\left(\begin{array}{ll}
0000 & 1000 \\
1000 & 0000 \\
0000 & 0000 \\
0110 & 0000 \\
0000 & 0100 \\
0000 & 0011 \\
0000 & 0000 \\
0001 & 0000
\end{array}\right)=\left(\begin{array}{ll}
1001 & 1011
\end{array}\right)=\# E
$$

Such an $R$ matrix can obviously be found for any other rearrangement which might be required and depends only on the form of the functions $f_{1}\left(A_{1}, A_{2}, A_{3}, \ldots\right), f_{2}\left(A_{1}, A_{2}, A_{3}, \ldots\right.$. , etc.

The Fundamental Equation. In the more general case, where

$$
F=F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right)
$$

only the variables $f_{1}, \ldots, f_{J}$ are affected. Observe that in a standard basis $b\left[f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right]$ the first $J$ rows consist of the standard basis $b\left[f_{1}, \ldots, f_{J}\right]$ repeated $2^{K}$ times. Thus we can subdivide the basis $b\left[f_{1}, \ldots, f_{J}, X_{1}, . . ., X_{K}\right]$, and consequently $\# F_{1}$, into $2^{K}$ groups. A rearrangement of the columns of $b\left[f_{1}, \ldots, f_{J}\right]$ to correspond to an array of the designation numbers of the $f_{1}, \ldots, f_{J}$, such as is shown in Fig. 13-9, has the effect of rearranging the bits of $\# F$ only within each of these groups. Furthermore, the bits with every group undergo the
same rearrangement. We recall that a unitary matrix such as $\left(R_{j i}\right)$ has the effect of rearranging the columns of a matrix which it multiplies on the right; i.e., multiplying by ( $R_{j i}$ ) rearranges the bits within each row of a matrix. Thus we form a matrix, called ( $F_{k j}$ ), by folding $\# F$ so that its group becomes individual rows, multiply by the proper ( $R_{j i}$ ) to rearrange the bits within the rows, and unfold the resulting matrix to form a new number. This number is the required $\# E$, since it represents the necessary rearrangement of $\# F$; thus Eq. (13-32) is justified (see page 420).

The Fundamental Formulas. The fundamental equation is of course a unitary equation, and hence all the results of Sec. 13-5 apply. Substituting the matrices $\left(F_{k j}\right),\left(R_{j i}\right)$, and $\left(E_{k i}\right)$ for matrices $\left(a_{k j}\right)$, $\left(U_{j i}\right)$, and ( $b_{k i}$ ), respectively, in Eqs. (13-19), (13-21), (13-23), (13-24), (13-26), and (13-28), we find the six fundamental formulas of Eq. (13-4). Comparison of Secs. 13-3 and 13-5 will show that the solutions to Eq. (13-32) are the antecedence solutions, and solutions to $\left(\bar{F}_{k j}\right) \otimes\left(R_{j i}\right)=\left(\bar{E}_{k i}\right)$ [see, for example, Eq. (13-21)] are consequence solutions. In the fundamental formulas, Eq. (13-4), we have used the subscripts $a$ and $c$ to distinguish between the determinations of matrices corresponding to antecedence and consequence solutions, which were denoted by the prime. (') and asterisk (*) in Sec. 13-5.

## EXERCISES

(a) Describe the meaning of Eq. (13-25) in terms of the type 2 circuit-design problem.
(b) Describe the meaning of Eq. (13-31) in terms of the type 3 circuit-design problem.
(c) Using the methods of Secs. 13-5 and 13-6, prove the assertions made in Sec. 13-3 under Properties of the Solutions.

## 13-7. Additional Topics $\dagger$

a. Operations and Properties of Boolean Matrices. Besides the operation of Boolean matrix multiplication defined in Sec. 11-11, we utilize in these chapters two matrix relationships (equality and implication), four matrix operations (and, or, not, and transposition), and three matrix properties (associativity, product transposition, and invariance of implication under multiplication):

Equality. $\quad\left(A_{i j}\right)=\left(B_{i j}\right)$ if $A_{i j}=B_{i j}$ in every position. That is, $\left(A_{i j}\right)$ and ( $B_{i j}$ ) have units and zeros in exactly the same positions.

Implication. $\left(A_{i j}\right) \rightarrow\left(B_{i j}\right)$ if $A_{i j} \rightarrow B_{i j}$ in every position. That is, $\left(B_{i j}\right)$ has units in at least every position in which $\left(A_{i j}\right)$ has units, for example, $\binom{00}{01} \rightarrow\binom{11}{01}$. As with the designation numbers $\left(A_{i j}\right) \rightarrow\left(B_{i j}\right)$ and $\left(B_{i j}\right) \rightarrow\left(A_{i j}\right)$ only if $\left(A_{i j}\right)=\left(B_{i j}\right)$.

And (logical multiplication). $\left(A_{i j}\right) \cdot\left(B_{i j}\right)=\left(C_{i j}\right)$ means that $C_{i j}=A_{i j} \cdot B_{i j}$ for every position. That is, the logical product has units only where $\left(A_{i j}\right)$ and ( $B_{i j}$ ) both have units; for example, $\binom{01}{11} \cdot\binom{11}{10}=\binom{01}{10}$.
$\dagger$ The material of Additional Topic $b$ was developed by William Ruthven Smith and James Bruce Wilson, and that of Additional Topics $c, d$, and $e$ by William Ruthven Smith, when they were graduate students of the author's at the George Washington University (see W. R. Smith, Master's thesis, June, 1959).

Or (logical addition). $\left(A_{i j}\right)+\left(B_{i j}\right)=\left(C_{i j}\right)$ means that $C_{i j}=A_{i j}+B_{i j}$ for every position. That is, the logical sum has units wherever either $\left(A_{i j}\right)$ or ( $B_{i j}$ ) or both have units; for example, $\binom{01}{01}+\binom{01}{10}=\binom{01}{11}$.

Not (complementation). $\quad\left(B_{i j}\right)=\overline{\left(A_{i j}\right)}$ means $B_{i j}=\bar{A}_{i j}$ for every position. That is, $\left(\overline{A_{i j}}\right)$ has zeros where ( $A_{i j}$ ) has units, units where ( $A_{i j}$ ) has zeros, for example, $\overline{\binom{01}{00}}=\binom{10}{11}$. Because of the definition we may write $\overline{\left(A_{i j}\right)}=\left(\bar{A}_{i j}\right)$ (that is, the complement of the matrix equals the matrix of the complements).

Transposition (denoted here by a superscript $T$ ). $\quad\left(A_{i j}\right)^{T}=\left(B_{i j}\right)$ means $B_{i j}=A_{i i}$ for each value of $i$ and $j$. That is, the transpose of a matrix is formed by interchanging its rows with its columns, for example, $\left(\begin{array}{l}11 \\ 01 \\ 10\end{array}\right)^{T}=\binom{101}{110}$.

Notice that equality, implication, and logical multiplication and addition are defined only between matrices of the same dimensions. Complementation of a matrix results in a matrix of the same dimension, while transposition results in a matrix whose width is the former depth and whose depth is the former width.
The following three properties are easily verified from the definitions of the operations involved:

## Associativity

$$
\begin{gathered}
\left(\left(A_{i j}\right) \cdot\left(B_{i j}\right)\right) \cdot\left(C_{i j}\right)=\left(A_{i j}\right) \cdot\left(\left(B_{i j}\right) \cdot\left(C_{i j}\right)\right)=\left(A_{i j}\right) \cdot\left(B_{i j}\right) \cdot\left(C_{i j}\right) \\
\left(\left(A_{i j}\right)+\left(B_{i j}\right)\right)+\left(C_{i j}\right)=\left(A_{i j}\right)+\left(\left(B_{i j}\right)+\left(C_{i j}\right)\right)=\left(A_{i j}\right)+\left(B_{i j}\right)+\left(C_{i j}\right) \\
\left(\left(A_{h i}\right) \otimes\left(B_{i j}\right)\right) \otimes\left(C_{j k}\right)=\left(A_{h i}\right) \otimes\left(\left(B_{i j}\right) \otimes\left(C_{j k}\right)\right)=\left(A_{h i}\right) \otimes\left(B_{i j}\right) \otimes\left(C_{j k}\right)
\end{gathered}
$$

Product transposition

$$
\left(\left(A_{h i}\right) \otimes\left(B_{i j}\right) \otimes\left(C_{j k}\right)\right)^{T}=\left(C_{j k}\right)^{T} \otimes\left(B_{i j}\right)^{T} \otimes\left(A_{h i}\right)^{T}
$$

That is, the transpose of the product of matrices is equal to the product of the transposes of the factor matrices, taken in reverse order.

Invariance of implication under multiplication. If
and

$$
\begin{aligned}
\left(A_{i j}\right) & \rightarrow\left(C_{i j}\right) \\
\left(B_{j k}\right) & \rightarrow\left(D_{j k}\right) \\
\left(A_{i j}\right) \otimes\left(B_{j k}\right) & \rightarrow\left(C_{i j}\right) \otimes\left(D_{i k}\right)
\end{aligned}
$$

then
Obviously the implication of the conclusion holds if either implication of the hypotheses is equality.

## References

Hohn, F. E., and R. L. Schissler: Boolean Matrices and the Design of Combinational Relay Switching Circuits, Bell System Tech. J., vol. 34, pp. 201-202, 1955.
Luce, R. D.: Note on Boolean Matrix Theory, Proc. Am. Math. Soc., vol. 3, pp. 382-388, 1952.
b. Generation of $E$ and $F$ Matrices by Direct Matrix Multiplication. Consider an $E$ function of the form

$$
E\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)=P\left(X_{1} \ldots, X_{K}\right) \cdot Q\left(A_{1}, \ldots, A_{I}\right)
$$

It is clear from the manner in which ( $E_{k i}$ ) is formed that in such a case

$$
\left(E_{k i}\right)=(\# P)^{r} \otimes(\# Q)
$$

For example, if $P=X_{1}+\bar{X}_{2}$ and $Q=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{2}$, then

$$
(1101)^{T} \otimes(0110)=\left(\begin{array}{c}
0110 \\
0110 \\
0000 \\
0110
\end{array}\right)=\left(E_{k i}\right)
$$

In fact, if $E=P_{1} Q_{1}+P_{2} Q_{2}+\cdots$, where $P_{m}=P_{m}\left(X_{1}, \ldots, X_{K}\right)$ and $Q_{m}=$ $Q_{m}\left(A_{1}, \ldots, A_{I}\right)$, then it follows that

$$
\left(E_{k i}\right)=\left(\begin{array}{l}
\# P_{1} \\
\# P_{2} \\
\cdot \cdot .
\end{array}\right)^{T} \otimes\left(\begin{array}{l}
\# Q_{1} \\
\# Q_{2} \\
\cdots \cdot .
\end{array}\right)
$$

For example, if $E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$, then

$$
\begin{aligned}
\left(E_{k i}\right) & =\left(\begin{array}{l}
\# I \\
\# X_{1} \\
\# X_{2}
\end{array}\right)^{T} \otimes\left(\begin{array}{l}
\# A_{1} \cdot A_{2} \\
\# \bar{A}_{2} \cdot A_{3} \\
\#\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)
\end{array}\right)=\left(\begin{array}{l}
1111 \\
0101 \\
0011
\end{array}\right)^{T} \otimes\left(\begin{array}{ll}
0001 & 0001 \\
0000 & 1100 \\
0111 & 0011
\end{array}\right) \\
& =\left(\begin{array}{ll}
0001 & 0001 \\
0001 & 1101 \\
0111 & 0011 \\
0111 & 1111
\end{array}\right)
\end{aligned}
$$

as in Sec. 13-2. (Note that the numbers for the functions are formed from $b\left[X_{1}, \ldots, X_{K}\right]$ and $b\left[A_{1}, \ldots, A_{I}\right]$, respectively.)

We can generalize these results. If $E=W\left[S(A, X), T(A, X)\right.$, . . .], then $\left(E_{k i}\right)=$ $W\left[\left(S_{k i}\right),\left(T_{k i}\right)\right.$, . .]. That is, if the function $E$ is expressed as a function of subfunctions $S(A, X), T(A, X)$, etc., then the matrices for the subfunctions can be formed as above and these combined according to the operations of the main function to form the matrix for $E$. For example, consider

$$
E=\overline{\left(A_{1}+X_{1} \cdot \bar{X}_{2}\right) \cdot\left(A_{2} \cdot\left(\bar{X}_{1}+X_{2}\right)\right)}
$$

We have

$$
\left(E_{k i}\right)=\overline{\left\{\left[(\# I)^{T} \otimes\left(\# A_{1}\right)\right]+\left[\left(\# X_{1} \bar{X}_{2}\right)^{T} \otimes(\# I)\right]\right\} \cdot\left\{\left(\#\left(\bar{X}_{1}+X_{2}\right)\right)^{T} \otimes\left(\# A_{2}\right)\right\}}
$$

On a different grouping of the terms, we could have equivalently

$$
\left(E_{k i}\right)=\overline{\left[\binom{\# I}{\# X_{1} \cdot X_{2}}^{T} \otimes\binom{\# A_{1}}{\# I}\right] \cdot\left[\left(\#\left(\bar{X}_{1}+X_{2}\right)\right)^{T} \otimes\left(\# A_{2}\right)\right]}
$$

and so forth.
These results of course also hold for the generation of the $F$ matrix. For example, consider $F=\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot \bar{f}_{2}+X_{2} \cdot f_{2} \cdot \bar{f}_{3}$. Here

$$
\begin{aligned}
\left(F_{k j}\right) & =\left(\begin{array}{c}
\# I \\
\# X_{1} \\
\# X_{2}
\end{array}\right)^{T} \otimes\left(\begin{array}{l}
\# \bar{f}_{1} \cdot f_{3} \\
\# f_{1} \cdot \bar{f}_{2} \\
\# f_{2} \cdot \bar{f}_{3}
\end{array}\right)=\left(\begin{array}{l}
1111 \\
0101 \\
0011
\end{array}\right)^{T} \otimes\left(\begin{array}{ll}
0000 & 1010 \\
0100 & 0100 \\
0011 & 0000
\end{array}\right) \\
& =\left(\begin{array}{ll}
0000 & 1010 \\
0100 & 1110 \\
0011 & 1010 \\
0111 & 1110
\end{array}\right)
\end{aligned}
$$

us in Sec. 13-2.
c. Finding ( $R_{i i}$ ) Directly in Type 3 Problems. From Eq. (13-31) we observe that $\left(R_{j i}\right)=\left(R_{i i}\right)_{a} \cdot\left(R_{j i}\right)_{c}$ for problems of type 3. However, the same ( $R_{i i}$ ) can be
obtained directly from $\left(F_{k j}\right)$ and ( $E_{k i}$ ) provided that we introduce a new kind of matrix-multiplication operation, called the theta product, defined as follows: $\left(S_{j i}\right)=$ $\left(P_{j k}\right) \Theta\left(Q_{k i}\right)$ if and only if for each position

$$
\begin{aligned}
S_{j i} & =\prod_{k}\left(P_{j k}=Q_{k i}\right) \\
& =\prod_{k}\left(P_{j k} \cdot Q_{k i}+\bar{P}_{j k} \cdot \bar{Q}_{k i}\right)
\end{aligned}
$$

For observe that
or

$$
\left(R_{j i}\right)=\left(R_{i i}\right)_{a} \cdot\left(R_{i i}\right)_{c}=\overline{\left(F_{k j}\right)^{T} \otimes\left(\bar{E}_{k i}\right)} \cdot \overline{\left(\bar{F}_{k j}\right)^{T} \otimes\left(E_{k i}\right)}
$$

$$
R_{i i}=\overline{\sum_{k} F_{i k} \cdot \bar{E}_{k i}} \cdot \overline{\sum_{k} \bar{F}_{i k} \cdot E_{k i}}
$$

which by De Morgan's rules becomes

$$
\begin{aligned}
R_{j i} & =\prod_{k}\left(\bar{F}_{j k}+E_{k i}\right) \cdot \prod_{k}\left(F_{j k}+\bar{E}_{k i}\right) \\
& =\prod_{k}\left(\bar{F}_{j k}+E_{k i}\right) \cdot\left(F_{j k}+\stackrel{\rightharpoonup}{E}_{k i}\right) \\
& =\prod_{k}\left(F_{i k} \cdot E_{k i}+\bar{F}_{j k} \cdot \bar{E}_{k i}\right) \\
& =\prod_{k}\left(F_{j k}=E_{k i}\right)
\end{aligned}
$$

Thus in terms of our theta matrix product

$$
\left(R_{j i}\right)=\left(F_{k j}\right)^{T} \theta\left(E_{k i}\right)
$$

which is the desired result.
$d_{i}$ Finding ( $R_{i i}$ ) for a Set of Given Functions $f_{1}, \ldots, f_{j}$ by Theta Matrix Multiplication. From the concept of type 1 problems observe that

$$
\# f_{1}\left(b\left[f_{1}, \ldots, f_{J}\right]\right) \otimes\left(R_{i i}\right)=\# f_{1}\left(A_{1}, \ldots, A_{I}\right)
$$

and likewise for $f_{2}, \ldots, f_{J}$ Hence

$$
\left(b\left[f_{1}, \ldots, f_{J}\right]\right) \otimes\left(R_{i i}\right)=\left(\begin{array}{l}
\# f_{1}\left(A_{1}, \ldots, A_{I}\right) \\
\# f_{2}\left(A_{1}, \ldots, \ldots, A_{I}\right) \\
\cdots \cdots, \ldots,)^{2} \\
\# f_{J}\left(A_{1}, \ldots, A_{I}\right.
\end{array}\right)
$$

Now if $b\left[f_{1}, \ldots, f_{J}\right]$ and $\# f_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, \# f_{J}\left(A_{1}, \ldots, A_{I}\right)$ are known, finding ( $R_{j i}$ ) is a type 3 problem. Hence

$$
\left(R_{i i}\right)=\left(b\left[f_{1}, \ldots, f_{J}\right]\right)^{T} \Theta\left(\begin{array}{l}
\# f_{1}\left(A_{1}, \ldots, A_{I}\right) \\
\# f_{2}\left(A_{1}, \ldots, A_{I}\right) \\
\cdots \ldots ., \ldots .)_{1} \\
\# f_{J}\left(A_{1}, \ldots, A_{I}\right)
\end{array}\right)
$$

For example, suppose that

$$
\begin{aligned}
& f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} \\
& f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} \\
& f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}
\end{aligned}
$$

Sec. 13-7] matrix equations and fundamental formulas
Then with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$ we have

$$
\# f_{1}=0100 \quad 1110 \quad \# f_{2}=0111 \quad 0010 \quad \text { and } \quad \# f_{3}=0001 \quad 1101
$$

Substituting into our formula,

$$
\begin{aligned}
\left(R_{j i}\right) & =\left(\begin{array}{ll}
0101 & 0101 \\
0011 & 0011 \\
0000 & 1111
\end{array}\right)^{T} \Theta\left(\begin{array}{ll}
0100 & 1110 \\
0111 & 0010 \\
0001 & 1101
\end{array}\right) \\
& =\left(\begin{array}{l}
000 \\
100 \\
010 \\
110 \\
001 \\
101 \\
011 \\
111
\end{array}\right) \Theta\left(\begin{array}{ll}
0100 & 1110 \\
0111 & 0010 \\
0001 & 1101
\end{array}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right)
\end{aligned}
$$

as in Sec. 13-2.
e. All Solutions to the Boolean Matrix Equation. Given the matrix equation

$$
\left(a_{i k}\right) \otimes\left(x_{k j}\right)=\left(b_{i j}\right)
$$

—where $i=0,1, \ldots, I ; j=0,1, \ldots, J ;$ and $k=0,1, \ldots, K$-first form

$$
\left(\dot{S}_{m j}\right)=\left\{\left(a_{i k}\right) \otimes\left(b\left[X_{0}, X_{1}, \ldots, X_{K}\right]\right)\right\}^{T} \theta\left(b_{i j}\right)
$$

When ( $S_{m_{j}}$ ) is interpreted as an $R$-type matrix, all solutions to the matrix equation can be found. For example, consider

$$
\binom{101}{011} \otimes\left(x_{k j}\right)=\binom{10}{11}
$$

Here $k=0,1,2$, and hence $\left(b\left[X_{0}, X_{1}, X_{2}\right]\right)=\left(\begin{array}{ll}0101 & 0101 \\ 0011 & 0011 \\ 0000 & 1111\end{array}\right)$, that is, just the basis for $K+1=3$ variables. Thus we have from our formula

$$
\begin{aligned}
& \left(S_{m i}\right)=\left\{\binom{101}{011} \otimes\left(\begin{array}{ll}
0101 & 0101 \\
0011 & 0011 \\
0000 & 1111
\end{array}\right)\right\}^{T} \Theta\binom{10}{11} \\
& =\left(\begin{array}{ll}
0101 & 1111 \\
0011 & 1111
\end{array}\right)^{T} \Theta\binom{10}{11} \\
& j 01
\end{aligned}
$$

From ( $S_{m i}$ ) we write a result array for $\left(x_{k j}\right)$, using the basis columns indicated by $m$ :

|  | $j=0$ | $j=1$ |
| :---: | :---: | :---: |
| $k=0$ | $1,0,1,0,1$ | 0 |
| $k=1$ | $1,0,0,1,1$ | 1 |
| $k=2$ | $0,1,1,1,1$ | 0 |

This gives rise to five matrices,

$$
\left(\begin{array}{l}
10 \\
11 \\
00
\end{array}\right) \quad\left(\begin{array}{l}
00 \\
01 \\
10
\end{array}\right) \quad\left(\begin{array}{l}
10 \\
01 \\
10
\end{array}\right) \quad\left(\begin{array}{l}
00 \\
11 \\
10
\end{array}\right) \quad \text { and } \quad\left(\begin{array}{l}
10 \\
11 \\
10
\end{array}\right)
$$

Note that in general $m=0,1, \ldots, 2^{K}-1$.
To see why the formula holds, observe that the matrix equation is really equivalent to $J+1$ sets each of $I+1$ equations. The equations for $j=0$ are, for example,

$$
\begin{aligned}
& a_{00} \cdot x_{00}+a_{01} \cdot x_{10}+\cdots+a_{0 K} \cdot x_{K 0}=b_{00} \\
& a_{10} \cdot x_{00}+a_{11} \cdot x_{10}+\cdots+a_{1 K} \cdot x_{K 0}=b_{10} \\
& a_{I 0} \cdot x_{00}+a_{I 1} \cdot x_{10}+\cdots+a_{I K} \cdot x_{K 0}=b_{I 0}
\end{aligned}
$$

Now note that the columns of the basis $b\left[X_{0}, \ldots, X_{K}\right]$ are all possible combinations of values that the $x_{00}, x_{10}, \ldots, x_{K 0}$ could possibly take. Thus

$$
\left(a_{00} a_{01} \cdots a_{0 K}\right) \otimes\left(b\left[x_{0}, \ldots, x_{K}\right]\right)=\left(r_{00} r_{01} \cdots r_{0 m}\right)
$$

gives the values $r_{0 k}$ which the left-hand side of the zeroth equation has when the $x_{00}, x_{10}, \ldots, x_{K 0}$ take on the combination of values given by the $k$ th column of the basis. Similarly the values of the left-hand sides of all the equations for each column of the basis can be determined from

$$
\left(a_{i k}\right) \otimes\left(b\left[x_{0}, \ldots, x_{K}\right]\right)=\left(R_{i m}\right)
$$

Consider the matrix equation

$$
\left(a_{i k}\right) \otimes\left(x_{k 0}\right)=\left(b_{i 0}\right)
$$

(i.e., just the first set of equations written out explicitly above). A column vector $\left(x_{k 0}\right)$ that satisfies this equation is simply that basis column corresponding to a column of ( $R_{i m}$ ) identical to the column $\left(b_{i 0}\right)$. Another way of putting this is to form

$$
\left(S_{m 0}\right)=\left(R_{i m}\right)^{T} \Theta\left(b_{i 0}\right)
$$

and then interpret the row number of a unit in ( $S_{m 0}$ ) as the position of the basis column that satisfies the equation and hence is ( $x_{k 0}$ ). Clearly this argument can be extended to include all the columns of $\left(b_{i j}\right)$, and our formula is proved.

If the Boolean matrix equation is

$$
\left(x_{i k}\right) \otimes\left(a_{k j}\right)=\left(b_{i j}\right)
$$

then

$$
\left(S_{m i}\right)=\left\{\left(b\left[X_{1}, \ldots, X_{K]}\right]\right)^{T} \otimes\left(a_{k i}\right)\right\} \Theta\left(b_{i j}\right)^{T}
$$

where the direct interpretation of $\left(S_{m i}\right)$ gives $\left(x_{k i}\right)=\left(x_{i k}\right)^{T}$. For example, let

$$
\begin{aligned}
& \left(x_{i k}\right) \otimes\binom{010}{010}=\left(\begin{array}{l}
000 \\
000 \\
010
\end{array}\right) \\
& \left(S_{m i}\right)=\left\{\binom{0101}{0011}^{T} \otimes\binom{010}{010}\right\} \Theta\left(\begin{array}{l}
000 \\
000 \\
010
\end{array}\right)^{T} \\
& =\left\{\left(\begin{array}{l}
00 \\
10 \\
01 \\
11
\end{array}\right) \otimes\binom{010}{010}\right\} \Theta\left(\begin{array}{l}
000 \\
001 \\
000
\end{array}\right) \\
& \text { i } 012 \\
& =\left(\begin{array}{l}
000 \\
010 \\
010 \\
010
\end{array}\right) \ominus\left(\begin{array}{l}
000 \\
001 \\
000
\end{array}\right)=\begin{array}{c}
m \\
0 \\
2
\end{array}\left(\begin{array}{c}
110 \\
001 \\
001 \\
001
\end{array}\right)
\end{aligned}
$$

Then

Thus $\left(x_{k i}\right)=\binom{001}{000},\binom{000}{001},\binom{001}{001}$, or the solutions are

$$
\left(x_{i k}\right)=\left(\begin{array}{c}
00 \\
00 \\
10
\end{array}\right) \quad\left(\begin{array}{c}
00 \\
00 \\
01
\end{array}\right) \quad\left(\begin{array}{c}
00 \\
00 \\
11
\end{array}\right)
$$

## APPLICATIONS OF MATRIX EQUATIONS IN CIRCUIT DESIGN

## 14-1. Type 1 Problems in Circuitry

Introduction. In the previous chapter we have described a general problem in the logical design of digital circuitry and have shown how to solve it by means of Boolean matrices. In this present chapter we give examples of the applications of that problem under a variety of circumstances.

Substitution. We shall consider first the solution to the type 1 problem of Sec. $13-1$, with $f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}, f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}$, and $f_{3}=A_{1} \cdot A_{2}+\overline{A_{2}} \cdot A_{3}$ and $F=\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot \bar{f}_{2}+X_{2} \cdot f_{2} \cdot f_{3}$. If we did not know about our computational method, we would substitute for $f_{1}, f_{2}$, and $f_{3}$ in $F$, obtaining $E$,

$$
\begin{aligned}
& \overline{\left(A_{1} \cdot \bar{A}_{2}+A_{1} \cdot A_{3}\right)} \cdot\left(A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}\right) \\
& +X_{1} \cdot\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}\right) \cdot \overline{\left(\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}\right)} \\
& \quad+X_{2} \cdot\left(\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}\right) \cdot \overline{\left(A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}\right)}
\end{aligned}
$$

and try to simplify this result. Or, better yet, we might find the designation number of $E$ with respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ and from this find a simple form. However, we can find the designation number of $F$ directly without performing the substitution, by using the formula for problems of type 1. To illustrate the process, we first find ( $R_{j i}$ ) corresponding to $f_{1}, f_{2}$, and $f_{3}$. This was done in Sec. 13-2 for the given $f_{1}, f_{2}$, and $f_{3}$ :

$$
\left(R_{i i}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right)
$$

The matrix $\left(F_{k j}\right)$ for our $F$ was also found in Sec. 13-2 and is

$$
\left(F_{k_{i}}\right)=\left(\begin{array}{ll}
0000 & 1010 \\
0100 & 1110 \\
0011 & 1010 \\
0111 & 1110
\end{array}\right)
$$

whence, to find $\left(E_{k i}\right)$, we use the formula for type 1 problems,

$$
\begin{aligned}
\left(F_{k j}\right) \otimes\left(R_{j i}\right) & =\left(\begin{array}{ll}
0000 & 1010 \\
0100 & 1110 \\
0011 & 1010 \\
0111 & 1110
\end{array}\right) \otimes\left(\begin{array}{ll}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right) \\
& =\left(\begin{array}{ll}
0001 & 0001 \\
0001 & 1101 \\
0111 & 0011 \\
0111 & 1111
\end{array}\right)=\left(E_{k i}\right)
\end{aligned}
$$

From this matrix,

$$
\# E=0001 \quad 0001 \quad 0001 \quad 1101 \quad 0111 \quad 0011 \quad 0111 \quad 1111
$$

which in Sec. 13-2 was seen to correspond to

$$
E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)
$$

Often, when it is desired to check $E$ in problems of types 2 and 3 , the matrices ( $R_{j i}$ ) and ( $F_{k j}$ ) already have been obtained. The formula for type 1 problems then becomes a valuable tool, as will be illustrated in subsequent sections.

## EXERCISES

(a) Let

$$
\begin{aligned}
F\left(f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right) & =\left(f_{1} \cdot \bar{X}_{2}+\bar{f}_{2} \cdot X_{1}\right) \cdot\left(f_{3} \cdot \bar{X}_{1}+\bar{f}_{2} \cdot \bar{X}_{2}\right) \\
f_{1} & =\left(A_{1}+A_{2}\right) \cdot A_{3} \\
f_{2} & =\left(A_{1} \cdot \bar{A}_{2} \cdot A_{3}+\bar{A}_{1} \cdot A_{2} \cdot \bar{A}_{3}\right) \\
f_{3} & =\left(A_{2} \cdot \bar{A}_{3}+A_{1} \cdot \bar{A}_{2}\right)
\end{aligned}
$$

Find $E=F\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)$.
(b) Let

$$
\begin{aligned}
& F=f_{1} \cdot \bar{f}_{2}+f_{2} \cdot \bar{f}_{3}+f_{3} \cdot \bar{f}_{1} \\
& f_{1}=A_{1} \cdot \bar{A}_{2}+A_{2} \cdot \bar{A}_{3} \\
& f_{2}=A_{2} \cdot \bar{A}_{3}+A_{3} \cdot \bar{A}_{1} \\
& f_{3}=A_{3} \cdot \bar{A}_{1}+A_{1} \cdot \bar{A}_{2}
\end{aligned}
$$

Find $E=F\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)$.

## 14-2. Type 2 Problems in Circuitry

Constraints. The determination of logical dependence or constraints between given elements has been mentioned as a special case of the determination of consequence solutions to a type 2 problem. If $f_{1}\left(A_{1}, \ldots, A_{I}\right), f_{2}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)$ are $J$ given functions, the constraint between them is a function $C\left(f_{1}, f_{2}, \ldots, f_{n}\right)$ such that with respect to $b\left[A_{1}, \ldots, A_{I}\right]$ we have

$$
C\left[f_{1}\left(A_{1}, \ldots, A_{I}\right), f_{2}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)\right]=I
$$

Observe the elementary fact that if $I \rightarrow W\left(A_{1}, \ldots, A_{I}\right)$ then $I=W$. Hence we can write the $C$ as a constraint if

$$
I \rightarrow C\left[f_{1}\left(A_{1}, \ldots, A_{I}\right), f_{2}\left(A_{1}, \ldots, A_{I}\right), \ldots, f_{J}\left(A_{1}, \ldots, A_{I}\right)\right]
$$

Thus the constraint $C$ is found as a consequence solution of type 2 in the special case where $E$ is $I$; it is therefore determined by

$$
\left(R_{j i}\right) \otimes\left(I_{i k}\right)=\left(C_{j k}\right)
$$

where $\left(C_{j k}\right)$ is used instead of $\left(F_{j k}\right)$ to emphasize the special nature of the formula. For example, suppose that

$$
\begin{aligned}
& f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} \\
& f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3} \\
& f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}
\end{aligned}
$$

To determine the constraint between $f_{1}, f_{2}$, and $f_{3}$, first form ( $R_{j i}$ ), which in this case has been determined in Sec. 13-2. The range of $i$ and $j$ is given by the number of elements $A_{i}$ and functions $f_{j}$, but the range of $k$ depends on the particular problem under consideration. In our case let $k=0$ only, whence we have

$$
\left(R_{j i}\right) \otimes\left(I_{i k}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right) \otimes\left(\begin{array}{l}
1 \\
1 \\
1 \\
1 \\
1 \\
1 \\
1 \\
1
\end{array}\right)=\left(\begin{array}{l}
1 \\
0 \\
1 \\
1 \\
1 \\
1 \\
1 \\
0
\end{array}\right)=\left(C_{j k}\right)
$$

Therefore $\# C=1011$ 1110, and $C=\left(\bar{f}_{1}+f_{2}\right) \cdot \bar{f}_{3}+\left(\bar{f}_{1}+\bar{f}_{2}\right) \cdot f_{3}$. This method becomes especially useful in problems where only $\# C$ is desired and where ( $R_{j i}$ ) may have been determined previously.

Circuit-design Example. We now proceed with general problems of type 2 , which often make good use of the special case just described.

Suppose three circuits with outputs, respectively, $A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}$,
$\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}$, and $A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}$ have already been constructed. Suppose that it is desired to construct a new circuit with output

$$
A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)
$$

The problem is to construct the new circuit whose inputs are $X_{1}$ and $X_{2}$ and the outputs of each of the three circuits already constructed. This problem is essentially one of finding the form $F\left(f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right)$, where $f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}, f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}, f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3} ;$ and $E\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$ are given. For antecedence solutions we have, by the formula for problems of type 2 ,

$$
\left(R_{j i}\right) \otimes\left(\bar{E}_{i k}\right)=\left(\bar{F}_{j k}\right)_{a}
$$

or, from the examples of Sec. 13-2,

$$
\left(\vec{F}_{j k}\right)_{a}=\left(\begin{array}{cc}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right) \otimes\left(\begin{array}{l}
\overline{0000} \\
0011 \\
0011 \\
1111 \\
0101 \\
0101 \\
0011 \\
1111
\end{array}\right)=\left(\begin{array}{l}
1111 \\
0000 \\
1100 \\
1100 \\
0000 \\
1010 \\
0000 \\
0000
\end{array}\right)
$$

[where we recall that ( $E_{i k}$ ) is the same as ( $E_{k i}$ ) with the rows and columns interchanged]. Hence

$$
\left(F_{k j}\right)_{a}=\left(\begin{array}{ll}
0100 & 1011 \\
0100 & 1111 \\
0111 & 1011 \\
0111 & 1111
\end{array}\right)
$$

or

$$
\# F_{a}=0100 \quad 1011 \quad 0100 \quad 1111 \quad 00111 \quad 1011 \quad 0111 \quad 1111
$$

We could now find $F$ with respect to $b\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$, except that doing this would imply that $f_{1}, f_{2}, f_{3}, X_{1}$, and $X_{2}$ are all independent, i.e., that no constraint exists between them. However, this is not necessarily true: most often $f_{1}, f_{2}$, and $f_{3}$ are not independent. This constraint with respect to $b\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$ is determined by

$$
\left(R_{i i}\right) \otimes\left(I_{i k}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right) \otimes\left(\begin{array}{l}
1111 \\
1111 \\
1111 \\
1111 \\
1111 \\
1111 \\
1111 \\
1111
\end{array}\right)=\left(\begin{array}{l}
1111 \\
0000 \\
1111 \\
1111 \\
1111 \\
1111 \\
1111 \\
0000
\end{array}\right)=\left(C_{j k}\right)
$$

Hence

$$
\# C=\begin{array}{llllllll}
1011 & 1110 & 1011 & 1110 & 1011 & 1110 & 1011 & 1110
\end{array}
$$

Thus we must find $F_{a}$ with respect to the constrained basis $b_{c}\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$,

| $\# f_{1}=001$ | 010 | 001 | 010 | 001 | 010 | 001 | 010 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{2}=011$ | 001 | 011 | 001 | 011 | 001 | 011 | 001 |
| $\# f_{3}=000$ | 111 | 000 | 111 | 000 | 111 | 000 | 111 |
| $\# X_{1}=000$ | 000 | 111 | 111 | 000 | 000 | 111 | 11 |
| $\# X_{2}=000$ | 000 | 000 | 000 | 111 | 111 | 111 | 111 |
| $\# F_{a}=000$ | 101 | 000 | 111 | 011 | 101 | 011 | 111 |

This gives

$$
F_{a}=\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot f_{2}+X_{2} \cdot f_{2} \cdot f_{3}
$$

However, we are not yet finished, for all we now have is an $F_{a}$ such that $F_{a} \rightarrow E$. To see whether or not $F_{a}\left(f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right)$ is $E$, we must substitute $f_{1}\left(A_{1}, A_{2}, A_{3}\right), f_{2}\left(A_{1}, A_{2}, A_{3}\right)$, and $f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ into $F_{a}$ and see whether or not $\# F_{a}=\# E$ with respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$. Hence we form

$$
\left(F_{k j}\right) \otimes\left(R_{i i}\right)=\left(\begin{array}{ll}
0100 & 1011 \\
0100 & 1111 \\
0111 & 1011 \\
0111 & 1111
\end{array}\right) \otimes\left(\begin{array}{cc}
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0100 & 0010 \\
0000 & 0001 \\
0000 & 1100 \\
0001 & 0000 \\
0000 & 0000
\end{array}\right)=\left(\begin{array}{ll}
0001 & 0001 \\
0001 & 1101 \\
0111 & 0011 \\
0111 & 1111
\end{array}\right)=\left(F_{k i}\right)_{a}
$$

Hence

$$
\left(F_{k i}\right)_{a}=\left(\begin{array}{ll}
0001 & 0001 \\
0001 & 1101 \\
0111 & 0011 \\
0111 & 1111
\end{array}\right)=\left(E_{k i}\right)
$$

as desired. In this example $F_{a}$ is truly the desired solution, that is, $F_{a}=E$.

Further Discussion. Whether $F_{a}=E$ or not is determined in most cases by means of the type 1 formulas. Consider the circumstances where $F_{a} \neq E$. In such a case, since $F_{a} \rightarrow E$, we can always find by inspection a function $W\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ such that $F+W=E$. Similarly if $F_{c} \neq E$, then since $E \rightarrow F_{c}$, we can always find by inspection a function $V\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ such that $F_{c} \cdot V=E$. The problem in each of these cases reduces to choosing from all possible functions $W$ (or $V$ ) the one that best suits the particular situation in question. In any case, before determining $F$ explicitly, any constraint that exists between the $f_{s}$ must be calculated by means of the formula given at the beginning of this section; then $F$ is determined with respect to the constrained basis $b_{c}\left[f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right]$.

## EXERCISES

Draw the logical circuit diagrams for all results.
(a) Suppose that two circuits have already been constructed with outputs $A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}$ and $A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}$. The problem is to connect these circuits so that the following output will result:

$$
E=A_{1} \cdot A_{2} \cdot\left(X_{1}+X_{2}\right)+\bar{A}_{1} \cdot\left(\bar{A}_{2} \cdot X_{1}+A_{2} \cdot \bar{X}_{1}\right)+A_{1} \cdot \bar{A}_{2} \cdot \bar{X}_{1} \cdot \bar{X}_{2}
$$

Solution. $\# F_{a}\left(A_{1}, A_{2}, X_{1}, X_{2}\right)=011010010000$ 1001, while $\# E\left(A_{1}, A_{2}, X_{1}, X_{2}\right)=$ 011010010011 1001, whence $F_{a} \neq E$. A function $W$ can be found so that $F_{a}+W=E$. One $W$ evidently is such that $\# W=0000000000110000$. To determine $F_{a}$ explicitly as $F\left(f_{1}, f_{2}, X_{1}, X_{2}\right)$, find the constraints between $f_{1}$ and $f_{2}$, and then with respect to the constrained basis $b_{c}\left[f_{1}, f_{2}, X_{1}, X_{2}\right]$ we have

$$
F_{a}+W=\underbrace{f_{1} \cdot X_{1}+f_{2} \cdot \bar{X}_{1} \cdot \bar{X}_{2}}_{F_{a}}+\underbrace{A_{2} \cdot \bar{X}_{1} \cdot X_{2}}_{W}=E
$$

(b) Consider Exercise $a$, but this time find the consequence solution $F_{c}$.

Solution. \#F $F_{c}\left(A_{1}, A_{2}, X_{1}, X_{2}\right)=011010011111$ 1001, whence $F_{c} \neq E$. An appropriate $V$ is $V=A_{2}+X_{1}+\bar{X}_{2}$ (that is, $\# V=111111110011$ 1111), whence $F \cdot V=\left(f_{1} \cdot\left(X_{1}+X_{2}\right)+f_{2} \cdot \bar{X}_{1}\right) \cdot\left(A_{2}+X_{1}+\bar{X}_{2}\right)=E$.

## 14-3. Type 3 Problems in Circuitry

Five Examples. In this section five examples will be given. The first example illustrates a normally complicated situation; the second considers the case when solutions cannot be obtained such that $F=E$; the third illustrates the situation in which many solutions turn up and additional criteria are required; the fourth considers the case when no solutions exist; the fifth illustrates how solutions may be obtained that involve only certain specified elementary elements.

The First Example. Suppose that a circuit $F$ has been constructed with inputs $f_{1}, f_{2}, X_{1}$, and $X_{2}$ such that its output Boolean function is given by
$F=\bar{f}_{1} \cdot \bar{f}_{2} \cdot \bar{X}_{2}+f_{1} \cdot \bar{f}_{2} \cdot X_{2}+\bar{f}_{1} \cdot f_{2}\left(X_{1} \cdot \bar{X}_{2}+\bar{X}_{1} \cdot X_{2}\right)+f_{1} \cdot f_{2} \cdot \bar{X}_{1} \cdot \bar{X}_{2}$
It is desired to produce, by attaching additional circuits to the $f_{1}$ and $f_{2}$ inputs of this $F$ circuit, the following output result:

$$
\begin{aligned}
& E=\left(\bar{A}_{1} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3}\right) \cdot \bar{X}_{1} \cdot \bar{X}_{2}+\left(\bar{A}_{1} \cdot \bar{A}_{3}+A_{1} \cdot A_{2}\right) \cdot X_{1} \cdot \bar{X}_{2} \\
&+\left(A_{1} \cdot \bar{A}_{3}+A_{2} \cdot A_{3}\right) \cdot \bar{X}_{1} \cdot X_{2} \\
&+\left(A_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot A_{2} \cdot A_{3}\right) \cdot X_{1} \cdot X_{2}
\end{aligned}
$$

The problem is to design the two circuits, with inputs $A_{1}, A_{2}$, and $A_{3}$, whose outputs should be connected to $f_{1}$ and $f_{2}$, respectively. The first step in the solution is to find the sets of antecedence solutions $f_{1}\left(A_{1}, A_{2}, A_{3}\right), f_{2}\left(A_{1}, A_{2}, A_{3}\right)$. Then $F_{a}\left(f_{1}\left(A_{1}, A_{2}, A_{3}\right), f_{2}\left(A_{1}, A_{2}, A_{3}\right), X_{1}, X_{2}\right)$ $\rightarrow E$. The next step is to find the sets of consequence solutions; then $E \rightarrow F_{c}$. Now, for those sets of solutions that are both antecedence and
consequence solutions, $F=E$, and hence these will be the desired solutions from which the circuits can be designed.

With respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$,

| $\# E=$ | 1010 | 1100 | 1011 | 0001 | 0101 | 0011 | 0100 | 0010 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $i$ | 0123 | 4567 | 0123 | 4567 | 0123 | 4567 | 0123 | 4567 |
|  |  | 0 |  | 1 |  | 2 |  | 3 |
|  |  |  | $\left(E_{k i}\right)$ | $=\left(\begin{array}{l}1010 \\ 1011 \\ 0101 \\ 0100\end{array}\right.$ | $\left.\begin{array}{l}1100 \\ 0001 \\ 0011 \\ 0010\end{array}\right)$ |  |  |  |

Next, with respect to $b\left[f_{1}, f_{2}, X_{1}, X_{2}\right]$,

$$
\begin{array}{rcccc}
\# F= & 1001 & 1010 & 0110 & 0100 \\
j & 0123 & 0123 & 0123 & 0123 \\
k & 0 & 1 & 2 & 3 \\
& & \\
& \left(F_{j k}\right)= & \left(\begin{array}{c}
1100 \\
0011 \\
0110 \\
1000
\end{array}\right)
\end{array}
$$

whence

For antecedence solutions

$$
\begin{aligned}
& \qquad\left(F_{i k}\right) \otimes\left(\bar{E}_{k i}\right)=\left(\begin{array}{l}
1100 \\
0011 \\
0110 \\
1000
\end{array}\right) \otimes\left(\begin{array}{ll}
0101 & 0011 \\
0100 & 110 \\
1010 & 1100 \\
1011 & 1101
\end{array}\right)=\left(\begin{array}{ll}
0101 & 1111 \\
1011 & 1101 \\
1110 & 1110 \\
0101 & 0011
\end{array}\right)=\left(\bar{R}_{i i}\right)_{a} \\
& 0123 \\
& 4567 \\
& \text { and therefore } \quad \\
& \left(R_{i i}\right)_{a}=\left(\begin{array}{ll}
1010 & 0000 \\
0100 & 0010 \\
00001 & 0001 \\
1010 & 1100
\end{array}\right)
\end{aligned}
$$

Hence
Result Array

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}$ | 0,1 | 1 | 0,1 | 0 | 1 | 1 | 1 | 0 |
| $\# f_{2}$ | 0,1 | 0 | 0,1 | 1 | 1 | 1 | 0 | 1 |

There are four antecedence solutions:

$$
\begin{array}{ll}
f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3} & f_{2}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3} \\
f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}+\bar{A}_{1} \cdot A_{2} & f_{2}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}+A_{2} \cdot \bar{A}_{3} \\
f_{1}=\bar{A}_{2}+\bar{A}_{1} \cdot A_{3} & f_{2}=A_{1} \cdot A_{2}+\overline{\bar{A}}_{2} \cdot A_{3}+\bar{A}_{1} \cdot \bar{A}_{2} \\
f_{1}=\bar{A}_{1}+\bar{A}_{2} & f_{2}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}+\bar{A}_{1} \cdot \bar{A}_{2}+A_{2} \cdot \bar{A}_{3}
\end{array}
$$

For the consequence solutions we have

$$
\begin{gathered}
\left(\bar{F}_{i k}\right) \otimes\left(E_{k i}\right)=\left(\begin{array}{l}
0011 \\
1100 \\
1001 \\
0111
\end{array}\right) \otimes\left(\begin{array}{lll}
1010 & 1100 \\
1011 & 0001 \\
0101 & 0011 \\
0100 & 0010
\end{array}\right)=\left(\begin{array}{llll}
0101 & 0011 \\
1011 & 1101 \\
1110 & 1110 \\
1111 & 0011
\end{array}\right)=\left(\bar{R}_{i i}\right)_{c} \\
\left(R_{i i}\right)_{c}=\left(\begin{array}{ccccccc}
11 & 0 & \text { (1) } & 0 & 1 & 1 & 0 \\
0 & (1) & 0 & 0 & 0 & 0 & (1) \\
0 & 0 & 0 & 1 & 0 & 0 & 0 \\
0 & 1 \\
0 & 0 & 0 & 0 & \text { (1) (1) } & 0 & 0
\end{array}\right)
\end{gathered}
$$

In order to obtain those solutions which are both consequence and antecedence solutions, we encircle those units which are common with the antecedence $\left(R_{j i}\right)_{a}$ matrix. This solution is the common one:

| Result Array |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| $\# f_{1}$ | - | - | - | $\overline{1}$ | - |  |  |  |
| $\# f_{2}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
|  |  |  |  |  |  |  |  |  |

The desired circuits are therefore as in Fig. 14-1.


Fig. 14-1. Solution to the first example.
The Second Example. Suppose that $E$ were the same as in the previous example, but that the circuit $F$ had been constructed slightly different, as follows:

$$
\begin{aligned}
F=\bar{f}_{1} \cdot f_{2} \cdot\left(\bar{X}_{1}+\bar{X}_{2}\right)+f_{1} \cdot \bar{f}_{2} \cdot X_{2}+\bar{f}_{1} \cdot f_{2} \cdot\left(X_{1} \cdot \bar{X}_{2}\right. & \left.+\bar{X}_{1} \cdot X_{2}\right) \\
& +f_{1} \cdot f_{2} \cdot \bar{X}_{1} \cdot \bar{X}_{2}
\end{aligned}
$$

We are to construct an $f_{1}$ and an $f_{2}$, as in the previous example. The antecedence solutions would be

$$
\left(R_{i i}\right)_{a}=\left(\begin{array}{cc}
0000 & 0000 \\
0100 & 0010 \\
0001 & 0001 \\
1010 & 1100
\end{array}\right)
$$

And for consequence solutions we would have

$$
\left(R_{j i}\right)_{c}=\left(\begin{array}{cc}
1011 & 1101 \\
0100 & 0010 \\
0001 & 0001 \\
0000 & 1100
\end{array}\right)
$$

Comparing the units of the antecedence and consequence $R$ matrices, we see that since there are no common units in columns 0 and 2 there are no solutions that are both antecedence and consequence solutions. This means that no set of input functions $f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ and $f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ will make the output of $F=E$. We can only have $F_{a} \rightarrow E$ for antecedence sets of solutions and $E \rightarrow F_{c}$ for consequence sets of solutions. However, we can always find a $W$ such that, if $F_{a} \rightarrow E$, then $F_{a}+W=E$, or some $V$ such that, if $E \rightarrow F_{c}$, then $F_{c} \cdot V=E$.

Since there is only one set of antecedence solutions, let us consider this case first. By the formula for type 1 problems we find $\# F_{a}$ with respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ :

$$
\# F_{a}=1010 \quad 1100 \quad \stackrel{8}{00001} \begin{array}{lllllll}
0001 & 0101 & 0011 & 0100 & 0010
\end{array}
$$

We compare this with \#E:

$$
\# E=1010 \quad 1100 \quad 1011 \quad 0001 \quad 0101 \quad 0011 \quad 0100 \quad 0010
$$

We note first that $\# F_{a}$ does indeed imply $\# E$, as expected, and that $\# F_{a}$ differs from $\# E$ in that $\# F_{a}$ is missing 2 units, in positions 8 and 10. In order that $F_{a}+W=E, W$ must be chosen so as to contribute these units. We could solve for $W$, but it can be easily obtained by inspection. Let $W=\bar{A}_{1} \cdot \bar{A}_{3} \cdot \bar{X}_{2}$,

$$
\begin{array}{llllllll}
1010 & 0000 & 1010 & 0000 & 0000 & 0000 & 0000 & 0000
\end{array}
$$

Now $\# F_{a}+\# W=\# E$, as is easily seen. Hence our final circuits will be as in Fig. 14-2.

Similarly, we can choose one of the nontrivial consequence solutions $f_{1}$, $f_{2}$ and determine some $V$ such that $F \cdot V=E$. [Note from the consequence $\left(R_{j i}\right)_{c}$ that there are 16 possible solutions, i.e., four columns have 2 units each.] Suppose that it is desired to choose a nontrivial consequence solution and determine the circuits for $f_{1}, f_{2}$, and $V$. For exam-


Fig. 14-2. Solution to the second example.
ple, choose the nontrivial solution corresponding to

$$
\left(R_{i i}\right)=\left(\begin{array}{ll}
1011 & 0001 \\
0100 & 0010 \\
0000 & 0000 \\
0000 & 1100
\end{array}\right)
$$

This gives

$$
\begin{array}{rrrrrrrrr}
\# F\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right) \\
=1011 & 1101^{7} & 1011 & 0001 & 1618 \\
1111 & 0011 & 0100 & 0010
\end{array}
$$

On comparing this with $\# E$ we see that $V$ must change the units in positions $3,7,16$, and 18 to zeros. Hence we can have

$$
V=\left(\bar{A}_{1}+\bar{A}_{2}+X_{1}+X_{2}\right) \cdot\left(A_{1}+A_{3}+X_{1}+\bar{X}_{2}\right)
$$

by inspection.
Too Many Solutions. It sometimes happens that there are many antecedence or consequence solutions. This merely means that additional criteria are needed to choose the desired solution. Such criteria are often that the desired solutions be both antecedence and consequence solutions (so that $E=F$ ), that the set of functions of the solution be as simple as possible, that the set be independent, that the set satisfy some given constraints, etc. These additional criteria will quickly reduce the number of allowable solutions. This is actually an exceedingly interest-
ing point, for here the mathematics is essentially disclosing whether or not the original formulation of the problem was adequately precise.

In order to illustrate these points, let us first solve the type 3 problem that was given in Sec. 13-1. [We determined $\left(E_{k i}\right)$ and $\left(F_{j k}\right)$ in Sec. 13-2.] To find the antecedence solutions using the formula for type 3 problems, find

Hence there are $2 \times 4 \times 4 \times 8 \times 4 \times 4 \times 4 \times 8=131,072$ sets of solutions.

This seems to be a large number of possible solutions, but after all it was narrowed down from the $8^{8}=16,777,216$ total possible sets of three functions of three variables! However, we are interested in solutions such that $F=E$, and our antecedence solutions assure us only that $F_{a} \rightarrow E$. Therefore let us find the consequence solutions such that $E \rightarrow F_{c}$, and then any solutions that turn out to be both antecedence and consequence solutions will satisfy $F=E$. For consequence solutions we have, upon substitution in the formula for type 3 problems,

Comparing the antecedence $\left(R_{j i}\right)_{a}$ with this consequence $\left(R_{j i}\right)_{c}$, we note that they have in common only the units circled above; hence only solutions corresponding to these units will be both antecedence and consequence solutions as desired. Filling in for the common units only, we find the result array:

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ | 0,1 | $\dot{0}, 1$ | 0,1 | 0,0 | 1,1 | 1,1 | 0,1 | 0,0 |
| $\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ | 0,1 | 1,1 | 1,1 | 0,1 | 0,0 | 0,0 | 1,1 | 0,1 |
| $\# f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ | 0,1 | 0,0 | 0,0 | 1,1 | 0,1 | 0,1 | 0,0 | 1,1 |

Thus the number of desired solutions has been reduced from 131,072 to $2 \times 2 \times 2 \times 2 \times 2 \times 2 \times 2 \times 2=256$ solutions, but there are still too many. Hence we can add another criterion to our desired solution, e.g., that it be as simple as possible. In passing, note that one set of valid solutions is that given in Sec. 13-1 [see the discussion of matrix ( $R_{j i}$ ) in Sec. 13-2].

To choose a simple solution from the 256 possible solutions, let us see whether or not any set of solutions has an elementary element as one of the functions. It is clear that $f_{2}$ cannot be expressed as an elementary element or its bar, for in $\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ positions 1 and 2 must both be units and therefore $f_{2}$ cannot be $A_{1}, \bar{A}_{1}, A_{2}$, or $\bar{A}_{2}$; and since position 5 must be a zero and 6 must be a unit, $f_{2}$ cannot be $A_{3}$ or $\bar{A}_{3}$. Similar reasoning shows also that $f_{3}$ cannot be so expressed. However, note that $f_{1}$ can be chosen to be an elementary element, namely, $\bar{A}_{2}$. Throwing away solutions not involving $f_{1}=\bar{A}_{2}$, we have the result array:

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | $=\# \bar{A}_{2}$ |
| $\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ | 1 | 1 | 1 | 0,1 | 0 | 0 | 1 | 0,1 |  |
| $\# f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ | 1 | 0 | 0 | 1 | 0,1 | 0,1 | 0 | 1 |  |

But this array still gives a choice of $2 \times 2 \times 2 \times 2=16$ sets of solutions, because of columns $3,4,5$, and 7 . Let us try to choose $f_{2}$ as simple as possible. From the elimination pairs of $A_{1}$ it is clear that $f_{2}$ can be chosen not to involve $A_{1}$. Then

$$
\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)=1111 \quad 0011=\#\left[A_{2}+\bar{A}_{3}\right]
$$

Note also that $f_{3}$ can be chosen so as to eliminate $A_{3}$ :

$$
\# f_{3}=1001 \quad 1001=\#\left[A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right]
$$

Hence a simple set of solutions is given by the array:

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}\left(A_{1}, A_{2}, A_{3}\right)$ | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | $=\# \bar{A}_{2}$ |
| $\# f_{2}\left(A_{1}, A_{2}, A_{3}\right)$ | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | $=\#\left[A_{2}+\bar{A}_{3}\right]$ |
| $\# f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | $=\#\left[A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right]$ |

The three desired circuits are shown in Fig. 14-3.
No Solutions. It can happen that antecedence or consequence solutions do not exist. For example, suppose that it is desired to find a function $f_{1}\left(A_{1}, A_{2}\right)$ such that, if the output of its circuit is connected to the input of another circuit $F$ whose output is $f_{1} \cdot X_{1}+\bar{f}_{1} \cdot \bar{X}_{1}$, the total resulting output $E$ will be $\bar{A}_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot X_{1}+\bar{A}_{2} \cdot \bar{X}_{1}$. Let us start by


Fig. 14-3. Solution to the third example.
trying for antecedence solutions:
$\begin{array}{rrrr}\# f_{1}=0101 & & \# A_{1}=0101 & 0101 \\ \# X_{1}=0011 \\ \# F=\#\left[f_{1} \cdot X_{1}+\bar{f}_{1} \cdot \bar{X}_{1}\right]=1001 & \# A_{2}=0011 & 0011 \\ & & \# X_{1}=0000 & 1111 \\ & & \# E=\#\left[\bar{A}_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot X_{1}+\bar{A}_{2} \cdot \bar{X}_{1}\right]=1100 & 1010 \\ \text { whence } \quad\left(F_{k j}\right)=\binom{10}{01} & \left(E_{k i}\right)=\binom{1100}{1010} & \end{array}$
Substituting in the antecedence formulas,
whence

$$
\begin{gathered}
\left(F_{j k}\right) \otimes\left(\bar{E}_{k i}\right)=\binom{10}{01} \otimes\binom{0011}{0101}=\binom{0011}{0101}=\left(\bar{R}_{j i}\right)_{a} \\
\left(R_{j i}\right)_{a}=\binom{1100}{1010}
\end{gathered}
$$

To interpret ( $R_{j i}$ ), we have
Result Array

| $i$ | 0 | 1 | 2 | 3 |
| :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}$ | 0,1 | 0 | 1 | None |

Hence no antecedence solution exists. The condition for the existence of a solution is computed (see "Type 3 Problems" in Sec. 13-3) by

$$
\left(V_{j}\right) \otimes\left(R_{j i}\right)=(11) \otimes\binom{1100}{1010}=(1110)
$$

to be interpreted with respect to $b\left[A_{1}, A_{2}\right]: \# A_{1}=0101, \# A_{2}=0011$. Hence $1110=\#\left[\bar{A}_{1}+\bar{A}_{2}\right]$. In order to have an antecedence solution, the signals on wires $A_{1}$ and $A_{2}$ must satisfy $A_{1} \rightarrow \bar{A}_{2}$; that is, if a unit signal level appears on wire $A_{1}$, then a zero signal level must appear on wire $A_{2}$. Suppose that this were actually the case. To find the ante-
cedence solution, we note that $b_{c}\left[A_{1}, A_{2}, X_{1}\right]$ becomes
whence

| $\# A_{1}=010$ | 010 |
| ---: | ---: | ---: |
| $\# A_{2}=001$ | 001 |
| $\# X_{1}=000$ | 111 |
| $\# E=\#\left[\bar{A}_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot X_{1}+\bar{A}_{2} \cdot \bar{X}_{1}\right]=110$ | 101 |

$$
\left(E_{k i}\right)=\binom{110}{101}
$$

Then

$$
\binom{10}{01} \otimes\binom{001}{010}=\binom{001}{010}=\left(\bar{R}_{j i}\right)_{a} \quad \text { and } \quad\left(R_{j i}\right)_{a}=\binom{110}{101}
$$

This gives the result array:

| $i$ | 0 | 1 | 2 |
| :---: | :---: | :---: | :---: |
| $\# f$ | 0,1 | 0 | 1 |

which, interpreted in terms of the constrained basis $b_{c}\left[A_{1}, A_{2}\right]$
becomes
or

$$
\begin{aligned}
& \# A_{1}=010 \\
& \# A_{2}=001 \\
& \# \# f_{1}=001=\# A_{2} \\
& \# f_{1}=101=\# \bar{A}_{1}
\end{aligned}
$$

which gives two alternatives for the desired solution. However, it can be observed that these solutions make $F_{a} \rightarrow E$, but $F \neq E$.

Specifying the Variables. Suppose that it is desired to find consequence solutions of

$$
E=A \cdot(\bar{B} \cdot C+B \cdot D)+\bar{A} \cdot \bar{C} \cdot(B \cdot \bar{D}+\bar{B} \cdot D)
$$

that do not involve $C$. In other words, we want to determine all $F$ such that $E \rightarrow F$ does not involve $C$. To do this, we rename our elementary elements $A, B, C$, and $D$ as $A_{1}, A_{2}, X_{1}$, and $A_{3}$, respectively. Then we find consequence solutions of type 3 for $E$, where $F$ is simply $f_{1}$. Thus

$$
\begin{aligned}
\# E & =\#\left[A_{1} \cdot\left(\bar{A}_{2} \cdot X_{1}+A_{2} \cdot A_{3}\right)+\bar{A}_{1} \cdot \bar{X}_{1} \cdot\left(A_{2} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3}\right)\right] \\
& =0010 \quad 1001 \quad 0100 \quad 0101
\end{aligned}
$$

and $\# F=\# f_{1}=0101$ with respect to $b\left[f_{1}, X_{1}\right]$. Hence

$$
\begin{aligned}
& \qquad\left(\bar{F}_{j k}\right) \otimes\left(E_{k i}\right)=\binom{11}{00} \otimes\left(\begin{array}{ll}
0010 & 1001 \\
0100 & 0101
\end{array}\right)=\left(\begin{array}{ll}
0110 & 1101 \\
0000 & 0000
\end{array}\right)=\left(\bar{R}_{j i}\right) \\
& \text { and } \\
& \quad\left(R_{j i}\right)=\left(\begin{array}{ll}
1001 & 0010 \\
1111 & 1111
\end{array}\right)
\end{aligned}
$$

and hence there are eight solutions:
Result Array

| $i$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $f$ | 0,1 | 1 | 1 | 0,1 | 1 | 1 | 0,1 | 1 |

Three simple nontrivial solutions are

|  | $A_{1}+A_{2}+A_{3}=A+B+D$ |
| :--- | :--- |
| $\bar{A}_{1}+\bar{A}_{2}+A_{3}=\bar{A}+\bar{B}+D$ |  |
| $A_{1}+\bar{A}_{2}+\bar{A}_{3}=A+\bar{B}+\bar{D}$ |  |

## EXERCISES

Suppose that the circuit $F$ has already been constructed and that it is desired to construct a circuit with output $E$. How should the circuits $f_{1}, f_{2}$, and $f_{3}$ be constructed?
(a) $F=\left(f_{1}+f_{3}\right) \cdot \bar{X}_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}+f_{3} \cdot X_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}+\left(f_{2}+f_{3}\right) \cdot \bar{X}_{1} \cdot X_{2} \cdot \bar{X}_{3}$ $+f_{1} \cdot X_{1} \cdot X_{2} \cdot \bar{X}_{3}+f_{3} \cdot \bar{X}_{1} \cdot \bar{X}_{2} \cdot X_{3}+f_{1} \cdot f_{2} \cdot X_{1} \cdot \bar{X}_{2} \cdot X_{3}$ $+f_{2} \cdot \bar{X}_{1} \cdot X_{2} \cdot X_{3}+\left(f_{3}+f_{2} \cdot f_{1}\right) \cdot X_{1} \cdot X_{2} \cdot X_{3}$.
$E=\left(\left(\bar{A}_{1}+A_{2}\right) \cdot \bar{A}_{3}+A_{3} \cdot\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right)\right) \cdot \bar{X}_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}$
$+\left(A_{2} \cdot \bar{A}_{3}+A_{1} \cdot A_{2} \cdot A_{3}\right) \cdot X_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}$
$+\left(\left(A_{1}+A_{2}\right) \cdot \bar{A}_{3}+A_{3} \cdot \bar{A}_{1}\right) \cdot \bar{X}_{1} \cdot X_{2} \cdot \bar{X}_{3}$
$+\left(\bar{A}_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}+A_{3} \cdot\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right)\right) \cdot X_{1} \cdot X_{2} \cdot \bar{X}_{3}$
$+\left(A_{2} \cdot \bar{A}_{3}+A_{1} \cdot A_{2} \cdot A_{3}\right) \cdot \bar{X}_{1} \cdot \bar{X}_{2} \cdot X_{3}+\bar{A}_{1} \cdot A_{2} \cdot A_{3} \cdot X_{1} \cdot \bar{X}_{2} \cdot X_{3}$ $+\left(A_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot A_{3}\right) \cdot \bar{X}_{1} \cdot X_{2} \cdot X_{3}+A_{2} \cdot X_{1} \cdot X_{2} \cdot X_{3}$.
Solution. $f_{1}=\bar{A}_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}+A_{3} \cdot\left(\overline{A_{1}} \cdot A_{2}+A_{1} \cdot \bar{A}_{2}\right), f_{2}=A_{1} \cdot \bar{A}_{2} \cdot A_{3}+\bar{A}_{1} \cdot A_{3}$, $f_{3}=A_{2} \cdot \bar{A}_{3}$.
(b) $F=\bar{X}_{1} \cdot f_{1} \cdot f_{2} \cdot \bar{f}_{3}+X_{1} \cdot f_{1} \cdot \bar{f}_{2} \cdot \bar{f}_{3}+\bar{f}_{1} \cdot f_{2} \cdot f_{3}$.

$$
E=\bar{X}_{1} \cdot \bar{X}_{2} \cdot\left(\bar{A}_{3} \cdot\left(\bar{A}_{1} \cdot \bar{A}_{2}+A_{1} \cdot A_{2}\right)+A_{3} \cdot\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right)\right)+X_{1} \cdot \bar{X}_{2} \cdot \bar{A}_{1}
$$

$$
+\bar{X}_{1} \cdot X_{2} \cdot\left(\bar{A}_{3} \cdot\left(A_{1}+A_{2}\right)+A_{3} \cdot\left(\bar{A}_{1}+A_{2}\right)\right)
$$

$+X_{1} \cdot X_{2} \cdot\left(\bar{A}_{3} \cdot\left(\bar{A}_{1} \cdot \bar{A}_{2}+A_{1} \cdot A_{2}\right)+A_{1} \cdot \bar{A}_{2} \cdot A_{3}\right)$.
(c) $F=\bar{X}_{1} \cdot \bar{X}_{2} \cdot\left(f_{2} \cdot \bar{f}_{3}+f_{1} \cdot \bar{f}_{2} \cdot f_{3}\right)+X_{1} \cdot \bar{X}_{2} \cdot\left(\bar{f}_{1} \cdot f_{2} \cdot \bar{f}_{3}+f_{3} \cdot\left(\bar{f}_{1}+f_{2}\right)\right)$
$+\bar{X}_{1} \cdot X_{2} \cdot\left(f_{1} \cdot \bar{f}_{2} \cdot \bar{f}_{3}+\bar{f}_{2} \cdot f_{3}\right)+X_{1} \cdot X_{2} \cdot\left(\bar{f}_{1} \cdot \bar{f}_{2} \cdot \bar{f}_{3}+f_{1} \cdot f_{2}\right)$.
$E=\bar{X}_{1} \cdot \bar{X}_{2} \cdot\left(\bar{A}_{1} \cdot A_{2} \cdot \bar{A}_{3}+A_{2} \cdot A_{3}\right)$
$+X_{1} \cdot \bar{X}_{2} \cdot\left(A_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}+A_{3} \cdot\left(\bar{A}_{1} \cdot \bar{A}_{2}+A_{1} \cdot A_{2}\right)\right)$
$+\bar{X}_{1} \cdot X_{2} \cdot\left(\bar{A}_{3} \cdot\left(\bar{A}_{1} \cdot \bar{A}_{2}+A_{1} \cdot A_{2}\right)+A_{3} \cdot \bar{A}_{2} \cdot \bar{A}_{1}\right)$
$+X_{1} \cdot X_{2} \cdot\left(\bar{A}_{3} \cdot A_{2} \cdot A_{1}+A_{3} \cdot\left(\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{2}\right)\right)$.

## 14-4. Constraints in the Problems

The Introduction of Constraints. There are four possible ways in which constraints can appear in antecedence and consequence problems. There may be logical dependence among the $A_{1}$, . . . , $A_{I}$ themselves, among the $X_{1}, \ldots, X_{K}$, among the $f_{1}, \ldots, f_{J}$, or between the $A_{1}, \ldots, A_{I}$ and the $X_{1}, \ldots, X_{K}$. In this section we consider how the first three such constraints affect the formation of the matrices; the fourth will be considered in the next section.

Constraints in the $E$ and $F$ Matrices. If constraints occur between the $A_{1}, \ldots, A_{I}$ themselves, then in $b\left[A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right]$ some columns of index $i$ will be omitted. The corresponding columns of ( $E_{k i}$ ) will also be omitted. Similarly, if some constraints occur between the $X_{1}, \ldots, X_{K}$, in $b\left[A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right]$ some columns of index $k$ will be omitted; the corresponding rows of ( $E_{k i}$ ) will also be omitted. For example, suppose that the logical dependence between $A_{1}, A_{2}$, and $A_{3}$ is given by $\bar{A}_{1}=A_{2}+A_{3}$ and $\bar{A}_{2}=A_{1}+A_{3}$. Suppose also that the logical dependence between $X_{1}$ and $X_{2}$ is such that $X_{1} \rightarrow X_{2}$. Then from the normal $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ we have


Hence the constrained basis $b_{c}\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ becomes

| $\# A_{1}=100$ | 100 | 100 |  |
| :---: | :---: | :---: | :---: |
| $\# A_{2}=010$ | 010 | 010 |  |
| $\# A_{3}=001$ | 001 | 001 |  |
| $\# X_{1}=000$ | 000 | 111 |  |
| $\# X_{2}=000$ | 111 | 111 |  |
| $i$ | 124 | 124 | 124 |
| $k$ | 0 | 2 | 3 |

Now suppose that $E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$, as in Sec. 13-2. Then with respect to $b_{c}\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$

In general we can say that, if the constraints between $A_{1}, \ldots, A_{I}$ are such that $b_{c}\left[A_{1}, \ldots, A_{I}\right]$ has $u$ columns and between $X_{1}, \ldots, X_{K}$ such that $b_{c}\left[X_{1}, \ldots, X_{K}\right]$ has $v$ columns, then the designation number of $E$ with respect to $b_{c}\left[A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right]$ is divided into $v$ parts each of $u$ positions; the successive parts form the successive rows of ( $E_{k i}$ ).

We have a similar situation when considering $\left(F_{k j}\right)$. For example, suppose that the logical dependence between $f_{1}, f_{2}$, and $f_{3}$ is such that $\bar{f}_{1}=f_{2}+f_{3}$ and $\bar{f}_{2}=f_{1}+f_{3}$ and between $X_{1}$ and $X_{2}$ such that $X_{1} \rightarrow X_{2}$.

Then $b_{c}\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$ is

$$
\begin{array}{rlrl}
\# f_{1}=100 & 100 & 100 \\
\# f_{2} & =010 & 010 & 010 \\
\# f_{3} & =001 & 001 & 001 \\
\# X_{1}=000 & 000 & 111 \\
\# X_{2}=000 & 111 & 111
\end{array}
$$

If $F=f_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot f_{2}+X_{2} \cdot f_{2} \cdot f_{3}$ as in Sec. 13-2, then with respect to $b_{c}\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$ we have

$$
\# F=001 \quad 011 \quad 111 \quad \text { and } \quad\left(F_{k j}\right)=\left(\begin{array}{l}
001 \\
011 \\
111
\end{array}\right)
$$

Constraints in the $R$ Matrix. Consider next the effect of constraints on matrix ( $R_{j i}$ ). Suppose $f_{1}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{3}, f_{2}=\bar{A}_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}$, and $f_{3}=A_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}$, as in Sec. 13-2. Then by Sec. 14-2 the constraint between $f_{1}, f_{2}$, and $f_{3}$ is given (for $k=0,1,2$, and 3 ) by

$$
\left(C_{j}\right)=\left(R_{i i}\right) \otimes\left(I_{i}\right)=\left(\begin{array}{l}
1 \\
0 \\
1 \\
1 \\
1 \\
1 \\
1 \\
0
\end{array}\right)
$$

With respect to $b\left[f_{1}, f_{2}, f_{3}\right]$ we have $\# C=10111110$, and $b_{c}\left[f_{1}, f_{2}, f_{3}\right]$ becomes

$$
\begin{array}{ll}
\# f_{1}=001 & 010 \\
\# f_{2}=011 & 001 \\
\# f_{3}=000 & 111
\end{array}
$$

Now suppose that in addition $\bar{A}_{1}=A_{2}+A_{3}$ and $\bar{A}_{2}=A_{1}+A_{3} ;$ then $b_{c}\left[A_{1}, A_{2}, A_{3}\right]$ becomes

$$
\begin{aligned}
& \# A_{1}=100 \\
& \# A_{2}=010 \\
& \# A_{3}=001
\end{aligned}
$$

Now we can determine ( $R_{j i}$ ) with the constraints, for with respect to $b_{c}\left[A_{1}, A_{2}, A_{3}\right]$ we have
i 124

|  | $j 0$ | 000 |
| :---: | :---: | :---: |
|  | 2 | 010 |
| $\# f_{1}=101$ | - 3 | 100 |
| $\# f_{2}=110$ | whence $\left(R_{j i}\right)=$ |  |
| $\# f_{3}=001$ | 4 | 000 |
|  | 5 | 001 |
|  | 6 | 000 |

Note that introducing a constraint on the $A_{1}, A_{2}, A_{3}$ in turn introduced an additional constraint on $f_{1}, f_{2}, f_{3}$, for

$$
\left(C_{i}\right)=\left(R_{j i}\right) \otimes\left(I_{i}\right)=\left(\begin{array}{l}
000 \\
010 \\
100 \\
000 \\
001 \\
000
\end{array}\right) \otimes\left(\begin{array}{l}
1 \\
1 \\
1
\end{array}\right)=\left(\begin{array}{l}
0 \\
1 \\
1 \\
0 \\
1 \\
0
\end{array}\right)
$$

or with respect to $b_{c}\left[f_{1}, f_{2}, f_{3}\right]$ we have $\# C=011010$. Hence $b_{c c}\left[f_{1}, f_{2}, f_{3}\right]$ (where the subscript $c c$ indicates the double constraint) becomes
$i 124$

$$
\begin{aligned}
& \# f_{1}=101 \\
& \# f_{2}=110 \\
& \# f_{3}=001
\end{aligned} \quad \text { whence }\left(R_{j i}\right)=\begin{aligned}
& j 2 \\
& 3
\end{aligned}\left(\begin{array}{l}
010 \\
100 \\
001
\end{array}\right)
$$

where the indices given for $i$ and $j$ refer to the unconstrained bases.

## EXERCISES

Consider the situation where the constraints between $A_{1}, A_{2}$, and $A_{3}$ are $\bar{A}_{1}=$ $A_{2}+A_{3}$ and $\bar{A}_{2}=A_{1}+A_{3}$. Let the constraint between $X_{1}$ and $X_{2}$ be $X_{1} \rightarrow X_{2}$. Let $f_{1}\left(A_{1}, A_{2}, A_{3}\right), f_{2}\left(A_{1}, A_{2}, A_{3}\right)$, and $f_{3}\left(A_{1}, A_{2}, A_{3}\right)$ be the same as used above (i.e., the same as in Sec. 13-2). Under these circumstances:
(a) Find $b_{c c}\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right]$.
(b) Find $b_{c}\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ and $b_{c}\left[A_{1}, A_{2}, A_{3}\right]$.
(c) Let $F=\bar{f}_{1} \cdot f_{3}+X_{1} \cdot f_{1} \cdot \bar{f}_{2}+X_{2} \cdot f_{2} \cdot \bar{f}_{3}$, and find $E$, using the type 1 formula.
(d) Let $E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2} \cdot A_{3}+X_{2} \cdot\left(A_{1} \cdot \bar{A}_{3}+A_{2}\right)$ as in Sec. 13-2. Using the $f_{s}$ given above, find $F\left(f_{1}, f_{2}, f_{3}, X_{1}, X_{2}\right)$ such that $F=E$.
(e) Let $F$ be as in Exercise $c$ and $E$ be as in Exercise $d$; determine $f_{1}, f_{2}$, and $f_{3}$ such that $F=E$.

## 14-5. Ordinary Equations

The Problem. The methods discussed in the previous section for taking account of constraints in circuit-design problems are relatively straightforward. In all the cases discussed the $A_{1}, \ldots, A_{I}$ and the $X_{1}, \ldots, X_{K}$ were independent of each other even though there may have been some logical dependence among the $A_{1}, \ldots, A_{I}$ themselvès and among the $X_{1}, \ldots, X_{K}$ themselves. In this section we shäll investigate problems where there is a logical dependence between the $A_{1}, \ldots, A_{I}$ and the $X_{1}, \ldots, X_{K}$.

First it must be noticed that if we tried to form ( $E_{k i}$ ) with respect to $b_{c}\left[A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right]$, where the constraint is between the $A$ 's and $X$ 's, the matrix would not be rectangular, i.e., some of the elements would be missing-and we shall not consider nonrectangular matrices.

For example, suppose that $A_{1} \rightarrow X_{1}$ and $X_{1} \cdot X_{2} \rightarrow A_{2}$. Let

$$
E=A_{1} \cdot A_{2}+X_{1} \cdot \bar{A}_{2}+X_{2} \cdot\left(A_{1}+A_{2}\right)
$$

with respect to $b_{c}\left[A_{1}, A_{2}, X_{1}, X_{2}\right]$,

$$
\begin{aligned}
& \# A_{1}=00 \quad 0101 \quad 00 \quad 01 \\
& \# A_{2}=01 \quad 0011 \quad 01 \quad 11 \\
& \# X_{1}=00 \quad 111100011 \\
& \begin{array}{lllll}
\# X_{2}=00 & 0000 & 11 & 11 \\
\hline \# E=00 & 1101 & 01 & 11
\end{array} \\
& \begin{array}{ccccc}
i & 01 & 0123 & 01 & 23 \\
k & 0 & 1 & 2 & 3
\end{array} \\
& \left(E_{k i}\right)=\left(\begin{array}{l}
00 \\
1101 \\
01 \\
11
\end{array}\right)
\end{aligned}
$$

which is not rectangular and has no meaning for us. In fact a little reflection will show that the whole meaning of problems of types 1,2 , and 3 vanishes if we let $X_{s}=X_{s}\left(A_{1}, \ldots, A_{I}\right)$ directly. Hence let us consider in more detail the kinds of problems that can occur where $X_{s}=X_{s}\left(A_{1}, \ldots, A_{I}\right)$.

If there is some relation between the $A_{1}, \ldots, A_{I}$ and $X_{1}, \ldots, X_{K}$, then the problem can be interpreted in terms of the problem of the solution to ordinary equations as considered in Chap. 12. In general these problems involve a function $E^{\prime}\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)$ which is to be a tautology, i.e., always true, when appropriate functions

$$
X_{s}=X_{s}\left(A_{1}, \ldots, A_{I}\right)
$$

are substituted into $E^{\prime}$. Two questions may arise concerning these problems: (1) Can $X_{1}\left(A_{1}, \ldots, A_{I}\right)$ be found which when substituted into a given $E^{\prime}$ will make $E^{\prime}$ a tautology? (2) Can an $E^{\prime}$ be found such that, when given functions $X_{1}\left(A_{1}, \ldots, A_{I}\right), \ldots, X_{K}\left(A_{1}, \ldots, A_{I}\right)$ are substituted into it, it becomes a tautology? These are essentially inverse problems to each other. The first question was really considered first in Chap. 12, where the function $F$ was usually of the form of a Boolean equation,

$$
H\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)=G\left(A_{1}, \ldots, A_{I}, X_{1}, \ldots, X_{K}\right)
$$

For simultaneous equations the function $E^{\prime}$ is simply the product of the given Boolean equations. The second question, however, was not considered previously. In this section we shall present methods for the solution of both of these equations in terms of Boolean matrices.

Ordinary Equations as an Antecedence-solution Problem. In order to recast the solution-to-equations problem into the types of problems considered in this chapter, note that we either are given or desire to find functions

$$
X_{s}=X_{s}\left(A_{1}, \ldots, A_{I}\right)
$$

Hence let $X_{s}=f_{s}\left(A_{1}, \ldots, A_{I}\right)$. Then we desire that these solutions make $E$ a tautology, i.e., make $E=I$. In other words, we want

$$
\begin{aligned}
&\left\{\left[X_{1}=f_{1}\left(A_{1}, \ldots, A_{I}\right)\right] \cdot\left[X_{2}=f_{2}\left(A_{1}, \ldots, A_{I}\right)\right] \cdots\right. \\
& {\left[X_{K}\right.}\left.\left.=f_{K}\left(A_{1}, \ldots, A_{I}\right)\right]\right\} \\
& \rightarrow\left\{E^{\prime}\left(\dot{A_{1}}, \cdots, A_{I}, X_{1}, \ldots, X_{K}\right)=I\right\}
\end{aligned}
$$

Hence our questions simply relate to antecedence solutions of the form $F=\left[\left(X_{1}=f_{1}\right) \cdot\left(X_{2}=f_{1}\right) \cdots\left(X_{K}=f_{K}\right)\right]$ of $E=\left[E^{\prime}=I\right]$. Question 1 becomes an antecedence-solution problem of type 3 , and question 2 becomes an antecedence-solution problem of type 1.

Two observations should be made: First recall that $\#\left(E^{\prime}=I\right)=\# E^{\prime}$, and hence the Boolean equation $E^{\prime}$ itself is the function $E$. Second, observe that the form of $F$ is known. In this case it turns out that $\left(F_{k j}\right)$ is a matrix with units on the diagonal and zeros elsewhere. For consider $F=\left[\left(X_{1}=f_{1}\right) \cdot\left(X_{2}=f_{2}\right)\right]$,

$$
\begin{array}{rl}
\#\left(X_{1}=f_{1}\right) & =1010 \\
0101 & 1010 \\
0 & 0101 \\
\#\left(X_{2}=f_{2}\right) & =\begin{array}{llll}
1000 & 0100 & 0010 & 0001 \\
\# F & =1000 & 0100 & 0010
\end{array} 0001
\end{array} \quad \text { and } \quad\left(F_{i k}\right)=\left(\begin{array}{l}
1000 \\
0100 \\
0010 \\
0001
\end{array}\right)
$$

This is an important observation, for if we denote such a diagonal matrix by ( $I_{j k}$ ), it is easy to see that for any Boolean matrix ( $a_{k j}$ )

$$
\left(I_{j k}\right) \otimes\left(a_{k j}\right)=\left(a_{k j}\right)
$$

In other words, multiplying a matrix by $\left(I_{j k}\right)$ results in the same original matrix. Thus, in finding antecedence solutions for type 3 problems with this $F$,

$$
\left(I_{j k}\right) \otimes\left(\bar{E}_{k i}\right)=\left(\bar{E}_{k i}\right)=\left(\bar{R}_{j i}\right) \quad \text { or } \quad\left(R_{j i}\right)=\left(E_{k i}\right)
$$

Hence the matrix multiplication need never be performed, the ( $R_{j i}$ ) being found directly as the ( $E_{k i}$ ). A similar situation occurs for antecedence solutions for type 1 problems with this $F$, where the ( $E_{k i}$ ) matrix is found directly as the ( $R_{j i}$ ) matrix.

1. Solution to Equations. Here the equation $E$ is given, and the problem is to find solutions $X_{s}=X_{s}\left(A_{1}, \ldots, A_{I}\right)$. As an example, consider the equation $E$ to be

$$
\left(A_{1}+A_{2}\right) \cdot X_{1} \cdot \bar{X}_{2}+\left(\bar{A}_{1}+\bar{A}_{2}\right) \cdot X_{2}=A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}
$$

A quick method for finding $\# E$ is first to find $\# H$ and $\# G, \dagger$ and then to note that $\# E$ has units in those positions where the corresponding bits of $\# H$ and $\# G$ are both zero or both units; the $\# E$ has zeros elsewhere. Thus

$$
\begin{array}{rl}
\#\left(A_{1}+A_{2}\right) \cdot X_{1} \cdot \bar{X}_{2}+\left(\bar{A}_{1}+\bar{A}_{2}\right) \cdot X_{2} & =0000 \\
\hline \bar{A}_{1} \cdot \bar{A}_{2} & =111 \\
\# A_{1} \cdot A_{2}+\bar{x}_{1} & 1110 \\
\# E & =\begin{array}{llll}
1110 \\
\hline 0110 & 0001 & 1001 & 1000 \\
\# A_{1} & 1000 & 1000
\end{array} ~
\end{array}
$$

$\dagger$ Recall that $H$ and $G$ are the left- and right-hand sides of the equation, respectively.

Thus $\left(E_{k i}\right)=\left(R_{j i}\right)=\left(\begin{array}{c}0110 \\ 0001 \\ 1000 \\ 1000\end{array}\right)$, and the result array becomes

| $i$ | 0 | 1 | 2 | 3 |
| :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}$ <br> $\# f_{2}$ | 0,1 | 0 | 0 | 1 |

whence

$$
X_{1}=f_{1}=A_{1} \cdot A_{2} \quad-\quad X_{2}=f_{2}=\bar{A}_{1} \cdot \bar{A}_{2}
$$

or
$X_{1}=f_{1}=A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2} \quad X_{2}=f_{2}=\bar{A}_{1} \cdot \bar{A}_{2}$
Summarizing, to find solutions to the equation $E$, (1) form \# $E$ and then $\left(E_{k i}\right)$, and (2) note that $\left(E_{k i}\right)=\left(R_{j i}\right)$, whence the solutions follow from ( $R_{j i}$ ).
2. Inverse Solution to Equations. Here the functions

$$
X_{s}=f_{s}\left(A_{1}, \ldots, A_{I}\right)
$$

are given, and the problem is to find an equation $E$. For example, given

$$
\begin{aligned}
& X_{1}=\bar{A}_{1} \cdot\left(A_{2} \cdot A_{3}+\bar{A}_{2} \cdot \bar{A}_{3}\right)+A_{1} \cdot \bar{A}_{2} \cdot A_{3}=f_{1} \\
& X_{2}=\bar{A}_{3} \cdot\left(A_{1}+A_{2}\right)+\bar{A}_{1} \cdot \bar{A}_{2} \cdot A_{3}
\end{aligned}
$$

what single equation has $X_{1}$ and $X_{2}$ as solutions? To determine ( $R_{j i}$ ), find, with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$,

$$
\begin{array}{ll}
\# f_{1}=1000 & 0110 \\
\# f_{2}=0111 & 1000
\end{array} \quad \text { whence }\left(R_{i i}\right)=\left(E_{k i}\right)=\left(\begin{array}{cc}
0000 & 0001 \\
1000 & 0110 \\
0111 & 1000 \\
0000 & 0000
\end{array}\right)
$$

and $\# E=0000 \quad 0001 \quad 1000 \quad 0110 \quad 0111 \quad 1000 \quad 0000 \quad 0000$
However, note that, if $E^{\prime}$ is an equation such that $E \rightarrow E^{\prime}$, then the solutions to $E$ are also solutions to $E^{\prime}$. This allows us the opportunity of choosing a more desirable $E^{\prime}$ for our equation.

To determine a good $E^{\prime}$, let us choose $E^{\prime}$ of the form

$$
H\left(A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right)=G\left(A_{1}, A_{2}, A_{3}\right)
$$

which is a form often found in circuit-design problems. Let us choose $G$ explicitly to be $A_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}+A_{2} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3}$. With respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}\right]$ we have

$$
\begin{array}{rlllllll}
\# E & =0000 & 0001 & 1000 & 0110 & & 0111 & 1000 \\
0000 & 0000 \\
\# G=0111 & 1101 & 0111 & 1101 & 0111 & 1101 & 0111 & 1101
\end{array}
$$

We determine $H$ so that $\# E=\#(G=H)$ :

$$
\# H=1000 \quad 0011 \quad 0000 \quad 0100 \quad 1111 \quad 1010 \quad 1000 \quad 0010
$$

That is, the bit of $\# H$ is the same as the corresponding bit in $\# G$ if $\# E$ has a unit in that position; in positions where $\# E$ has a zero, the cor-
responding bit in $\# H$ is different from that in \#G. However, this $H$ is too complicated; perhaps we can find an $E^{\prime}$ such that $E \rightarrow E^{\prime}$, for which $H$ will be simpler. Since $E \rightarrow E^{\prime}, \# E^{\prime}$ can be formed only by changing some zeros of $\# E$ to units, and this has a corresponding effect


Fig. 14-4. Example of inverse solution to equations.
on $\# H$. If $\Phi$ means that we can fix $\# E^{\prime}$ so that $\# H$ can have either a 0 or a 1 in that position, the choices for $\# H$ are seen to be

$$
\begin{array}{llllllll}
Ф Ф \Phi \Phi & \Phi \Phi \Phi 1 & 0 Ф \Phi \Phi & \Phi 10 \Phi & \Phi 111 & 1 \Phi \Phi \Phi & \Phi Ф \Phi \Phi & Ф Ф Ф \Phi
\end{array}
$$

One simple \#H that is included in these possibilities is
$\begin{array}{llllllll}0101 & 0101 & 0101 & 0101 & 1111 & 1111 & 0000 & 0000\end{array}$

$$
=\#\left(A_{1} \cdot \bar{X}_{2}+\bar{X}_{1} \cdot X_{2}\right)
$$

Hence we can have for the equation

$$
A_{1} \cdot \bar{X}_{2}+\bar{X}_{1} \cdot X_{2}=A_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}+A_{2} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3}
$$

Summarizing the technique, first (1) use $\left(R_{j i}\right)=\left(E_{k i}\right)$ to determine $\# E$ from $f_{1}, f_{2}, \ldots, f_{n}$; then (2) let $E=(H=G)$, where $G$ is given by the problem, and determine a simple $H$, making sure that $E^{\prime}$ is such that $E \rightarrow E^{\prime}$.

As an application of this procedure to circuit design, suppose that two circuits with inputs $A_{1}, A_{2}$, and $A_{3}$ have been constructed such that the output of one is $X_{1}=\bar{A}_{1} \cdot\left(A_{2} \cdot A_{3}+\bar{A}_{2} \cdot \bar{A}_{3}\right)+A_{1} \cdot \bar{A}_{2} \cdot A_{3}$ and of the other $X_{2}=\bar{A}_{3} \cdot\left(A_{1}+A_{2}\right)+\bar{A}_{1} \cdot \bar{A}_{2} \cdot A_{3}$. Suppose that it is now desired to gate the outputs of these circuits to form a new circuit whose output is $A_{1} \cdot A_{2}+A_{1} \cdot \bar{A}_{3}+A_{2} \cdot \bar{A}_{3}+\bar{A}_{2} \cdot A_{3}$. The problem is how to design the gating. The solution, as found above, appears in Fig. 14-4.

## EXERCISES

(a) Suppose that two circuits with outputs $X_{1}=\left(A_{1} \cdot \bar{A}_{2}+A_{2} \cdot \bar{A}_{3}\right)$ and $X_{2}=\left(\bar{A}_{1} \cdot A_{2}+\bar{A}_{2} \cdot A_{3}\right)$ have been built. How can the outputs of these circuits be gated so that the final output is the following $G$ ?

$$
G=A_{1} \cdot \bar{A}_{3}+A_{1} \cdot \bar{A}_{2}+A_{2} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot A_{3}
$$

One solution is $X_{1}+X_{2}=G$.
(b) Suppose that three circuits have already been built with outputs $X_{1}=A_{1} \cdot \bar{A}_{2}+$ $\bar{A}_{1} \cdot A_{2} \cdot A_{3}, X_{2}=\bar{A}_{1} \cdot A_{2}+\left(\bar{A}_{1}+\bar{A}_{2}\right) \cdot A_{3}, X_{3}=\bar{A}_{1} \cdot A_{2}+\left(\bar{A}_{1}+A_{2}\right) \cdot \bar{A}_{3} . \quad$ It is desired to form from these a circuit with output

$$
G=\left(A_{1} \cdot A_{2}+\bar{A}_{1} \cdot \bar{A}_{2}\right) \cdot \bar{A}_{3}+\left(A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right) \cdot A_{8}
$$

The problem is to form the desired circuit. One solution is

$$
X_{1} \cdot X_{2}+\bar{X}_{2} \cdot X_{3}=G
$$

## 14-6. More General Circuit-design Problems

Properties of the General Net. Until now the functions $f_{1}, f_{2}, \ldots, f_{J}$ were considered to be functions of $A_{1}, A_{2}, \ldots, A_{I}$ directly, that is, $f_{s}=f_{s}\left(A_{1}, \ldots, A_{I}\right)$. However, in the present section we extend our results to the more general situation where $f_{1}, f_{2}, \ldots, f_{J}$ are functions of other functions, say $g_{1}, g_{2}, \ldots, g_{P}$, that is, $f_{s}=f_{s}\left(g_{1}, \ldots, g_{P}\right)$; the functions $g_{1}, g_{2}, \ldots, g_{P}$ may themselves be considered in turn as functions of still other functions, and so forth, until finally a set of functions $h_{1}, h_{2}, \ldots, h_{Q}$ are direct functions of the $A_{1}, A_{2}, \ldots, A_{I}$. In Fig. 14-5 we give an example of three levels of such functions $f_{s}, g_{s}$, and $h_{s}$, although in general there can be as many levels as necessary, and each level can contain as many functions as necessary. In the most general case each function will involve all the functions of the preceding level.

The most important observation for our generalization is concerned with the $R$ matrices. If the functions $f_{1}, f_{2}, \ldots, f_{J}$ are given explicitly, then in the usual fashion the $R$ matrix can be derived (where $g_{1}, g_{2}, \ldots$, $g_{P}$ replaces the previous use of $A_{1}, A_{2}, \ldots, A_{I}$ ). Let us denote this matrix by $\left(R_{j p}{ }^{f}\right)$, where the superscript $f$ indicates that the $R$ matrix refers to the set of functions $f_{1}, f_{2}, \ldots, f_{J}$. Similarly, if the functions $g_{1}, g_{2}, \ldots, g_{P}$ are given explicitly, we can derive ( $R_{p q}{ }^{g}$ ), and so forth, until finally from an explicit form of $h_{1}, h_{2}, \ldots, h_{Q}$, we can derive ( $R_{q i}{ }^{h}$ ).

Now the function $F\left(f_{1}, \ldots, f_{J}, X_{1}, \ldots, X_{K}\right)$ has, in a manner of speaking, no way of knowing that the input wires $f_{1}, f_{2}, \ldots, f_{J}$ involve such a complicated net; it can still consider $f_{s}$ as an "eventual" function of $A_{1}, \ldots, A_{I}$. Hence $F$ "sees" a total matrix ( $R_{j i}$ ), as in the problem of Chap. 13. The important observation that we can make is that $\dagger$

[^8]\[

$$
\begin{equation*}
\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p q}{ }^{g}\right) \otimes \cdots \otimes\left(R_{q i}{ }^{h}\right)=\left(R_{j i}\right) \tag{14-1}
\end{equation*}
$$

\]

In other words, we are stating that for the general case the fundamental matrix equation (13-32) becomes

$$
\begin{equation*}
\left(F_{k j}\right) \otimes\left[\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p q}\right) \otimes \cdots \otimes\left(R_{q i}{ }^{h}\right)\right]=\left(E_{k i}\right) \tag{14-2}
\end{equation*}
$$

Similarly it is clear that if in the situation of Fig. 14-5 we let

$$
\left(R_{j q}{ }^{G}\right)=\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p q}{ }^{q}\right) \quad \text { and } \quad\left(R_{p i}^{H}\right)=\left(R_{p q}{ }^{q}\right) \otimes\left(R_{q i}{ }^{h}\right)
$$

we have

$$
\left(R_{j q}{ }^{G}\right) \otimes\left(R_{q i}{ }^{h}\right)=\left(R_{j i}\right) \quad \text { and } \quad\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p i}{ }^{H}\right)=\left(R_{j i}\right)
$$

and so forth. The general rule of thumb is that the $R$ matrix corresponding to a set of functions nearer $F$ appears nearer the left in the product, while the $R$ matrix corresponding to a set of functions farther from $F$ appears nearer the right in the product.


Fig. 14-5. The general circuit-design problem.
As an example, suppose that in Fig. 14-5 we had

$$
h_{1}=A_{2}+A_{3} \quad h_{2}=A_{1}+A_{3}
$$

whence

$$
\left(R_{\mathrm{gi}^{h}}{ }^{h}\right)=\left(\begin{array}{cc}
1000 & 0000 \\
0010 & 0000 \\
0100 & 0000 \\
0001 & 1111
\end{array}\right)
$$

and

$$
g_{1}=h_{1} \cdot h_{2} \quad g_{2}=\overline{h_{1}} \cdot \overline{h_{2}} \quad g_{3}=h_{1} \cdot \overline{h_{2}}
$$

whence

$$
\left(R_{p q^{g}}\right)=\left(\begin{array}{l}
0010 \\
0001 \\
1000 \\
0000 \\
0100 \\
0000 \\
0000 \\
0000
\end{array}\right)
$$

and

$$
\begin{gathered}
f_{1}=g_{1}+g_{2} \quad f_{2}=g_{2}+g_{3} \\
\left(R_{i p}{ }^{\prime}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
0100 & 0000 \\
0000 & 1000 \\
0011 & 0111
\end{array}\right)
\end{gathered}
$$

By algebraic means we have

$$
\begin{gathered}
f_{1}=\left(\overline{\left.A_{2}+A_{3}\right)} \cdot\left(A_{1}+A_{3}\right)+\left(\overline{A_{2}+A_{3}}\right) \cdot\left(\overline{A_{1}+A_{3}}\right)\right. \\
f_{2}=\left(\overline{A_{2}+A_{3}}\right) \cdot\left(\begin{array}{c}
A_{1}+A_{3}
\end{array}\right)+\left(A_{2}+A_{3}\right) \cdot\left(\begin{array}{c}
A_{1}+A_{3}
\end{array}\right) \\
\therefore \quad\left(R_{i i}\right)=\left(\begin{array}{ll}
0100 & 0000 \\
0001 & 1111 \\
0010 & 0000 \\
1000 & 0000
\end{array}\right)
\end{gathered}
$$

and
whence

To check this by our formula, we compute
$\left(\begin{array}{l}1000 \\ 0100 \\ 00000 \\ 0000 \\ 1000 \\ 0011\end{array} 0111\right)\left(\begin{array}{l}0010 \\ 0001 \\ 1000 \\ 0000 \\ 0100 \\ 0000 \\ 0000 \\ 0000\end{array}\right) \otimes\left(\begin{array}{ll}1000 & 0000 \\ 0010 & 0000 \\ 0100 & 0000 \\ 0001 & 1111\end{array}\right)=\left(\begin{array}{l}0010 \\ 0001 \\ 0100 \\ 1000\end{array}\right) \otimes\binom{1000}{0010}\left(\begin{array}{l}0000 \\ 0100 \\ 0000 \\ 0000 \\ 1111\end{array}\right)=\left(\begin{array}{l}0100 \\ 0001 \\ 0000 \\ 0010 \\ 00000 \\ 1000\end{array}\right)$
as expected.
Solving Circuit-design Problems. For circuit-design problems of type 1 the extension of the problem presents nothing new, except that the overall ( $R_{j i}$ ) matrix is computed from the individual-level $R$ matrices according to the method just described. Similarly, for circuit-design problems of type 2 little change is required in the method of solution, ( $R_{j i}$ ) being calculated from the individual-level $R$ matrices by Eq. (14-1). However, consider problems of type 3. Here as before, given ( $F_{k_{j}}$ ) and ( $E_{k i}$ ), all possible over-all ( $R_{j i}$ ) can be computed. However, suppose that it is known, for example, that there are three levels of functions, namely, $f_{s}, g_{s}$, and $h_{s}$, and that the function sets $g_{s}$ and $h_{s}$ are known explicitly; then it might be required to find the function set $f_{s}$. In this case from Eq. (14-1) we have

$$
\left(R_{j p^{f}}\right) \otimes\left[\left(R_{p q}{ }^{q}\right) \otimes\left(R_{q i}{ }^{h}\right)\right]=\left(R_{j i}\right)
$$

where ( $R_{j i}$ ) has just been calculated and the matrices in the square brackets are known. Thus, to find ( $R_{j p}{ }^{f}$ ), that is, the function set $f_{s}$, simply solve the equation for the matrix $\left(R_{j p}{ }^{j}\right)$, using Eqs. (13-19) and their correspondent from Exercise $e$ of Sec. 13-5. This technique can be used, for the product in the square brackets will be of the form $\left(U_{p i}\right)$, and ( $R_{j_{p}{ }^{f}}$ ) corresponds to ( $a_{j p}$ ) considered in that section. If on the other hand ( $R_{j p}{ }^{f}$ ) and ( $R_{q i}{ }^{h}$ ) are known explicitly and it is desired to find ( $R_{p q}{ }^{q}$ ), we would write

$$
\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p q}{ }^{g}\right) \otimes\left(R_{q i}{ }^{h}\right)=\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p i} i^{j b}\right)=\left(R_{j i}\right)
$$

and solve for ( $R_{p i}{ }^{\text {ah }}$ ), by the methods of Sec. 13-5. When ( $R_{p i} i^{\text {ah }}$ ) has been determined, we would solve

$$
\left(R_{p q}{ }^{q}\right) \otimes\left(R_{q i}{ }^{h}\right)=\left(R_{p i} i^{a h}\right)
$$

for the desired $\left(R_{p q}{ }^{q}\right)$.
Summarizing, to solve circuit-design problems of type 3, the over-all ( $R_{j i}$ ) matrix is first computed as usual from the appropriate fundamental formulas. Next by Eqs. (13-15) and (13-16), Eq. (14-1) relating the level $R$ matrices with ( $R_{j i}$ ) is solved for the desired results. As is immediately clear, there are in general many ways of tackling the same problems, using different variations of the techniques presented.

Examples. As a first example, consider a circuit synthesis problem, and suppose that the situation is as in Fig. 14-5, where $h_{1}=A_{2}+A_{3}$, $h_{2}=A_{1}+A_{3}, g_{1}=h_{1} \cdot h_{2}, g_{2}=\bar{h}_{1} \cdot \bar{h}_{2}, g_{3}=h_{1} \cdot \overline{h_{2}}$, $F=\left(\bar{f}_{1}+f_{2}\right) \cdot X_{1} \cdot \bar{X}_{2}+\left(f_{1}+f_{2}\right) \cdot \bar{X}_{1} \cdot X_{2}+\left(f_{1} \cdot f_{2}+\bar{f}_{1} \cdot \bar{f}_{2}\right) \cdot \bar{X}_{1} \cdot \bar{X}_{2}$ and $E=\left(\bar{A}_{2} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot \bar{A}_{3} \cdot X_{1}\right) \cdot \bar{X}_{2}+\left(\bar{A}_{1}+A_{2}+A_{3}\right) \cdot \bar{X}_{1} \cdot X_{2}$ are all given. That is to say, the circuits $h_{1}, h_{2}, g_{1}, g_{2}$, and $g_{3}$ have already been constructed and wired together; the circuit $F$ has already been built. It is desired to determine how to build circuits $f_{i}$ and $f_{2}$, with inputs $g_{1}, g_{2}$, and $g_{3}$, so that the output of the entire system in terms of $A_{1}, A_{2}$, $A_{3}, X_{1}$, and $X_{2}$ will be the function $E$.

First we determine ( $R_{j i}$ ) by the type 3 formulas, finding

$$
\left(R_{j i}\right)=\left(\begin{array}{ll}
0100 & 0000 \\
0001 & 1111 \\
0010 & 0000 \\
1000 & 0000
\end{array}\right)
$$

as the only common antecedence and consequence solution. Next we observe that

$$
\left(R_{p q^{g}}\right) \otimes\left(R_{q i^{i}}\right)=\left(\begin{array}{ll}
0100 & 0000 \\
0001 & 1111 \\
1000 & 0000 \\
0000 & 0000 \\
0010 & 0000 \\
0000 & 0000 \\
0000 & 0000 \\
0000 & 0000
\end{array}\right)=\left(R_{p i}{ }^{H}\right)
$$

whence we desire to solve $\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p i}{ }^{H}\right)=\left(R_{j i}\right)$ for the matrix $\left(R_{j p}{ }^{f}\right)$. It turns out [from Eqs. (13-23) and (13-24)] that

$$
\left(R_{i p}{ }^{f \prime}\right)=\left(\begin{array}{ll}
1001 & 0111 \\
0101 & 0111 \\
0001 & 1111 \\
0011 & 0111
\end{array}\right) \quad\left(R_{i p^{f}}{ }^{f *}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
0100 & 0000 \\
0000 & 1000 \\
0010 & 0000
\end{array}\right)
$$

whence by Eq. (13-25) $\quad\left(R_{i p}{ }^{f}\right)=\left(\begin{array}{ll}100 \Phi & 0 \Phi \Phi \Phi \\ 010 \Phi & 0 \Phi \Phi \Phi \\ 000 \Phi & 1 \Phi \Phi \Phi \\ 001 \Phi & 0 \Phi \Phi \Phi\end{array}\right)$
Columns 0,1 , and 2 indicate that $f_{1}$ must involve $g_{1}$ and $g_{2}$, and columns 0 , 2 , and 4 indicate that $f_{2}$ must involve $g_{2}$ and $g_{3}$ (by the elimination pairs of positions). Hence a simple solution is seen to be:

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# f_{1}$ | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | $=g_{1}+g_{2}$ |
| $\# f_{2}$ | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | $=g_{2}+g_{3}$ |

Another set of valid solutions is:

| $\# f_{1}$ | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\# f_{2}$ | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 |
|  | $=g_{1} \cdot \bar{g}_{2}+\bar{g}_{1} \cdot g_{2}$ |  |  |  |  |  |  |  |
| $g_{2} \cdot \bar{g}_{3}+\bar{g}_{2} \cdot g_{3}$ |  |  |  |  |  |  |  |  |

As the second example, consider a circuit-maintenance problem. Suppose that a circuit has been constructed such that

$$
\begin{gathered}
g_{1}=A_{1} \cdot \bar{A}_{2}+A_{2} \cdot \bar{A}_{3} \quad g_{2}=A_{2} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot A_{3} \\
f_{1}=g_{1}+\bar{g}_{2} \\
F=f_{1} \cdot \bar{f}_{2}+\bar{f}_{1} \cdot f_{2}
\end{gathered}
$$

The output of this circuit is seen to be $E=A_{1} \cdot \bar{A}_{2}+\left(\bar{A}_{1}+\bar{A}_{2}\right) \cdot A_{3}$, where $\# E=0100$ 1110. Now suppose that the circuit breaks down, that it does not produce the proper output. The problem is to determine which of the circuits $g_{1}, g_{2}, f_{1}, f_{2}$, or $F$ is not operating correctly. The information at our disposal for this investigation is (1) the original circuit design, i.e., the explicit (correct) functions $g_{1}, g_{2}, f_{1}, f_{2}$, and $F$, and (2) how the circuit is malfunctioning. This latter information is obtained by putting into the $A_{1}, A_{2}$, and $A_{3}$ inputs each of the eight possible input states and recording the output bit for each state. Suppose that these output states are 00001010 for the usual successive input-state order as given by the standard basis. This malfunctioning-output result is of course actually the designation number of the output of the malfunctioning circuit with respect to $b\left[A_{1}, A_{2}, A_{3}\right]$, that is,

$$
\# E_{m}\left(A_{1}, A_{2}, A_{3}\right)=0000 \quad 1010
$$

Our purpose is to use this information to explore all possible ways in
which the circuits $f_{1}, f_{2}, g_{1}, g_{2}$, and $F$ can malfunction to give the output result $\# E_{m}$.

Let us begin by first making the reasonable assumption that only one of these circuits is malfunctioning. To be specific, let us see whether $f_{1}$ or $f_{2}$ can malfunction to produce $\# E_{m}$. Observe that $\# F=0110$, whence

$$
\begin{aligned}
& \left(F_{i 0}\right) \otimes\left(\bar{E}_{0 i}\right)=\left(\begin{array}{l}
0 \\
1 \\
1 \\
0
\end{array}\right) \otimes\left(\begin{array}{ll}
1111 & 0101
\end{array}\right)=\left(\begin{array}{ll}
0000 & 0000 \\
1111 & 0101 \\
1111 & 0101 \\
0000 & 0000
\end{array}\right) \quad\left(R_{j i}\right)_{a}=\left(\begin{array}{ll}
1111 & 1111 \\
0000 & 1010 \\
0000 & 1010 \\
1111 & 0101
\end{array}\right) \\
& \left(\bar{F}_{i 0}\right) \otimes\left(E_{0 i}\right)=\left(\begin{array}{l}
1 \\
0 \\
0 \\
1
\end{array}\right) \otimes\left(\begin{array}{ll}
0000 & 1010
\end{array}\right)=\left(\begin{array}{ll}
0000 & 1010 \\
0000 & 0000 \\
0000 & 0000 \\
0000 & 1010
\end{array}\right) \quad\left(R_{j i}\right)_{c}=\left(\begin{array}{ll}
1111 & 0101 \\
1111 & 1111 \\
1111 & 1111 \\
1111 & 0101
\end{array}\right) \\
& \text { and }\left(R_{j i}\right)=\left(\begin{array}{ll}
1111 & 0101 \\
0000 & 1010 \\
0000 & 1010 \\
1111 & 0101
\end{array}\right) . \quad \text { Next we observe that }\left(R_{p i} \sigma\right)=\left(\begin{array}{ll}
1000 & 0001 \\
0100 & 0100 \\
0000 & 1010 \\
0011 & 0000
\end{array}\right) .
\end{aligned}
$$

Hence, solving $\left(R_{j p}{ }^{f}\right) \otimes\left(R_{p i}{ }^{0}\right)=\left(R_{j i}\right)$ for $\left(R_{j p}{ }^{f}\right)$, find

$$
\begin{aligned}
& \left(R_{i p^{\prime \prime}}\right)=\left(\begin{array}{ll}
0000 & 1010 \\
1111 & 0101 \\
1111 & 0101 \\
0000 & 1010
\end{array}\right) \otimes\left(\begin{array}{l}
1000 \\
0100 \\
0001 \\
0001 \\
0010 \\
0100 \\
0010 \\
1000
\end{array}\right)=\left(\begin{array}{l}
1101 \\
0010 \\
0010 \\
1101
\end{array}\right) \\
& \left(R_{i p^{f *}}\right)=\left(\begin{array}{ll}
1000 \\
0100 \\
0001 \\
0000 & 1010 \\
1111 & 010
\end{array}\right) \otimes\left(\begin{array}{l}
0101 \\
0001 \\
0010 \\
0100 \\
0010 \\
1000
\end{array}\right)=\left(\begin{array}{l}
1101 \\
0010 \\
0010 \\
1101
\end{array}\right)
\end{aligned}
$$

Hence $\left(R_{p i}{ }^{f}\right)=\left(\begin{array}{l}1101 \\ 0010 \\ 0010 \\ 1101\end{array}\right)$ with the result array:

|  | 0 | 1 | 2 | 3 |
| :---: | :---: | :---: | :---: | :---: |
| $f_{1}$ | 0,1 | 0,1 | 0,1 | 0,1 |
| $f_{2}$ | 0,1 | 0,1 | 1,0 | 0,1 |

giving all possible pairs of functions that will result in the malfunctioning. Suppose that $f_{1}$ is good; then since $\# f_{1}=\#\left(g_{1}+\bar{g}_{2}\right)=1101$, we find that $\# f_{2}=1111=\# I$, which is certainly a reasonable way for a malfunctioning circuit to act. Suppose instead that we assume that $f_{2}$ is good; then since $\# f_{2}=\#\left(\bar{g}_{1}+g_{2}\right)=1011$, we find that

$$
\# f_{1}=1001=\#\left(g_{1} \cdot g_{2}+\bar{g}_{1} \cdot \bar{g}_{2}\right)
$$

which is rather an unreasonable way for a circuit to break. Of course the evaluation of alternative malfunctioning explanations ultimately depends on the electronic design of the circuit. Similarly the circuits $g_{1}, g_{2}$, and $F$ could be examined.

## EXERCISES

(a) For the circuit-maintenance problem discussed above explore the possibilities of malfunctioning circuits $g_{1}, g_{2}$, and $F$ that can explain the erroneous output \# $E_{m}$.
(b) For the circuit-synthesis problem discussed above suppose that the following circuits have already been built: $h_{1}=A_{2}+A_{3}, h_{2}=A_{1}+A_{3}, f_{1}=g_{1}+g_{2}$, and $f_{2}=g_{2}+g_{3}$, with $F$ as described above. How can the circuits $g_{1}, g_{2}$, and $g_{3}$ be constructed so that when wired in as shown in Fig. 14-5 the function $E$ described above will result?

## 14-7. Additional Topics $\dagger$

a. Logical Interpretation of Antecedence and Consequence Solutions, and Examples. The majority of logical problems involve given or accepted premises, hypotheses, rules, or other logical relationships which are the given equations and essentially comprise the statement of the problems. There are two types of solutions to a set of given equations, the antecedence solutions and the consequence solutions. Antecedence solutions are hypotheses or theories from which the given equations can be deduced; consequence solutions can be deduced from the given equations. In other words, the truth of the antecedence solutions is sufficient for the truth of the given equations, but the truth of the consequence solutions is necessary for the truth of the given equations. If the given equations are true, then the consequence solutions are true, while the antecedence solutions may or may not be true; but the truth of the given equations can be deduced from the hypotheses embodied in the antecedence solutions, this latter being the method for theory construction. In terms of our above notation the function $E$ represents the given equations and the functions $F_{a}$ and $F_{c}$ the antecedence and consequence solutions, respectively.
First Example. Suppose that the Lower Slobbovian army had three kinds of companies: rifle companies $A_{1}$, machine-gun companies $A_{2}$, and submachine-gun companies $A_{3}$. Consider, in addition, the following pieces of equipment: a light machine gun $X_{1}$, a scout car $X_{2}$, and a submachine gun $X_{3}$. Now suppose that

[^9]military intelligence has determined that the distinguishing features that identify the three types of companies in terms of the equipment they carry are as follows:
\[

$$
\begin{aligned}
& A_{1}=X_{1} \cdot \bar{X}_{3}+X_{2} \cdot X_{3} \\
& A_{2}=X_{2} \cdot \bar{X}_{3}+\bar{X}_{1} \cdot X_{3} \\
& A_{3}=\bar{X}_{1} \cdot \bar{X}_{2}+X_{2} \cdot X_{3}
\end{aligned}
$$
\]

It happened that in a certain field an observer noticed that soldiers were carrying either machine guns or submachine guns, or both, he could not be sure, and there was no scout car-i.e., the observer reported $\left(X_{1}+X_{3}\right) \cdot \bar{X}_{2}$. Suppose in addition that it was known that a submachine-gun company never accompanies a machine-gun company, that is, $A_{3} \rightarrow \bar{A}_{2}$. The problem then is: Assuming that at least one is present in the field, what companies of the Lower Slobbovian army are in the field? In more precise form the problem is: What are the consequence solutions to the given intelligence equations, of the form

$$
\left(X_{1}+X_{3}\right) \cdot \bar{X}_{2}=f\left(A_{1}, A_{2}, A_{3}\right)
$$

under the constraint $A_{3} \rightarrow \bar{A}_{2}$ ? To solve this problem, find

$$
\left(F_{i k}\right)=\left(\begin{array}{ll}
1011 & 0011 \\
0100 & 1100
\end{array}\right) \quad\left(E_{k i}\right)=\left(\begin{array}{cc}
0000 & 1000 \\
0100 & 0000 \\
0010 & 0000 \\
0001 & 0000 \\
0000 & 0010 \\
1000 & 0000 \\
0000 & 0001 \\
0000 & 0100
\end{array}\right)
$$

Hence

$$
\begin{aligned}
\left(R_{i i}\right) & =\left(\begin{array}{ll}
0011 & 1101 \\
1100 & 0010
\end{array}\right) \\
\# f & =\begin{array}{ll}
1100 & 0010
\end{array}
\end{aligned}
$$

and
However, at least one company must be in the field-that is, $A_{1}+A_{2}+A_{3}=I$ is a second constraint. Since $\#\left(A_{1}+A_{2}+A_{3}=I\right)=01111111$ and $\#\left(A_{3} \rightarrow \bar{A}_{2}\right)=$ 1111 1100, we find that

$$
\# f=.100 \quad 00 \ldots=A_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}
$$

In other words, from the observer report, together with the given intelligence information, it can be deduced that only $A_{1}$, a rifle company, is in the field.

Second Example. In biochemistry an enzyme often cannot be isolated easily, and therefore experiments performed with one enzyme often will involve several others. Consequently a combination of reactions must be observed. In such a complex situation the ordinary, simple logical analysis usually employed in experimental sciences is found inadequate. In these cases our logical computational methods can be extremely useful for evaluating experimental results and planning future experiments to yield the maximum information.

Suppose that a chemist is studying enzymes $A_{1}, A_{2}, A_{3}$ in relation to reactions $X_{1}$, $X_{2}, X_{3}$. Suppose that he has done the following four experiments: $\left(E_{1}\right)$ A solution containing none of $A_{1}, A_{2}, A_{3}$ produced reaction $X_{2}$, but not $X_{1}$ and not $X_{3}$. ( $E_{2}$ ) The
solution contained $A_{1}$ and either $A_{2}$ or $A_{3}$, or both; he could not be sure. $\because$ The reaction was neither $X_{2}$ nor both $X_{1}$ and $X_{3}$. ( $E_{3}$ ) The solution had $A_{2}$ but not $A_{1}$ or else did not have $A_{2}$ but had $A_{3}$. Reactions $X_{1}$ and $X_{2}$ occurred, or reaction $X_{3}$ occurred, but $X_{1}$ did not. ( $E_{4}$ ) The solution was obtained from a source that had $A_{3}$, and $A_{1}$ or $A_{2}$ or both, or else had neither $A_{1}$ nor $A_{3}$; the solution turns color, which means that $X_{1}$ does not take place or that both $X_{2}$ and $X_{3}$ do.
The antecedence problem is: What theories about the enzymes associated with each reaction will explain the experimental results? The consequence problem is: What combinations of enzymes are necessary for each reaction to take place?

The experiments and their designation numbers with respect to $b\left[A_{1}, A_{2}, A_{3}, X_{1}, X_{2}, X_{3}\right]$ are as follows:


For the antecedence problem the form of the solution is $X_{1}=f_{1}, X_{2}=f_{2}, X_{3}=f_{3}$. Recall for antecedence solutions of this special form that $\left(E_{k i}\right)=\left(R_{i i}\right)$. Hence

$$
\left(E_{k i}\right)=\left(R_{j i}\right)=\left(\begin{array}{ll}
0000 & 0001 \\
0001 & 0000 \\
1000 & 0000 \\
0000 & 1000 \\
0000 & 0100 \\
0100 & 0000 \\
0010 & 0010 \\
0010 & 0010
\end{array}\right)
$$

from which the solutions are read.
Result Array

| $\# f_{1}$ | 0 | 1 | 1,0 | 1 | 1 | 0 | 1,0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\# f_{2}$ | 1 | 0 | 1,1 | 0 | 1 | 0 | 1,1 | 0 |
| $\# f_{3}$ | 0 | 1 | 1,1 | 0 | 0 | 1 | 1,1 | 0 |

Thus there are four sets of antecedence solutions of the form $X_{s}=f_{s}$, namely,

$$
\begin{aligned}
& X_{1}=f_{1}=A_{1} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot A_{2}, \text { or } \bar{A}_{3} \cdot\left(A_{1}+A_{2}\right)+\bar{A}_{1} \cdot \bar{A}_{2} \cdot A_{3}, \\
& \text { with } \quad \text { or }_{3} \cdot\left(A_{1}+A_{2}\right)+\bar{A}_{1} \cdot A_{3}, \text { or } A_{1} \cdot \bar{A}_{3}+\bar{A}_{1} \cdot \bar{A}_{2} \cdot A_{3} \\
& \quad X_{2}=f_{2}=\bar{A}_{1} \quad \text { and } \quad X_{3}=f_{3}=A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}
\end{aligned}
$$

The first two sets are logically independent. The last two sets of solutions imply that the reactions are not independent but that $X_{2} \cdot X_{3} \rightarrow X_{1}$ and $X_{1} \cdot X_{2} \cdot X_{3}=0$, respectively. For the consequence problem, the form of the solution and corresponding designation numbers with respect to $b\left[f_{1}, f_{2}, f_{3}, X_{1}, X_{2}, X_{3}\right]$ are as follows:
$\#\left(X_{1} \rightarrow f_{1}\right)=$
1111111101010101111111110101010111111111010101011111111101010101 $\#\left(X_{2} \rightarrow f_{2}\right)=$
1111111111111111001100110011001111111111111111110011001100110011 $\#\left(X_{3} \rightarrow f_{3}\right)=$
1111111111111111111111111111111100001111000011110000111100001111 $\#\left[\left(X_{1} \rightarrow f_{1}\right) \cdot\left(X_{1} \rightarrow f_{2}\right) \cdot\left(X_{3} \rightarrow f_{3}\right)\right]=$
1111111101010101001100110001000100001111000001010000001100000001
Hence $\dagger$

$$
\left(F_{j k}\right)=\left(\begin{array}{ll}
1000 & 0000 \\
1100 & 0000 \\
1010 & 0000 \\
1111 & 0000 \\
1000 & 1000 \\
1100 & 1100 \\
1010 & 1010 \\
1111 & 1111
\end{array}\right) \quad \text { and } \quad\left(R_{i i}\right)=\overline{\left(\bar{F}_{j k}\right) \otimes\left(E_{k i}\right)}=\left(\begin{array}{cc}
0000 & 0001 \\
0001 & 0001 \\
1000 & 0001 \\
1001 & 1001 \\
0000 & 0101 \\
0101 & 0101 \\
1000 & 0101 \\
1111 & 1111
\end{array}\right)
$$

This gives the result array:

| $\# f_{1}$ | 1010 | 11 | 1 | 1111 | 11 | 1010 | 1 | $\Phi$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\# f_{2}$ | 1111 | 10 | 1 | 1010 | 11 | 1100 | 1 | $\Phi$ |
| $\# f_{3}$ | 1100 | 11 | 1 | 1100 | 10 | 1111 | 1 | $\Phi$ |

The most significant set of solutions for this form is the minimum set, i.e., the solutions with the most zeros; we choose

$$
\begin{aligned}
& \# f_{1}=0111 \quad 1010=\#\left[\bar{A}_{3} \cdot\left(A_{1}+A_{2}\right)+\bar{A}_{1} \cdot A_{3}\right] \\
& \# f_{2}=1010 \quad 1010=\# \bar{A}_{1} \\
& \# f_{3}=0110 \quad 0110=\#\left[A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}\right] \\
& X_{1} \rightarrow \bar{A}_{3} \cdot\left(A_{1}+A_{2}\right)+\overline{A_{1}} \cdot A_{3} \\
& X_{2} \rightarrow \bar{A}_{1} \\
& X_{3} \rightarrow A_{1} \cdot \bar{A}_{2}+\bar{A}_{1} \cdot A_{2}
\end{aligned}
$$

or
b. Boolean Matrix Equations in Three Values. Until now we have been considering Boolean matrices the elements of which can be either 0 or 1 . Suppose now that the elements of the matrix can take on three values, say 0 , 1, and 2. However, we must define our operations for these values. Suppose that we define the operations + and $\cdot$ as in Sec. 12-11d, namely,

| + | 0 | 1 | 2 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 2 |
| 1 | 1 | 1 | 2 |
| 2 | 2 | 2 | 2 |

and

| $\cdot$ | 0 | 1 | 2 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 2 | 0 | 1 | 2 |

with the - as $\overline{0}=1, \overline{1}=2$, and $\overline{2}=0$. Then the matrix equation

$$
\left(a_{i k}\right) \otimes\left(x_{k i}\right)=\left(b_{i j}\right)
$$

means

$$
b_{i j}=\sum_{k} a_{i k} \cdot x_{k j}
$$

$\dagger\left(F_{i k}\right)=\left(F_{k i}\right)^{T}$.
where the summation and product are computed as above. Using the analogy of the solution to the two-valued matrix equations, we shall find an ( $x_{k j}^{\prime}$ ) solution such that, if $\left(x_{k j}\right)$ is also a solution, then $\left(x_{k i}\right) \rightarrow\left(x_{k i}^{\prime}\right)$. Here we use the $\rightarrow$ in the sense $0 \rightarrow 1 \rightarrow 2,0 \rightarrow 0,1 \rightarrow 1,2 \rightarrow 2$. Also $\left(p_{k_{j}}\right) \rightarrow\left(q_{k_{i}}\right)$ if $p_{k i} \rightarrow q_{k j}$ for each $k$ and $j$. In order to determine our ( $x_{k j}^{\prime}$ ), let us first observe that for a particular ( $a_{i k}$ ) and ( $b_{i j}$ ) the greatest value that $x_{k j}$ can take so that $a_{i k} \cdot x_{k j} \rightarrow b_{i j}$ is as follows (where "greatest" is in terms of our $\rightarrow$ relation):

| $a_{i k}$ | 012 | 012 | 012 |
| :--- | :--- | :--- | :--- |
| $b_{i j}$ | 000 | 111 | 222 |
| $x_{k j}$ | 200 | 221 | 222 |

For example, if $a_{i k}=0$ and $b_{i j}=0$, then $0 \cdot 2=0 \rightarrow 0$ so that $x_{k j}$ can be $0,1,2$; the remaining eight cases are treated similarly. In terms of our three-valued operations we may write (omitting the subscripts) $x=\overline{a+\bar{a}}+\overline{(b+\bar{b})} \cdot \bar{a}+b$. Now consider a new operation, denoted by c as derived from this relation:

|  |  | 0 | $b$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | 1 | 2 |
|  | 0 |  | 2 | 2 | 2 |
| $a$ | 1 | 0 | 2 | 2 |
|  | 2 | 0 | 1 | 2 |

(Note that this operation is not commutative.) Based on this definition, consider the matrix operation

$$
\left(a_{k i}\right) \subset\left(b_{i j}\right)=\left(c_{k j}\right)
$$

defined by

$$
c_{k j}=\prod_{i}\left(a_{k i} \mathbf{c} b_{i j}\right)=\min \left(a_{k i} \mathbf{c} b_{i j}\right)
$$

Then

$$
\left(x_{k j}^{\prime}\right)=\left(a_{i k}\right)^{T} \text { © }\left(b_{i j}\right)
$$

is the desired solution. If a solution to aur original matrix equation exists, then

Otherwise

$$
\begin{aligned}
& \left(a_{i k}\right) \otimes\left[\left(a_{i k}\right)^{T} \Subset\left(b_{i j}\right)\right]=\left(b_{i j}\right) \\
& \left(a_{i k}\right) \otimes\left[\left(a_{i k}\right)^{T} \mathbb{C}\left(b_{i j}\right)\right] \rightarrow\left(b_{i j}\right)
\end{aligned}
$$

c. Problems of Types 1 and 2 in Three Values. With the above in mind we can extend our matrix methods for antecedence and consequence solutions to this threevalued logic. The matrix ( $E_{k i}$ ) is now formed from a designation number with three possible values for each position, and similarly for ( $F_{k_{j}}$ ). The matrix ( $R_{i i}$ ) must now have only a single 2 in each column, in order to perform the necessary pseudopermutation. Then the fundamental equation

$$
\left(F_{k j}\right) \otimes\left(R_{j i}\right)=\left(E_{k i}\right)
$$

still holds. For example, let $F=\left(\overline{f_{1}+\bar{f}_{2}}\right) \cdot X, f_{1}=\overline{A_{1} \cdot \overline{A_{2}}}$, and $f_{2}=\overline{A_{1}+\overline{A_{2}}}$. Then

| $\# f_{1}=012$ | 012 | 012 | 012 | 012 | 012 | 012 | 012 | 012 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\# f_{2}=000$ | 111 | 222 | 000 | 111 | 222 | 000 | 111 | 222 |
| $\# X=000$ | 000 | 000 | 111 | 111 | 111 | 222 | 222 | 222 |
| $\# F=000$ | 000 | 000 | 110 | 000 | 110 | 220 | 000 | 120 |
|  |  |  | 012 | 345 | 678 |  |  |  |
|  |  | $\# A_{1}=012$ | 012 | 012 |  |  |  |  |
|  |  | $\# A_{2}=000$ | 111 | 222 |  |  |  |  |
|  |  | $\# f_{1}=122$ | 120 | 111 |  |  |  |  |
|  |  | $\# f_{2}=220$ | 000 | 120 |  |  |  |  |

Hence $\quad\left(F_{k j}\right)=\left(\begin{array}{lll}000 & 000 & 000 \\ 110 & 000 & 110 \\ 220 & 000 & 120\end{array}\right) \quad$ and $\quad\left(R_{i i}\right)=\left(\begin{array}{lll}000 & 002 & 000 \\ 000 & 200 & 002 \\ 002 & 020 & 000 \\ 000 & 000 & 000 \\ 000 & 000 & 200 \\ 000 & 000 & 000 \\ 000 & 000 & 000 \\ 200 & 000 & 020 \\ 020 & 000 & 000\end{array}\right)$

Then $\quad\left(F_{k_{j}}\right) \otimes\left(R_{j i}\right)=\left(\begin{array}{ccc}000 & 000 & 000 \\ 100 & 101 & 011 \\ 200 & 202 & 022\end{array}\right)=\left(E_{k i}\right)$
or

$$
\# E=000 \quad 000 \quad 000 \quad 100 \quad 101 \quad 011 \quad 200
$$

and

$$
E=\left\{\left(\overline{A_{1}+\bar{A}_{1}}\right) \cdot\left(\overline{A_{2}+\bar{A}_{2}}\right)+\left(\overline{\overline{A_{1} \cdot \overline{\bar{A}}_{1}}}\right) \cdot\left(\overline{\left(\overline{A_{2}+\bar{A}_{2}}\right)}+\left(\overline{\left.\overline{\bar{A}_{1} \cdot \overline{\bar{A}}_{1}}\right)} \cdot\left(\overline{\left(\bar{A}_{2}+\bar{A}_{2}\right.}\right)\right\} \cdot X\right.\right.
$$

Thus it is clear how to solve problems of type 1, that is, substitution problems. For type 2 problems we solve the fundamental equation by finding

$$
\left(F_{j k}\right)=\left(R_{j i}\right) \Subset\left(E_{i k}\right)
$$

and then substitute into

$$
\left(F_{k i}\right) \otimes\left(R_{j i}\right)=\left(E_{k i}^{\prime}\right)
$$

to determine whether or not $\left(E_{k i}^{\prime}\right)=\left(E_{k i}\right)$, that is, whether or not a solution to the circuit-design problem actually exists.

Suppose that

$$
f_{1}=\overline{A_{1} \cdot \bar{A}_{2}} \quad f_{2}=\overline{A_{1}+\overline{A_{2}}}
$$

and

$$
E=\left\{\left(\overline{A_{1}+\bar{A}_{1}}\right) \cdot\left(\overline{A_{2}+\bar{A}_{2}}\right)+\overline{\overline{A_{1} \cdot \bar{A}_{1}}}\right) \cdot\left(\overline{\left(\overline{A_{2}+\bar{A}_{2}}\right)}+\overline{\left(\overline{\overline{\bar{A}_{1} \cdot \overline{\bar{A}}_{1}}}\right) \cdot\left(\overline{\left(\overline{A_{2}+\bar{A}_{2}}\right)}\right\} \cdot X, ~}\right.
$$

as above; then, to find $F$, we compute

$$
\left(\begin{array}{lll}
000 & 002 & 000 \\
000 & 200 & 002 \\
002 & 020 & 000 \\
000 & 000 & 000 \\
000 & 000 & 200 \\
000 & 000 & 000 \\
000 & 000 & 000 \\
200 & 000 & 020 \\
020 & 000 & 000
\end{array}\right) \odot\left(\begin{array}{l}
012 \\
000 \\
000 \\
012 \\
000 \\
012 \\
000 \\
012 \\
012
\end{array}\right)=\left(\begin{array}{l}
012 \\
012 \\
000 \\
222 \\
000 \\
222 \\
222 \\
012 \\
000
\end{array}\right)=\left(F_{j k}\right)
$$

Since $f_{1}$ and $f_{2}$ are constrained, we find $F$ with respect to the constrained basis,

which is now the same as the $F$ used above.
There are two other equivalent forms to the fundamental equation which follow directly, since ( $R_{j i}$ ) is a pseudopermutation:

$$
\left(\bar{F}_{k j}\right) \otimes\left(R_{i i}\right)=\left(\bar{E}_{k i}\right) \quad \text { and } \quad\left(\bar{F}_{k i}\right) \otimes\left(R_{j i}\right)=\left(\bar{E}_{k i}\right)
$$

These give rise to three types of logical problems: antecedence, intercedence, and consequence problems. Can you find equations analogous to the fundamental formulas for type 2 problems corresponding to antecedence, intercedence, and consequence problems?
d. M-valued Post $\dagger$ Logics. The three-valued logic discussed above has the property that $+(a, b)=\max (a, b)$ and $\cdot(a, b)=\min (a, b)$, where $0<1<2$ as usual. Also the - permuted cyclically $0,1,2$. We can generalize these operations to $(m+1)$ values $0,1,2, \ldots, m$ and define $+(a, b)=\max (a, b), \cdot(a, b)=\min (a, b)$, and - to permute cyclically. For example, for five-valued logic we would have

| + | 0 | 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 2 | 3 | 4 |
| 1 | 1 | 1 | 2 | 3 | 4 |
| 2 | 2 | 2 | 2 | 3 | 4 |
| 3 | 3 | 3 | 3 | 3 | 4 |
| 4 | 4 | 4 | 4 | 4 | 4 |


| $\cdot$ | 0 | 1 | 2 | 3 | 4 |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 |  |
| 1 | 0 | 1 | 1 | 1 | 1 | $\overline{0}=1$ |
| 2 | 0 | 1 | 2 | 2 | 2 | $\overline{1}=2$ |
| 3 | 0 | 1 | 2 | 3 | 3 | $\overline{3}=3$ |
| 4 | 0 | 1 | 2 | 3 | 4 | $\overline{4}=4$ |
|  |  |  |  |  |  |  |

All the above results can be directly carried over, provided that the c operation becomes

| $\mathbf{c}$ | 0 | 1 | 2 | 3 | $\cdots$ | $m$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $m$ | $m$ | $m$ | $m$ | $\cdots$ | $m$ |
| 1 | 0 | $m$ | $m$ | $m$ | $\cdots$ | $m$ |
| 2 | 0 | 1 | $m$ | $m$ | $\cdots$ | $m$ |
| 3 | 0 | 1 | 2 | $m$ | $\cdots$ | $m$ |
| 4 | 0 | 1 | 2 | 3 | $\cdots$ | $m$ |
| $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ | $\cdots$ |
| $m$ | 0 | 1 | 2 | 3 | $\cdots$ | $m$ |

or for five-valued logic

| c | 0 | 1 | 2 | 3 | 4 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{0}$ | 4 | 4 | 4 | 4 | 4 |
| 1 | 0 | 4 | 4 | 4 | 4 |
| 2 | 0 | 1 | 4 | 4 | 4 |
| 3 | 0 | 1 | 2 | 4 | 4 |
| 4 | 0 | 1 | 2 | 3 | 4 |

$\dagger$ From E. L. Post (see References below).

References. For discussions of the logical considerations associated with manyvalued logics see, for example:

Post, E. L.: Introduction to a General Theory of Elementary Propositions, Am. J. Math., vol. 43, pp. 163-185, 1921.
Rosenbloom, P.: "The Elements of Mathematical Logic," pp. 51-69, Dover Publications, New York, 1950.
Rosser, J. B., and A. R. Turquette: Axiom Schemes for M-valued Propositional Calculi, J. Symbolic Logic, vol. 10, pp. 61-82, 1945.

For other approaches to many-valued logic in circuit design see:
Berlin, R. D.: Synthesis of N-valued Switching Circuits, IRE Trans. on Electronic Computers, vol. EC-7, no. 1, pp. 52-57, March, 1958.
Gilbert, E. N.: N-terminal Switching Circuits, Bell System Tech. J., vol. 30, pp. 668-688, 1951.
Lee, C. Y.: Switching Functions for an N-dimensional Cube, Trans. AIEE, vol. 73, pp. 289-291, September, 1954.
——and W. H. Chen: Several Valued Combinational Switching Circuits, Communs. and Electronics, no. 25, pp. 278-283, July, 1956.
e. Problems of Type 3 in an $M$-valued Post Logic. The many-valued generalization of the $\Theta$ matrix product is particularly useful for problems of type 3 in an ( $m+1$ )valued Post logic. We define

$$
\left(c_{k j}\right)=\left(a_{k i}\right) \Theta\left(b_{i j}\right)
$$

such that $c_{k j}$ is $m$ if the $k$ th row of ( $a_{k i}$ ) is identical to the $j$ th column of ( $b_{i j}$ ); otherwise $c_{k j}$ is 0 . With this in mind we have from the fundamental equation that

$$
\left(R_{j i}\right)=\left(F_{k j}\right)^{T} \Theta\left(E_{k i}\right)
$$

from which the solutions can be found that have a single $m$ in each column. For example, if $m+1=3$ (that is, three-valued logic) and $F=\left(\overline{f_{1}+\bar{f}_{2}}\right) \cdot X$ and

$$
E=\left\{\overline{\left(A_{1}+\bar{A}_{1}\right)} \cdot\left(\overline{\left(A_{2}+\bar{A}_{2}\right.}\right)+\overline{\left.\overline{\left(A_{1} \cdot \bar{A}_{1}\right.}\right)} \cdot\left(\overline{\left(A_{2}+\bar{A}_{2}\right)}+\overline{\left.\overline{\left(A_{1} \cdot \bar{A}_{1}\right.}\right)} \cdot\left(\overline{\left(\bar{A}_{2}+\bar{A}_{2}\right)}\right\} \cdot X\right.\right.
$$

then

$$
\left(R_{j i}\right)=\left(\begin{array}{l}
012 \\
012 \\
000 \\
000 \\
000 \\
000 \\
011 \\
012 \\
000
\end{array}\right) \quad \Theta\left(\begin{array}{lll}
000 & 000 & 000 \\
100 & 101 & 011 \\
200 & 202 & 022
\end{array}\right)=\left(\begin{array}{lll}
200 & 202 & 022 \\
200 & 202 & 022 \\
022 & 020 & 200 \\
022 & 020 & 200 \\
022 & 020 & 200 \\
022 & 020 & 200 \\
000 & 000 & 000 \\
200 & 202 & 022 \\
022 & 020 & 200
\end{array}\right)
$$

The $3 \times 5 \times 5 \times 3 \times 5 \times 3 \times 5 \times 3 \times 3=151,875$ sets of solutions include the set $f_{1}={\overline{A_{1} \cdot \bar{A}_{2}}}_{2}, f_{2}=\overline{A_{1}+\bar{A}_{2}}$.

It is interesting to note the relation between the $\boldsymbol{\theta}$ and the (C) operations at this point, namely,

$$
\left(a_{k i}\right) \Theta\left(b_{i j}\right)=\left\{\left(a_{k i}\right) \text { © }\left(b_{i j}\right)\right\} \cdot\left\{\overline{\left(\overline{a_{k i}}\right)} \text { © }\left(\overline{b_{i j}}\right)\right\} \cdot\left\{\overline{\overline{\left(a_{k i}\right)}} \text { © }\left(\overline{\overline{b_{i j}}}\right)\right\}
$$

for our three-valued logic. Can you prove this? An analogous relation holds for an ( $m+1$ )-valued Post logic.
f. All Solutions to Boolean Matrix Equations in a Many-valued Logic. Let (alb be any matrix-type logical operation [that is, for $\left(c_{p r}\right)=\left(a_{p q}\right)\binom{(1)}{\left(b_{q r}\right)}$, each $c_{p r}$ is some logical function of corresponding ( $q$ th) elements of the $p$ th row of ( $a_{p q}$ ) and the $r$ th column of $\left(b_{q_{r}}\right)$ ]. Then if

$$
\left(a_{i k}\right) \oplus\left(x_{k j}\right)=\left(b_{i j}\right)
$$

all matrix solutions, if any exist, can be found from

$$
\left(S_{m i}\right)=\left\{\left(a_{i k}\right) \otimes\left(b\left[X_{1}, \ldots, X_{k}\right]\right)\right\}^{T} \theta\left(b_{i j}\right)
$$

by the usual $R$-matrix type of procedure, generalized as required. The operations $\theta$ and (©) can be considered as specialized examples of the general matrix operation (10.

# LOGICAL DESIGN OF DIGITAL-COMPUTER CIRCUITRY 

## CHAPTER 15

## SERIAL ARITHMETIC OPERATIONS

## 15-1. Introduction

Generalized Concept of a Computer. As we have observed in previous chapters, only one word at a time can be transmitted between the computer's memory and its computing unit. In the computing unit are temporary storage locations or registers which receive the words from the memory; we have previously noted some of these registers, such as the accumulator and the instruction register. As a word is transmitted from a memory location to a register or back, it passes through logical gating networks of the types considered in Part 3. The computations take place in these logical gating networks; i.e., in these gating networks the numbers are transformed or combined according to the operation being executed. Thus we can conceive a computer as consisting of a temporary storage and a more permanent storage, with gating networks in between (see Fig. 15-1). Words are transmitted from the permanent storage, the computer memory, through the gating networks to the temporary storage, the computing-unit registers, and then back again through the gating networks. This chapter is concerned with the gating networks by means of which numbers are


Fig. 15-1. Generalized concept of a computer. transformed according to the computations involved in arithmetic operations.

Serial and Parallel Computers. In a serial computer a word is transmitted serially in a train, one bit at a time, to and from the computer's memory through the gating networks (see Fig. 15-2). In Chap. 2 such a sequence of events was described where the accumulator was the register
involved and the adder was the gating network. The length of time during which 1 bit is transmitted from the memory, through the gating network, and into the register is called a unit time interval. Thus, if a word has $w$ bits, it will take $w$ unit time intervals to transmit it to a register, or back, in a serial computer.


Fig. 15-2. Serial vs. parallel computer.
In a parallel computer, on the other hand, the bits of a word can be transmitted through the gating network from the memory to a register or back all at the same time, in parallel (see Fig. 15-2). Thus it takes only one unit time interval to transmit an entire word to the registers through the gating network. Thereby parallel computers can be many times faster than serial computers. On the other hand this increased speed is gained at a cost of additional hardware; for a serial computer need handle only 1 bit at a time, whereas a parallel computer must be able to handle all the bits of a word simultaneously. Thus a serial computer will in general be much less expensive and slower than a parallel computer.

Topics to Be Covered. In this chapter and the next we shall consider both serial and parallel arithmetic units, both binary and decimal. In
general there are several ways for solving each of the problems posed. We take the point of view that it is better to consider one method in detail than to survey all methods known. It is felt that the specific method chosen in each case will contain all the essential features common to other methods.

This chapter starts with a section on simple, common computer components such as shift registers, counters, adders, and so forth. Next we discuss concepts involving the synchronous operation of a computer, which are basic to the subsequent material. The serial arithmetic unit is then discussed, where we have used a combination adder-subtractor unit rather than the more popular input-output complementary-adder technique. The approach is pedagogically sound, since the subtractor is almost identical to the adder. It is felt that this will help the student to grasp the fundamentals more rapidly. The exercises then proceed systematically to build up the input-output complementer technique, which now becomes easy to master. The excess-three decimal-coded binary scheme is used to illustrate the decimal arithmetic unit. Although there are other decimal techniques (see Additional Topics, Sec. 15-7), excessthree can be treated as a simple extension of binary methods. In addition the parallel decimal arithmetic unit can be treated as a variation of the parallel binary arithmetic unit. This is done in the following chapter.

## 15-2. Common Computer Components

Synchronous Dynamic Flip-Flop and Shift Register. As will be illustrated in Part 5 of this text, flip-flops as described in Chap. 2 can be constructed from electronic circuits with two stable states. However, they can also be constructed by means of and and or gates. Consider, for example, the synchronous dynamic fip-flop. This is called a dynamic flip-flop because it has a recirculation loop (as considered above); if a unit signal voltage is recirculating, the flip-flop is said to be in the unit state; otherwise it is in the zero state. Besides the recirculation $C$ the input is a signal pulse $A$ and a clock pulse $P$. Here the synchronous aspect enters; for a unit signal pulse in $A$ occurring synchronously with the clock pulse will turn the flip-flop to its unit state; a zero signal pulse in $A$ occurring synchronously with the clock pulse will turn the flip-flop to its zero state; when no clock pulse appears, the flip-flop will not change its state. Thus this flip-flop acts like a 1-bit storage cell, storing whatever signal pulse was last synchronized with the clock pulse. Thus the function table becomes

$$
\begin{array}{ll}
\# A=0101 & 0101 \\
\# C=0011 & 0011 \\
\# P=0000 & 1111 \\
\# C^{\prime}=0011 & 0101
\end{array}=C \cdot \bar{P}+A \cdot P
$$

and the circuit diagram appears in Fig. 15-3. Note that the recirculation is called $C$ on one side of the unit delay line, while it is called $C^{\prime}$ on the other (why?).

A set of such flip-flops cascaded together, i.e., the output of one becoming the input signal to the next, is called a shift register. When a clock pulse appears, each flip-flop takes on the state that the previous flip-flop had. Hence, if $C_{i-1}$ is the state (output) of the previous flip-flop and $C_{i}$ that of the flip-flop under consideration, then the function table for the new state of the flip-flop $C_{i}^{\prime}$ is

$$
\begin{aligned}
& \# C_{i-1}=010100101 \\
& \# C_{i}=0011 \\
& 0011 \\
& \# P=0000
\end{aligned} 1111 .
$$

Figure 15-4 illustrates such a shift register. Observe that we had to move the unit delay line round from its position in Fig. 15-3 (why?). The accumulator in a serial computer is an example of such a shift register, where, as each result leaves the adder and enters the accumulator, the contents of the latter are shifted each unit time period to make room for the entering result bit.


Fra. 15-3. Flip-flop circuit.


Fig. 15-4. Shift register.

Cascaded Counters. We have considered the design of counters previously. For example, we know how to design a counter that counts $0,1,2, \ldots, p, 0,1,2, \ldots, p, 0,1, \ldots$, and so forth. Now suppose that we had two such counters and connected them together so that whenever the first increased past p to 0 , it would increase the count of the second by 1. Then the second counter would register how many times the first counter passed $p$. Thus suppose that the first counter is counting clock pulses (i.e., increases by 1 for each unit signal voltage of its input clock pulse); then if the count on the first counter is $a_{0}$ and the count on the second is $a_{1}$, the total number of clock pulses counted
will be $a_{1} q^{1}+a_{0} q^{0}$ (where $q=p+1, q^{0}=1$ ). Similarly, if the second counter is connected in this way to still a third counter of the same kind, and if the counts on the three counters are $a_{2}, a_{1}$, and $a_{0}$, then the number of clock pulses counted will be $a_{2} q^{2}+a_{1} q^{1}+a_{0} q^{0}$, and so forth. Thus it becomes clear that the counts of counters cascaded in this way represent the digits of a number to the base, or radix, $q$ (see Fig. 15-5). Note, however, that when a component counter reaches the count of $q$, although it sends a signal to increase the count on the next counter, its own count will really be zero. This of course is necessary since $a_{i}<q$.


Fig. 15-5. Cascading counters of radix $q$.


Fig. 15-6. Cascading counters for $q=2$.
For instance, if $q=4$, the counts of three cascaded counters would sequence as follows:


As a first example, let us consider the simple case of $q=2$. Let $Q$ denote the signal that increases the count of a component counter, $C$ the signal generated by the component counter to increase the next counter, and $B$ the count of the component counter itself (where only 1 bit is required in this case). Thus we have for the function table

$$
\begin{array}{ll}
B & 0101 \\
Q & 0011 \\
\hline B^{\prime} & 0110 \\
C & 0001=B \cdot \bar{Q}+\bar{B} \cdot Q \\
\hline
\end{array}
$$

Figure 15-6 is a diagram of four such counters cascaded together.
As the second example, let us consider $q=4$. Then our component counter will be a 2 -bit counter that counts $0,1,2,3,0,1,2,3,0, \ldots$
and that generates the triggering signal for the next cascaded counter. For instance, we would have

|  | 0123 | 4567 |
| :--- | :--- | :--- |
| $B_{1}$ | 0101 | 0101 |
| $B_{2}$ | 0011 | 0011 |
| $Q$ | 0000 | 1111 |
| $B_{1}^{\prime}$ | 0101 | $1010=B_{1} \cdot \bar{Q}+\bar{B}_{1} \cdot Q$ |
| $B_{2}^{\prime}$ | 0011 | $0110=B_{2} \cdot \bar{Q}+B_{1} \cdot \bar{B}_{2} \cdot Q+\bar{B}_{1} \cdot B_{2}$ |
| $C$ | 0000 | $0001=B_{1} \cdot B_{2} \cdot Q$ |

This counter counts in binary, as shown in Table 15-1. However, there is no necessity for a counter to count in the usual binary sequence; so let

Table 15-1. Binary and Cyclic Counting Sequences

| Decimal | Binary |  | Cyclic |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $B_{2}$ | $B_{1}$ | $B_{2}^{\prime}$ | $B_{1}^{\prime}$ |
| 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 2 | 1 | 0 | 1 | 1 |
| 3 | 1 | 1 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |

us consider a counter that counts in the so-called cyclic sequence shown in Table 15-1. In this case we have

| $B_{1}$ | 0101 | 0101 |
| :--- | :--- | :--- |
| $B_{2}$ | 0011 | 0011 |
| $Q$ | 0000 | 1111 |
| $B_{1}^{\prime}$ | 0101 | 1100 |
| $B_{2}^{\prime}$ | 0011 | $0101=B_{1} \cdot \bar{Q}+B_{2} \cdot \bar{Q}+B_{2} \cdot Q$ |
| $C$ | 0000 | $0010=B_{1} \cdot Q$ |
|  | $=\bar{B}_{1} \cdot B_{2} \cdot Q$ |  |

Two such counters cascaded together are shown in Fig. 15-7. Comparing this with Fig. 15-6, it is seen that our cyclic counter is somewhat simpler. If we compare our cyclic counter with a binary counter for $q=4$, we see that the cyclic counter is much simpler.


Fig. 15-7. Cascading cyclic counters with $q=4$.

Parallel Counter. Observe that in cascaded counters, after the signal $Q$ (which is to increase the count) enters the first counter stage, its effect must propagate sequentially through all the stages before the actual count finally appears. In practice this can consume a relatively large portion of time. There is, however, a method of arranging the cascaded counters so that the count appears immediately, with no propagation time lag. Consider, for example, a straight binary counter with $q=2$. Observe


Fig. 15-8. Parallel counter composed of cascaded stages.
that stage $a_{i}$ should change (from 0 to 1 or 1 to 0 ) only when stages $a_{i-1}, a_{i-2}, \ldots, a_{0}$ are all units and a signal $Q$ is received-for example,

$$
001111+1=010000
$$

Hence, to have a parallel counter we simply make the signal $C_{i}$ that changes the $a_{i}$ stage, as follows:

$$
C_{i}=a_{i-1} \cdot a_{i-2} \cdot \cdots a_{0} \cdot Q
$$

Figure 15-8 illustrates these connections. Figure $15-8$ should be compared with Fig. 15-6.

## EXERCISES

(a) Design a flip-flop circuit that has, besides its recirculation input and the clock input, two other inputs $A$ and $B$ such that a unit pulse in $A$ synchronized with the clock pulse will put the circuit in its unit state, while a unit pulse in $B$ synchronized with the clock pulse will put the circuit in its zero state. Assume that unit pulses in both $A$ and $B$ will never occur simultaneously (i.e., a constraint).
(b) Design a shift register using the flip-flops of Exercise $a$.
(c) Design a cascaded counter using units with $q=8$ (that is, 3 bits) where each unit counts in the following sequence: $000,001,011,010,110,111,101,100$, $000, \ldots$ Compare 2 of these units with the circuit found by cascading 6 of the $q=2$ units.
(d) Design a cascaded parallel counter with $q=4$, where each of the counter stages counts in cyclic. (Hint: The solution to this problem will be related to Fig. 15-7 in the same way Fig. 15-8 is related to Fig. 15-6.)

## 15-3. Common Computer Components (Continued)

Simple Adders and Subtractors. Consider the addition of two binary numbers as ordinarily accomplished by hand. First the least significant bits are added, forming the least significant sum bit and a carry bit. Then the next least significant bits are added, with the carry, forming the
next sum and carry bits, and so on. A serial adder is a circuit whose inputs are the 2 corresponding bits from the two numbers to be added, and the carry bit from the preceding sum; the outputs are the new sum and carry bits. The two numbers are fed serially and synchronously into the adder (in the manner illustrated in Chap. 2), and the carry recirculates. Figure 15-9 shows four phases in the addition of 10101 and


Fig. 15-9. Several stages in the serial addition of 10101 and 10011.
10011, where the last carry becomes the most significant bit of the completed sum. If the $i$ th bit of each of the numbers is denoted by $A_{i}$ and $B_{i}$, respectively, and the $i$ th bit of the sum by $R_{i}$ and the generated carry by $C_{i}$, then the function table for a serial adder becomes

| $A_{i}$ | 0101 | 0101 |
| :--- | :--- | :--- |
| $B_{i}$ | 0011 | 0011 |
| $C_{i-1}$ | 0000 | 1111 |
| $R_{i}$ | 0110 | $1001=\left(A_{i} \cdot \bar{B}_{i}+\bar{A}_{i} \cdot B_{i}\right) \cdot \bar{C}_{i-1}+\left(\bar{A}_{i} \cdot \bar{B}_{i}+A_{i} \cdot B_{i}\right) \cdot C_{i-1}$ |
| $C_{i}$ | 0001 | $0111=A_{i} \cdot B_{i}+\left(A_{i}+B_{i}\right) \cdot C_{i-1}$ |

The design of a serial adder is shown in Fig. 15-10.
For a different design of the serial adder note that the designation numbers of $R_{i}$ and $\bar{C}_{i}(11101000)$ differ in only two positions. This suggests that we might construct $R_{i}$ from $\bar{C}_{i}$. To find all ways of doing this, let $R_{i}=\bar{C}_{i} \cdot X+Y$, and solve for $X$ and $Y$. On performing the computations, find that

$$
X=011 \Phi \quad 1 \Phi \Phi \Phi \quad \text { and } \quad \# Y=0 \Phi \Phi 0 \quad \Phi 001
$$

One simple solution is $X=A_{i}+B_{i}+C_{i-1}$ and $Y_{i}=A_{i} \cdot B_{i} \cdot C_{i-1}$.


Fig. 15-10. Serial adder.


Fig. 15-11. Serial adder.
Hence we have the serial adder of Fig. 15-11. Perhaps an even simpler adder could be constructed if we note that between $R_{i}$ and $\bar{C}_{i}$ only five elementary products $\dagger$ are needed. This observation results in the adder of Fig. 15-12.
$\dagger$ Or five elementary sums.

In a similar way let us consider a serial subtractor, where for the present we shall assume that the result of the subtraction is always positive. Our function table becomes (where $D_{i}$ now represents the subtractive carry)

| $A_{i}$ | 0101 | 0101 |
| :--- | :--- | :--- |
| $B_{i}$ | 0011 | 0011 |
| $D_{i-1}$ | 0000 | 1111 |
| $R_{i}$ | 0110 | 1001 |
| $D_{i}$ | 0010 | 1011 |

Note that the difference $\left(R_{i}\right)$ in subtraction and the sum in addition are identical; only the carries differ. In the case of subtraction we have

$$
D_{i}=\bar{A}_{i} \cdot B_{i}+\left(\bar{A}_{i}+B_{i}\right) \cdot D_{i-1}
$$

Note that $D_{i}$ has the same form as $C_{i}$, except that $\bar{A}_{i}$ replaces $A_{i}$ (where the notation $D_{i-1}$ replaces $C_{i-1}$ ). Hence, if we complemented $A_{i}$, we could


Fig. 15-12. Serial adder.
use the same circuitry to generate both the subtraction and addition carries. Thus, if the sum were desired, we would send $A_{i}$ into the carrygenerating circuitry; if the difference were desired, we would send $\bar{A}_{i}$ into this circuitry. For example, suppose that, if the signal $P$ is a unit, the sum is to be formed; if $P$ is a zero, the difference is to be formed. This can be arranged as in Fig. 15-13.

The subtractor can easily be formed in still another way from the adder. For if in the circuit of Fig. 15-12 we added an and gate forming $\bar{A}_{i} \cdot B_{i} \cdot C_{i-1}$, we could form $D_{i}$ as well as $C_{i}$. Then either $C_{i}$ or $D_{i}$ would be recirculated depending on whether the sum or the difference is to be formed. Again this can be controlled by a signal $P$ (see Exercise $f$ of this section).

Logical Operations Derived from Adder. Consider the function tables for serial logical addition, logical multiplication, logical equalization, and
logical nonequalization, respectively:

| $A_{i}$ | 0101 | $A_{i}$ | 0101 | $A_{i}$ | 0101 | $A_{i}$ | 0101 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $B_{i}$ | 0011 | $B_{i}$ | 0011 | $B_{i}$ | 0011 | $B_{i}$ | 0011 |
| $L_{i}$ | 0111 | $\overline{M_{i}}$ | 0001 | $\overline{E_{i}}$ | 1001 | $\overline{F_{i}}$ | 0110 |

Circuits for these functions are easily formed. However, observe the addition carry of the last paragraph, namely, $C_{i}=00010111$, and note that, when $C_{i-1}$ is held at unity, $C_{i}$ becomes simply $L_{i}$; and when $C_{i-1}$ is held at zero, $M_{i}$ is obtained. Similarly observe $R_{i}$ of addition: when $C_{i-1}$ is held at unity, $E_{i}$ is obtained; when $C_{i-1}$ is held at zero, $F_{i}$ is obtained. Thus by fixing $C_{i-1}$ we can enable our serial adder to double as a logical unit.


Fig. 15-13. Adder and subtractor combination forms sum for $P=1$, forms difference for $P=0$.

To see how the carry may be controlled, suppose that $K_{L}, K_{M}, K_{E}$, and $K_{F}$ are control signals that take on unit signal voltage whenever the logical operation indicated by the respective subscript is to be accomplished. Let $C_{i}^{*}$ represent the controlled carry. Then since only one of $K_{L}, K_{M}, K_{E}$, and $K_{F}$ can be "on" at a particular time, we have the following function table of all possible input conditions for $C_{i-1}^{*}$ :

| $K_{L}$ | 01000 | 01000 |
| :--- | :--- | :--- |
| $K_{M}$ | 00100 | 00100 |
| $K_{E}$ | 00010 | 00010 |
| $K_{F}$ | 00001 | 00001 |
| $C_{i-1}$ | 00000 | 11111 |
| $C_{i-1}^{*}$ | 01010 | $11010=K_{L}+K_{E}+\bar{K}_{M} \cdot \bar{K}_{F} \cdot C_{i-1}$ |

On the other hand the $R_{i}$ output of the adder must be modified so that it
will produce the logical results as well. Calling this modified output $R_{i}^{*}$, we find the function table:

| $R_{i}$ | 0101 | 0101 | 0101 | 0101 | 0101 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $C_{i}$ | 0011 | 0011 | 0011 | 0011 | 0011 |
| $K_{L}$ | 0000 | 1111 | 0000 | 0000 | 0000 |
| $K_{M}$ | 0000 | 0000 | 1111 | 0000 | 0000 |
| $K_{E}$ | 0000 | 0000 | 0000 | 1111 | 0000 |
| $K_{F}$ | 0000 | 0000 | 0000 | 0000 | 1111 |
| $R_{i}^{*}$ | 0101 | 0011 | 0011 | 0101 | 0101 |
| $=$ |  |  |  |  |  |$R_{i} \cdot \bar{K}_{L} \cdot \bar{K}_{M}+C_{i} \cdot\left(K_{L}+K_{M}\right)$

Hence we have the modified input-output adder as in Fig. 15-14. When none of the signals $K_{L}, K_{M}, K_{E}$, or


Fig. 15-14. Use of adder for logical operations. $K_{F}$ is on, the adder will behave as an ordinary adder; but if any one of these signals is on, the adder will behave as a logical unit.

Subtractive Complementer. The subtractive complement of an integer $N$ to the base $q$ and of $p$ significant figures is defined as $C(N)=q^{p}-N$. For decimal numbers

$$
C(N)=10^{p}-N
$$

for binary numbers

$$
C(N)=2^{p}-N
$$

For example, if $N=10110$ (base 2), then $p=5$, whence we should have $C(N)=100000-10110=01010$. If $N=77$ (base 10 ), then $p=2$, whence $C(N)=100-77=23$.

The importance of the subtractive complement is related to the process of subtraction. Recall that, in the subtractor designed above, we assumed that the result would always be positive. Since our subtractor formed $A-B$, this was the same as assuming that $A>B$. But suppose that $B>A$, what would the circuit we designed do then? It would of course still form $A-B$. An illustration in terms of decimal numbers may clarify this situation. If we perform the subtraction $87-64$, we find 23 as the result; on the other hand, if asked to perform $64-87$, we could call -23 the result. But if we perform $64-87$ digit by digit, we find

$$
\begin{array}{r}
64 \\
-\quad 87 \\
\hline 9977
\end{array}
$$

or, on keeping only the two least significant figures, find 77. This is what our subtractor would do. However, notice that

$$
C(77)=100-77=23
$$

which is the correct result when preceded by a minus sign.
Thus the importance of the subtractive complementer becomes clear: for a subtractor designed to form $A-B$, the case of $B>A$ is treated by taking the subtractive complement of the result. To see this more precisely, note that the "cutting off" of the 9 s and retaining only the 77 is equivalent to forming $100+$ $64-87$, that is, $q^{p}+A-B$. Thus, if $B>A$, then, as desired,

$$
\begin{aligned}
& C\left(q^{p}+A-B\right) \\
& \quad=q^{p}-\left(q^{p}+A-B\right) \\
& \quad=-(A-B)=B-A
\end{aligned}
$$



Fig. 15-15. Subtractive complementer.

To design a subtractive complementer, observe that we are merely subtracting $N$ from all zeros; the $2^{p}$ in $C(N)=2^{p}-N$ is taken care of by terminating the calculations. The function table therefore becomes (where $C_{i}$ is the recirculating carry)

$$
\begin{array}{ll}
0 & 0000 \\
\hline N_{i} & 0101 \\
C_{i-1} & 0011 \\
\hline R_{i} & 0110 \\
C_{i} & 0111=N_{i} \cdot \bar{C}_{i-1}+\bar{N}_{i} \cdot C_{i-1} \\
C_{i-1}
\end{array}
$$

Hence the circuit appears as in Fig. 15-15.

## EXERCISES

(a) Design a serial adder by forming $C_{i}$ from $\bar{R}_{i}$; that is, let $C_{i}=\bar{R}_{i} \cdot X+Y$.
(b) How can an adder be made to subtract? [Hint: Note that $A+C(B)=$ $A+2^{p}-B=2^{p}+(A-B)$. Thus, if the unit in the $2^{p}$ position is ignored, $A-B$ is formed.] Illustrate with an example.
(c) If subtraction is accomplished as in Exercise b, what happens when $B>A$ ? How can this be remedied? Illustrate with an example.
(d) Observe that $C(N)$ for binary $N$ can be formed by complementing $N$ (that is, forming $\bar{N}$ ) and adding 1. For instance if $N=10110$, observe that $01001+1=$ 01010 (where + stands for ordinary addition), which is $C(10110)$. How can you explain this?
(e) Design a circuit which has as inputs two serial binary numbers $A$ and $B$ (like the adder) and whose output will be a unit if $A>B$, zero otherwise.
( $f$ ) Design an adder-subtractor combination analogous to the adder of Fig. 15-12, so that the combination forms the sum $A+B$ when a signal $P$ is a unit and the difference $A-B$ when $P$ is a zero.

## 15-4. Preliminaries to Synchronous Operation

Phase Pulses. In Sec. 2-3 we distinguished four phases in the execution of an instruction. For example, consider the execution of an addition instruction that reads "Add ( $\alpha$ ) to ( $\beta$ ), put the sum into $\gamma$, and take the next instruction from $\delta$." During phase $1,(\beta)$ would usually be transmitted into the accumulator; during phase $2,(\alpha)$ would be transmitted into the arithmetic unit and added to (acc) (see Figs. 2-8 to 2-13); during phase 3 , (acc) would be transmitted into $\gamma$; during phase 4 the next instruction would be transmitted into the instruction register. In order that the different parts of the computer know which phase of operation is in progress, phase pulses are emitted by the control unit. We denote by $F 1, F 2, F 3$, and $F 4$ the phase pulse signals that are units only during phases $1,2,3$, and 4 , respectively. We shall consider the generation of these signals in detail in Chap. 17. It suffices here, however, to note that phase 4 occurs in three-, two-, and one-address systems, when the next instruction is brought into the instruction register. Phase 2 of course also occurs in the three-, two-, and one-address systems, where a modified definition of phase 2 must be made for certain instructions of the two- and one-address systems.

Unit Time Intervals and Minor Cycles. In Sec. 2-4 we discussed clock pulses and briefly described how the entire computer was synchronized by these pulses. These pulses define units of time that are indivisible in so far as the computer is concerned. Thus a clock pulse is said to be a unit time interval in width (for example, the interval between $t_{i}$ and $t_{i+1}$ in Fig. 11-18). A minor cycle of a computer is a measure of time in terms of unit time intervals; its numerical value is equal to the number of positions in the accumulator shift register. That is, once a word has been selected from the memory, a minor cycle is the number of unit time intervals required for the word to be propagated down the accumulator shift register, at the rate of one shift per unit time interval. As we shall see below, the number of positions in the accumulator is usually greater than the number of bits in a word.

Phases 1,3 , and 4 usually consist of one minor cycle each; phase 2 will consist of one minor cycle for addition and subtraction but more than one minor cycle for multiplication and division, as we shall see below. The minor cycles are numbered within each phase, starting from 1 ; the unit time intervals are numbered within each minor cycle, starting from 0 . Thus, within a phase, a particular unit time interval can be indicated by denoting its number and minor cycle. The $n$th unit time interval of the $q$ th minor cycle is denoted by $T_{n}{ }^{q}$. This notation will be used extensively below. A signal pulse that is a unit only during the $n$th unit time interval of each minor cycle is denoted by $T_{n}$. Such pulses are generated by a counter that counts the clock pulses themselves. The synchronous operation of a computer is directed by these pulses.

The Continuously Shifting Register. A topic that will prove of importance in discussing the serial arithmetic unit is an analysis of the con-
tinuously shifting register. The accumulator is such a register, for, as we have seen in Sec. 2-4, as each bit of a word is transmitted from the memory into the accumulator the contents of the accumulator must shift one stage, to make room for the entering bit. Thus after each unit time interval the contents of the accumulator must shift. For example, consider a 5 -bit continuously shifting register accepting a 4 -bit word P3 P2 P1 P0. Label the stages of the shift register by $0,1,2,3$, and 4, from left to right as indicated in Fig. 15-16; then the contents of


| $T_{0}^{1}$ | $P_{0}$ |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $T_{1}^{1}$ | $P_{1}$ | $P_{0}$ |  |  |  |  |
| $T_{2}^{1}$ | $P_{2}$ | $P_{1}$ | $P_{0}$ |  |  |  |
| $T_{n}^{1}$ | $P_{3}$ | $P_{2}$ | $P_{1}$ | $P_{0}$ |  |  |
| $T_{4}^{q}$ |  | $P_{3}$ | $P_{2}$ | $P_{1}$ | $P_{0}$ |  |
| $T_{0}^{2}$ |  |  | $P_{3}$ | $P_{2}$ | $P_{1}$ |  |
| $T_{1}^{2}$ |  |  |  | $P_{3}$ | $P_{2}$ | $\longrightarrow P_{0}$ |
| $T_{2}^{2}$ |  |  |  |  | $P_{3}$ |  |
| $T_{3}^{2}$ |  |  |  |  |  |  |
| $T_{4}^{2}$ |  |  |  |  |  |  |

Fig. 15-16. A 4-bit word shifting through a 5 -bit continuously shifting register.
this register as a function of time is shown, where it is assumed that $P 0$ enters stage 0 at $T_{0}{ }_{0}$.

Next consider the more complicated situation where the output of the shift register is recirculated, as in Fig. 15-17. In the timing rows we have omitted the $P$, and the numbers represent the respective bits of our 4 -bit word. In (1), straight recirculation, note that each minor cycle (after the first) is identical. That is, at $T_{0^{q}, ~ P 0 ~ i s ~ a t ~ s t a g e ~} 0, P 1$ is at stage $4, P 2$ is at stage 3 , etc. On the other hand consider the case where the recirculation loop is shortened as in (2). Here our word "precesses," so to speak: e.g., at $T_{0}{ }^{1}, P 0$ is at position 0 ; at $T_{0}{ }^{2}, P 0$ is at position 1 ; at $T_{0}{ }^{3}, P 0$ is at position 2, etc.; at $T_{0}{ }^{q}, P 0$ is at position $q-1$ (for $q \leq 5$ ). In (3) a lengthened precession is considered: $P 0$ is at position 0 at $T_{0}{ }^{1}$, at position 0 at $T_{1}{ }^{2}$, at position 0 at $T_{2}{ }^{3}$; so in general $P 0$ is at position 0 at $T_{q-1}^{q}$ for $q \leq 5$.
Let us generalize these observations. Let $p$ represent a stage number
of the shift register and $s$ a bit number of a word. Then for the situation pictured in (3) of Fig. 15-17, that of lengthened precession, we find that $n-(q-1)-p=s$. Thus, given $T_{n}{ }^{q}$, we can determine $s$ for a particular $p$ or, conversely, $p$ for a given $s$. For example, for $T_{3}{ }^{2}$ and $p=1$
(1) Straight recirculation
(2) Shortened precession
(3) Lengthened precession



Fig. 15-17. Continuously shifting register with various recirculation situations.
we find $3-1-1=1$, as can be easily confirmed from (3). However, for $T_{2}{ }^{3}$ and $p=3$ we find $2-2-3=-3$, which clearly is not one of the values taken by $s$ since $s=0,1,2$, and 3 . In such a situation let us note that if there were $w$ stages to the shift register, that is, $p=0,1,2$, $\ldots, w-1$, then $T_{n}{ }^{q}=T_{n+w}^{q-1}$; that is, $T_{n}{ }^{q}$ and $T_{n+w}^{q-1}$ represent the same
time period. For our example, $w=5$; hence we replace $T_{2}{ }^{3}$ by $T_{7}{ }^{2}$, whence we find $7-1-3=3$, which is correct.

Next consider the situation in (2) of Fig. 15-17. Here note that $n+(q-1)-p=s$. For example, for $T_{1}{ }^{3}$ and $p=0,1+1-0=2$, which can be checked in the proper chart of Fig. 15-17. However, if $p=4$, for example, we would have $1+1-4=-2$. The solution to this dilemma is to note that $T_{1}{ }^{2}=T_{6}{ }^{1}$, whence $6+0-4=2$, which is


Fig. 15-18. Delay line. correct.

In general it is now easy for us to see that if $\Delta$ is the number of stages lengthened (and $-\Delta$ is the number of stages shortened) then

$$
\begin{equation*}
n-\Delta(q-1)-p=s \tag{15-1}
\end{equation*}
$$

where we shall often have to use the fact that

$$
\begin{equation*}
T_{n}^{q}=T_{n+w}^{q-1}=T_{n-w}^{q+1} \tag{15-2}
\end{equation*}
$$

to obtain the proper solution.
These formulas are primarily of use in discussing serial multiplication and division. The recirculation of the accumulator for addition and subtraction is analogous to (1) of Fig. 15-17, where the formulas are not really necessary.


Fig. 15-19. Using a drum for a delay-line shift register.
The continuously shifting register is important, not only because the serial accumulator is one, but also because all delay-line registers are of this type. Until now we have considered registers as shift registers. However, delay lines can be used for the temporary storage required for registers. Previously we have used the concept of a unit delay when discussing recursive functions; delay lines that are used as part of a register usually afford many time periods of delay. Figure $15-18$ represents a possible method of constructing a delay line. For the purposes of logical design the most important difference between a shift register
and a delay-line register is that the pulses in a shift register may be shifted or not at any time, depending on the occurrence of a controlling shift pulse, but that, as is clear from Fig. 15-18, the pulses in a delay-line register keep moving all the time. A delay-line register is thus like a shift register that is always shifting. The advantage of a delay-line shift register is its often low cost as compared with a shift register. For example, a small computer with a drum could use part of the drum for a delay-line shift register (see Fig. 15-19). Here the pulses are put on the rotating drum in sequence and are picked up after the delay of rotation at the reading head. A great disadvantage of delay-line registers is that they are not appropriate for parallel computers, as will be seen below.

## EXERCISES

(a) The Pedagac has a minor cycle of 23 unit time intervals. Design a cascaded counter that will generate $T_{0}, T_{1}, \ldots, T_{22}$. (See Fig. 18-16, pages 612, 613.)
(b) Draw the detailed logical diagram for the shift register of Fig. 15-17, and indicate where the connections would be made for each of the recirculation situations of the figure. Show that the recirculation loops are connected correctly in each case.
(c) For $\Delta=-1, w=5$, locate $P 2$ at $T_{2}{ }^{2}$; locate $P 2$ at $T_{0}{ }^{2}$ (that is, find $p$ ). Check results with the charts of Fig. 15-17.
(d) For $\Delta=+1, w=5$, locate $P 2$ at $T_{4}{ }^{3}$; locate $P 2$ at $T_{0}{ }^{3}$. Check results with the charts of Fig. 15-17.
(e) For $\Delta=+1, w=5$, what bit will be located at $p=2$ at $T_{2}{ }^{3}$ ? (That is, find s.) Can you explain the result obtained? Check result with the charts of Fig. 15-17.
( $f$ ) For the arrangement shown in Fig. 15-19, how can shortened and lengthened precession be obtained without using additional heads? (Hint: Use the drum for only part of the register.)

## 15-5. Serial Arithmetic Unit: Addition and Subtraction

The Addition of Words. We have shown in Sec. 15-3 how a serial adder is designed. Now consider the problem of incorporating such an adder into the arithmetic unit of a serial computer. In general only one word at a time can be transmitted from the memory to the arithmetic unit. Hence in adding two words, say $A$ and $B$, the word $B$ is usually transmitted to the accumulator first, during phase 1. Then during phase 2 this word is recirculated from the accumulator through the adder at the same time as $A$ is being transmitted from the memory through the adder, and in this way $A$ and $B$ are added and the sum put into the accumulator. In the three- or four-address systems it is convenient during phase 1 to transmit into the accumulator through the adder; here $B$ is added to all zeros, which is accomplished by gating the recirculation from the accumulator with $F 2$, which is off during phase 1 (see Fig. 15-20). However, the other input to the adder must be open during both phase 1 and phase 2 and is therefore gated with $F 1+F 2$. For one-address addition systems the contents of the accumulator is taken as one of the arguments directly,
phase 1 being eliminated. The two-address system may work either way.

The sign bits of the words are not sent through the adder; they are recorded in flip-flops (not shown in Fig. 15-20) until needed. Therefore $P 1$ is the first bit of a word to enter the accumulator, since the $P 0$ bit is the sign bit. It is customary to arrange the timing so that, when a word is transmitted from the memory to the accumulator, its P1 bit enters the zeroth stage at $T_{1}{ }^{1}$. For the present we shall assume that it takes no appreciable time for a pulse to go through the adder or, in fact, through any gating levels. Of course this is not actually so, as we shall see when


Fig. 15-20. The addition of words.
we discuss the electronic design of the gates. Thus, in phase 1, bit $B 1$ enters the zeroth stage of the accumulator shift register at $T_{1}{ }^{1}$; in phase 2 , the sum of $B 1$ and $A 1$, namely, $R 1$, enters the zeroth stage at $T_{1}{ }^{1}$.

The Sum and the Difference. Since each word may be either positive or negative, sometimes even when subtraction is called for, the sum may be required, and when addition is called for, the difference may be required. Let us define some terms in order to facilitate the discussion. Henceforth we shall mean by addition and subtraction the operation written into any instruction. On the other hand by sum and difference we shall mean that which is carried out by the arithmetic unit in any instance. Table 15-2 summarizes all possibilities.

Table 15-2. Sum and Difference Conditions

| $S_{A}$ | $S_{B}$ | Operation $W$ | Result $P$ |
| :---: | :---: | :--- | :--- |
| + | + | Add | Sum <br> - <br> +$+$ |
| Add | Difference |  |  |
| - | - | Add | Difference |
| + | - | Add | Sum |
| + | + | Subtract | Difference |
| + | + | Subtract | Sum |
| - | - | Subtract | Sum |
|  | - | Subtract | Difference |

Our adder-subtractor combination of the previous section forms the sum or difference of $A$ and $B$ depending on whether the sum carry $C$ or the difference carry $D$ is recirculated. The signal $P$ that determines this must itself then depend on three signals: the sign of the number $A$, denoted by $S_{A}$, the sign of the number $B$, denoted by $S_{B}$, and the operation. Let $S_{A}$ and $S_{B}$ be 1 for a positive number and 0 for a negative number. Let $W$ represent the operation, such that for addition $W$ is 1 and for subtraction 0 . Then from Table 15-2 we can form the following condition-function table for $P$, where it is recalled that when $P$ is 1 the sum is to be formed, when $P$ is 0 the difference is to be formed:

```
S
```



```
W
```

The next problem is to determine the sign of the result. For this we need one additional piece of information if the difference was formed, namely, whether $|A|>|B|$ or $|B|>|A|$. Then the sign conditions are summarized in Table 15-3. Let us suppose for the moment that this

Table 15-3. Sign Conditions for $A \pm B=C \dagger$

$$
\begin{aligned}
& \left.\begin{array}{l}
(+A)+(+B) \\
(+A)-(-B)
\end{array}\right\}=(+C) \\
& \left.\begin{array}{l}
(-A)+(+B) \\
(-A)-(-B)
\end{array}\right\}=\left\{\begin{array}{l}
(+C) \text { for }|B| \geq|A| \\
(-C) \text { for }|B|<|A|
\end{array}\right. \\
& \left.\begin{array}{l}
(+A)+(-B) \\
(+A)-(+B)
\end{array}\right\}=\left\{\begin{array}{l}
(+C) \text { for }|A| \geq|B| \\
(-C) \text { for }|A|<|B|
\end{array}\right. \\
& \left.\begin{array}{l}
(-A)+(-B) \\
(-A)-(+B)
\end{array}\right\}=(-C)
\end{aligned}
$$

$\dagger(+A)$ means that $A$ is positive, $(-A)$ means that $A$ is negative, and similarly for $B$ and $C$. Note that zero is positive.
can be determined and that, if $|B|>|A|$, then $X$ is 1 and, if $|A|>|B|$, then $X$ is 0 . Let $S$ be the sign ( 1 if positive, 0 if negative) of the sum or difference as the case may be; then the condition-function table for $S$ becomes

|  |  |  | 910 | $12 \quad 15$ |
| :---: | :---: | :---: | :---: | :---: |
| $S_{A}$ | 0101 | 0101 | 0101 | 0101 |
| $S_{B}$ | 0011 | 0011 | 0011 | 0011 |
| W | 0000 | 1111 | 0000 | 1111 |
| $X$ | 0000 | 0000 | 1111 | 1111 |
| $S$ | 0101 | 0101 | 1100 | 001 |

Note that the case for $A=B$ was not covered. This must be taken care of separately, as we shall see below.

As can be seen from Table 15-3, the only time $X$ is important is when
a difference is being calculated by the adder-subtractor. For the addersubtractor described above, the difference calculation always performed is $|A|-|B|$. When $|B|>|A|$, the result is $2^{p}+|A|-|B|$ and the subtractive complement of the result must be taken. Now if $p$ is taken greater than the length of the word, units would appear to the left of the word. For example, consider 5 -bit words with the difference carried to eight places,

$$
\begin{array}{r|r|}
000 & 01010 \\
-\quad 000 \\
\hdashline & 10110 \\
\hdashline & 10100
\end{array}
$$

The subtractive complement is 01100 , and the result is negative. However, the important point to note is the propagation of units to the left


Fig. 15-21. Adder and subtractor combination with controls.
in the result. This will occur whenever the difference is formed with $|B|>|A|$. Hence it is this propagation of units that tells us when $|B|>|A|$ or $|B|<|A|$. Thus a propagated unit can be taken for $X$. It is wisest to choose a unit in position $p+2$ (as indicated by the arrow), where $p$ is the number of positions in the word, for position $p+1$ could possibly become a unit due to normal overflow, but not $p+2$. When $X$ is chosen as this bit, it is easily seen that conditions $9,10,12$, and 15 will never occur, for here the sum of the numbers is being formed. Hence these columns can be dropped, forming a constrained basis. Under this constraint $S$ reduces to

$$
S=S_{A} \cdot \bar{X}+\bar{S}_{A} \cdot X
$$

In Fig. 15-21 we have summarized the developments so far in this section. For the addition and subtraction of words we described an adder-subtractor combination (that formed $|A|+|B|$ and $|A|-|B|$ ) followed by an elongated accumulator. However, to take care of the case when $|B|>|A|$, we need an output subtractive complementer. Also we need controls to tell the adder combination when to form the
sum and when to form the difference, controls to determine the sign of the result, and a control for the output subtractive complementer. This latter control is particularly simple: if a unit is propagated two positions more significant than the most significant (leftmost) position of a word, then the complementer is turned on; otherwise it is left off. The sign bits $S_{B}$ and $S_{A}$ that precede the entrance of $B$ and $A$ from the memory are sensed as they enter the arithmetic unit and are not used in the adder itself; the sign of the result is placed in the word just before it goes to the memory. Note that the accumulator must be at least 2 bits longer than the word length itself (why?).

Decimal Addition and Subtraction. In Sec. 3-10 we discussed the concept of decimal-coded binary computer design. Here we shall discuss a particular system of decimal-coded binary which contains the basic ingredients of any such system. The specific circuits used for decimal addition and subtraction of course depend on the particular decimal-coded binary code used. We shall choose a code called the excess-three code, in terms of which these operations are especially simple to perform. Table $15-4$ gives the excess-three code. If $V$ is a decimal digit, then its excessthree code is found by converting $V+3$ to binary, which we shall represent by $(V+3)_{b}$.

The first obvious advantage of this code concerns the decimal carry. In adding two decimal digits a carry is obtained when the sum of the
Table 15-4. Decimal-coded Binary in the Excess-three Code System
Decimal

0 | Exces-three code |  |
| :---: | :---: |
| 1 | 0011 |
| 2 | 0100 |
| 3 | 0101 |
| 4 | 0110 |
|  | 0111 |
| 5 | 1000 |
| 6 | 1001 |
| 7 | 1010 |
| 8 | 1011 |
| 9 | 1100 |

digits is 10 or greater. In the excess-three code, if we add in the usual binary fashion the codes representing two such digits, we find $\dagger$

$$
(U+3)_{b}+(V+3)_{b}=(U+V)_{b}+(3+3)_{b} \geq 10_{b}+6_{b}=16_{b}
$$

but binary 16 has a fifth bit, which corresponds to the decimal carry. This suggests a method for performing the addition of two excess-three binary-coded decimal words. Simply add the corresponding digits (groups of 4 bits) as if they were actually binary numbers; if there is a carry from the previous 4 -bit addition result, add this in also. Of
$\dagger$ Recall that if $U$ and $V$ are decimal digits $(U+V)_{b}=U_{b}+V_{b}$, where the subscript $b$ means "converted to binary."
course the binary sum will not be the proper excess-three code and hence must be adjusted accordingly, as will now be considered.

Suppose that we desire to form the following sum, where we use 4-digit numbers as an example:

$$
+\begin{array}{lllll} 
& N_{4} & N_{3} & N_{2} & N_{1} \\
& M_{4} & M_{3} & M_{2} & M_{1} \\
\hline R_{5} & R_{4} & R_{3} & R_{2} & R_{1}
\end{array}
$$

where $N_{i}, M_{i}$, and $R_{i}$ are the decimal digits of the arguments and the result. Now, if $N_{1}+M_{1} \leq 9$, then $N_{1}+M_{1}=R_{1}$. However, we desire the digit $R_{1}$ in excess-three code, i.e., as $\left(R_{1}+3\right)_{b}$. Suppose that we added the excess-three codes of $N_{1}$ and $M_{1}$ directly; we would obtain $\left(N_{1}+3\right)_{b}+\left(M_{1}+3\right)_{b}=\left(N_{1}+M_{1}+6\right)_{b}=\left(R_{1}+6\right)_{b}$. Thus, to obtain the correct excess-three result, we would form the sum of the excess-three codes of corresponding digits and subtract 3 ; that is,

$$
\left(R_{1}+3\right)_{b}=\left(N_{1}+3\right)_{b}+\left(M_{1}+3\right)_{b}-3_{b}
$$

Next consider $N_{1}+M_{1}>9$. In this case $R$ is the least significant figure of the addition. The most significant digit, 1, becomes the carry to the next position (e.g., if $N_{1}=6, N_{2}=7$, then $N_{1}+N_{2}=13$ and $R_{1}=3$ with the 1 becoming the carry). Thus $R_{1}=N_{1}+M_{1}-10$, and the desired excess-three code result is $\left(N_{1}+M_{1}-10+3\right)_{b}$. We observed above that, under these conditions, the binary sum of the excess 3 digits will contain 5 significant bits; we use the fifth bit as a carry, retaining only the other 4 . The 4 -bit result of the excess-three addition becomes $\left(N_{1}+3\right)_{b}+\left(M_{1}+3\right)_{b}-16_{b}=\left(N_{1}+M_{1}-10\right)_{b}$. To this we must add 3 to obtain the correct excess-three result:

$$
\left[\left(N_{1}+M_{1}-10\right)+3\right]_{b}=\left[\left(N_{1}+3\right)_{b}+\left(M_{1}+3\right)_{b}\right]-16_{b}+3_{b}
$$

Summarizing, the rules for addition are as follows: To form the excessthree result of adding (summing) the corresponding digits of two numbers, sum their excess-three codes and then subtract 3 if no carry results, or add 3 if a carry does result. The carry increases $M_{i+1}$ by 1 , and hence also its excess-three code. Thus the carry is added to the addition of the least significant place of $M_{i+1}$ just as in an ordinary binary adder. For example, consider the following addition:

| Decimal |  | Decimal-coded binary |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 274 |  | 0101 | 1010 | 0111 |
| $\underline{+465}$ |  | +0111 | 1001 | 1000 |
|  | Binary sum. | 1101 | 0011 | 1111 |
|  | Carry record | No | Yes | No |
|  | Adjustment. | -0011 | $\underline{+0011}$ | -0011 |
| alt 739 |  | 1010 | 0110 | 1100 |

Consider now subtraction. Forming

$$
\left(N_{1}+3\right)_{b}-\left(M_{1}+3\right)_{b}=\left(N_{1}-M_{1}\right)_{b}
$$

we see immediately that, if $N_{1} \geq M_{1}$, all we need do is add 3 to this result, that is, $R_{1}+3=\left(N_{1}-M_{1}+3\right)_{b}=\left(N_{1}+3\right)_{b}-\left(M_{1}+3\right)_{b}+3_{b}$. On the other hand suppose that $M_{1}>N_{1}$; then we desire

$$
R_{1}=10+N_{1}-M_{1}
$$

whence $\left(R_{1}+3\right)_{b}=\left(10+N_{1}-M_{1}+3\right)_{b}$. We form

$$
\begin{aligned}
2^{4} b+\left(N_{1}+3\right)_{b}-\left(M_{1}+3\right)_{b}-3_{b} & =\left(16+N_{1}-M_{1}-3\right)_{b} \\
& =\left(10+N_{1}-M_{1}+3\right)_{b}
\end{aligned}
$$

Notice that in this latter case the binary subtraction will produce a carry from the most significant position (which is the reason for the $2^{4}$ ), and


Fig. 15-22. Adder and subtractor combination for excess-three decimal-coded binary words, with controls.
hence the carry indicates that the difference between $\left(N_{1}+3\right)_{b}$ and $\left(M_{1}+3\right)_{b}$ must be reduced by 3 .

Summarizing, the rules for subtraction are as follows: To form the excess-three result of subtracting (differencing) corresponding digits, difference their excess-three codes and then add 3 if no carry results or subtract 3 if a carry does result. Again any carry is added to $\left(M_{i+1}+3\right)_{b}$, and the subtraction then takes place in these four bit positions, etc.

Figure 15-22 represents a block diagram of a serial excess-three adder and subtractor and associated control circuits. The 4 units of delay adjacent to the accumulator hold the 4 bits of the sum or difference of the excess-three codes of corresponding digits before the recirculation through the adder for $\pm 3$ adjustment. The $3_{b}$ generator generates 0011 to be added to or subtracted from the recirculating 4 -bit result. During this recirculation no further bits of $A$ or $B$ enter the adder. When the recirculation and $\pm 3$ adjustment have been accomplished, the next digits, i.e., the next 4 bits each, of $A$ and of $B$ enter the adder. The process continues alternating: sum or difference next 4 bits, recirculate result adding or subtracting 3 , sum or difference next 4 bits, recirculate result, etc. The carry must be recorded in a flip-flop, held during the
recirculation, and then inserted just as the next digits of $A$ and of $B$ enter the adder. The $\pm 3_{b}$ control signal, denoted by $P_{r}$, determines whether the $3_{b}$ should be summed or differenced during the recirculation, while the adder-subtractor control signal $P$ does this during the processing of the next digits. The signal $P$ is generated in the same way as in the binary case of the previous paragraph; the signal $P_{r}$ depends on $P$ and on the carry $C_{D}$, as described by our above rules. Since $P$ is 1 when the two numbers are being summed and 0 when they are being differenced, the function table for $P_{r}$ becomes

$$
\begin{array}{ll}
C_{D} & 0101 \\
P & 0011 \\
\hline P_{r} & 1001
\end{array}=C_{D} \cdot P+\bar{C}_{D} \cdot \bar{P}
$$

The sign generator is as in the binary case, except that sometimes the sign itself is coded into 4 bits. The output subtractive complementer is actuated this time by a 9 in the overflow decimal position.

The subtractive complement of an integer $N$ having $p$ significant figures in base ten is $10^{p}-N$. If the rightmost digits of $N$ are zeros, then $C(N)$ ends in the same number of zeros; thence the rightmost nonzero digit of $N$ is subtracted from 10, and each succeeding leftward digit is subtracted from 9. For example, we have

$$
\begin{array}{r}
100000 \\
55500 \\
\hline 44500
\end{array}
$$

Observe that the inverse $\bar{N}_{i}$ of the $i$ th digit of $N$ represented in excess-three is $15_{b}-\left(N_{i}+3\right)_{b}=12_{b}-\left(N_{i}\right)_{b}=\left(9-N_{i}\right)+3_{b}$, that is, the excessthree representation of $9-N_{i}$. Note also that $10-N_{i}=\left(9-N_{i}\right)+1$. Our subtractive complementer (Fig. 15-23) is designed to pass all rightmost zeros, form $10-N_{i}=\bar{N}_{i}+1 \dagger$ for the rightmost nonzero digit, and then form $9-N_{i}=\bar{N}_{i}$ for the leftward digits.

Referring to Fig. 15-23, if the least significant excess-three digit of $N$ is zero (i.e., if $P 4 P 3 P 2 P 1=0011$ at $T_{0}{ }^{q}$, with $K=0$ ), gate 1 sets the flip-flop to the unit state, through gate 2. As long as each later digit is a zero (for $K=1,2, \ldots$.), the flip-flop will remain set. The first nonzero digit will reset the flip-flop to the zero state, through gate 3. As long as the flip-flop is set, $C=1$ and gates 6 and 7 (and their associated not gates) form $R=\bar{N}_{i}=N_{i}$ (that is, so long as $N_{i}=0$ ). As the flipflop is reset, its last unit bit is delayed, so that $C$ will still be 1 as $\left(N_{i}\right)_{0}$
$\dagger$ According to the following function table for $\left(N_{i}\right)_{j}$, the $j$ th bit of the $i$ th digit of $N$ :

$$
\begin{array}{rl}
\left(N_{i}\right)_{j} & 0101 \\
C & 0011 \\
R & 1001 \\
C^{\prime} & 0010
\end{array}
$$

where $C$ is the carry $\left(C^{\prime}\right)$ delayed, and $j=0 \rightarrow C=1$, so that the 1 is added to $N_{i}$.
of the first nonzero digit of $N$ enters the complementer, initiating the $10-N_{i}$ function. If $N_{1} \neq 0, T_{0}{ }^{9}$ entering gate 4 will make $C=1$ for $\left(N_{1}\right)_{0}$, to initiate $10-N_{1}$. After $10-N_{i}$ is formed for the first nonzero digit, no carry can result [unless by error $\left(N_{i}+3\right)_{b} \doteq 1111$ ], and since


Fig. 15-23. Excess-three subtractive complementer. $T_{4 K}{ }^{q}$ marks the beginning of each successive digit as $K=0,1,2, \ldots$
the flip-flop will be reset, $C$ will be 0 and gates 5 and 7 will form $R=\bar{N}_{i}=9-N_{i}$ for all following digits.

## EXERCISES

(a) Consider a word that is 15 bits plus a sign bit long. Suppose that the signal $X$ as defined above is to be sensed from stage 1 of the accumulator at time $T_{n}{ }^{1}$. What should be the value of $n$ ? (Ans. $T_{177^{1}}$.)
(b) What is the purpose of $\bar{T}_{0}$ in Fig. 15-20?
(c) In Exercise b of Sec. 15-3 it was described how an adder could subtract. This requires an input subtractive complementer lo the adder as well as an output subtractive complementer. Suppose that it is decided always to form $C(B)$ if $B$ is negative (where $B$ enters the arithmetic unit first, before $A$ enters). Then the decision on whether to form $C(A)$ is determined by the operation $W$ and the signs $S_{A}$ of $A$ and $S_{B}$ of $B$. Suppose that this complementation is not to take place when control signal $Q$ is 0 and is to take place when $Q$ is 1 . Determine $Q=Q\left(S_{A}, S_{B}, W\right)$. (Hint: Recall from Exercise $b$ of Sec. $15-3$ that, if the difference of $A$ and $B$ is to be computed, only one of $A$ or $B$, but not both, must be subtractive-complemented; if the sum of $A$ and $B$ is to be formed, either both $A$ and $B$ must not be subtractive-complemented or else both $A$ and $B$ must be subtractive-complemented.)
(d) If $X$ is the output-subtractive-complementer control, how is it generated in the binary system of Exercise $c$ ? [Hint: The difficult case is when $C(A)+C(B)$ is formed in the accumulator. Here the sum is $2^{p}-A+2^{p}-B=2^{p+1}-(A+B)$. Hence we must form by means of the output complementer $2^{p+1}-\left(2^{p+1}-(A+B)\right)$.]
(e) For the system of Exercise $c$ design a circuit to generate the proper sign.
(f) How can advantage be taken of the adder to simplify the input-subtractivecomplementer circuit of the system of Exercise $c$ ? (Hint: See Exercise $d$ of Sec. 15-3.)
(g) Describe in detail a decimal system using excess-three decimal-coded binary words, where only an adder is available, together with input and output subtractive complementers.
(h) In a computer zero is always considered to be positive. Can a negative zero occur in the binary sign-generating system described in this section? (Ans. Yes.) Under precisely what conditions?
(i) A zero sensor circuit determines if the result of an addition or subtraction is zero. Design such a circuit for a binary system, and show how it can be made to override the sign generator when necessary.
(j) Design a zero sensor for the decimal system described in this section.
(k) Is a zero sensor necessary for a binary system as described in Exercise c?
( $l$ ) In Fig. 15-22 the 4 units of delay are followed by a direction-control box. This circuit is to recirculate the 4 bits for the $\pm 3_{b}$ adjustment and then send these 4 bits to the accumulator. Design a circuit that includes a 3-bit counter that will perform this task.

## 15-6. Serial Arithmetic Unit : Multiplication and Division

Multiplication. Binary multiplication as accomplished by a serial computer is similar to the ordinary hand method except that it is more convenient to form the partial sums directly instead of summing last. For example, consider the following multiplication $M \times N=P$ :

| By hand |  | By serial computer |  |
| :---: | :---: | :---: | :---: |
| 11101 | Multiplicand $N$ | 11101 | Multiplicand $N$ |
| 10011 | Multiplier M | 10011 | Multiplier M |
| 11101 |  | 1110:1 | 1st partial sum |
| 11101 |  | 11101 |  |
| 00000 |  | 10101:11 | 2d partial sum |
| 00000 |  | 00000 |  |
| 11101 | Product $P$ | 1010:111 | 3d partial sum |
| $\overline{1000100111}$ |  | 00000 |  |
|  |  | $\begin{array}{c:c} 0101: 0111 \\ 11101 \end{array}$ | 4th partial sum |
|  |  | $\underbrace{10001} \underbrace{00111}$ | Product $P$ |
|  |  | Major Minor |  |

Hence, in a serial computer, the product $P$ is formed by successively adding to the partial sum either all zeros or the appropriately shifted multiplicand $N$, as directed by the multiplier $M$. In the following discussion we assume that $M$ and $N$ are positive, since the sign of the product $P$ is generated independently. Also recall that the sign bits never enter the register but are recorded for later use in the sign generator.

The method for implementing the multiplication process involves two additional shift registers besides the accumulator. One of these registers will record the multiplicand so that it will be readily available for forming the partial sums; this register is called the icand register. The other register records the multiplier and presents the appropriate bit to direct the partial-sum formation at each stage of the multiplication; this register is called the ier register. The ier register has another function also. Recall that a product can be twice the length of a word, and therefore major and minor multiplication is obtained (see above example). The ier register is used to store the minor product as it is formed. To see how this double function can be accomplished by the ier register, observe that, after a bit of the multiplier has directed the formation of its cor-
responding partial product, it can be discarded. Also note that the bits of the minor product are generated one at a time by each successive partial product (indicated by dashed line above). Hence, as a bit of the multiplier is discarded, it can be replaced in the ier register by the newly generated bit of the minor product at the end of the multiplication process. The major product is found in the accumulator.

Figure $15-24$ is a simplified block diagram of the circuits used in serial multiplication for a three-address system. During phase 1 the multiplier enters the ier shift register (where the signal $F 1$ is a unit during phase 1).


Fig. 15-24. Serial multiplication: arrangement shown for multiplication only.
During phase 2 the multiplicand is brought into the arithmetic unit (where the signal $F 2$ is a unit during phase 2 ), and the multiplication is executed. In the first minor cycle of the phase the multiplicand enters the icand register to be stored; at the same time the first sum is formed, such that only if $P 1$ of the multiplier is 1 will the multiplicand be allowed to enter the adder.

During the second minor cycle the icand register recirculates the multiplicand and at the same time sends it to the adder. At $T_{0}{ }^{2}$ the multiplier is shifted right one position, putting $P 2$ in the controlling position, and spilling $P 1$, as $P 1$ of the product is simultaneously inserted into the most significant position of the ier register. The multiplicand enters the adder or not depending on $P 2$. At this time the first partial product is being recirculated through the adder, to be added to the multiplicand (or to all zeros, depending on $P 2$ ). In the above example $P 2$ is a unit. Note, however, that, when this addition is accomplished, the first partial product must be displaced one position to the right with respect to the multiplicand. This displacement is accomplished by recirculating the first partial product one position before it reaches the end of the accumulator. Thus $P 2$ of the first partial product is added to $P 1$ of the multiplicand, etc., to form the second partial product. Since $P 1$ of the first partial product does not contribute to the second partial product and has already been stored in the register, it is not recirculated.

At $T_{0}{ }^{3}$ the ier register is again shifted right as the next least significant bit of the minor product is inserted. This puts P3 of the multiplier in the controlling position and spills P2. Again the icand register recirculates the multiplicand, sending it as well to the adder. The second partial sum begins to recirculate one position before the end of the accumulator. And so the third and following partial products are generated, until the entire product has been formed. By this scheme a serial computer with $n$ bits to a word will consume $n$ minor cycles during multiplication.

In phase 3 either the major or the minor product is transmitted to the memory as indicated by the output gates from the accumulator and ier register as controlled by $F 3$ and the signal $J$, which is 1 when the major product is desired, 0 when the minor product is desired in Fig. 15-24.

Let us now examine some of the timing factors involved in multiplication. The multiplier $M$ is transmitted to the ier register so that $M 1$ enters the zeroth stage at $T_{1}{ }^{1}$ of phase 1 (since the sign bit is recorded elsewhere). $\quad M$ is shifted down the ier register so that $M 1$ reaches the end and can be presented to control the adder input at $T_{1}{ }^{1}$ of the first minor cycle of phase 2 . During each subsequent minor cycle of phase 2 the ier register shifts at $T_{1}{ }^{q}$, presenting the bit $M_{q}$ of $M$. The multiplicand $N$ is transmitted from the memory to both the icand register and adder during the first minor cycle of phase 2 so that $N 1$ enters the zeroth stage at $T_{1}{ }^{1}$. Of course, depending on $M 1$, it may or may not get into the adder. However, it is shifted down the icand register and recirculated in it each minor cycle so that $N 1$ is presented to the adder at $T_{1}{ }^{q}$.

To describe the timing associated with the accumulator, we need some special notation. Let $P^{q}$ be the $q$ th partial product generated during the $q$ th minor cycle of phase 2. Then the least significant bit of $P^{q}$, namely, $P^{q} 1$ (since no sign is attached to $P^{q}$ ), is actually the $P q$ bit of the (minor) final product. We want to recirculate $P^{q}$ so that $P^{q} 2$ enters the adder during $T_{1}{ }^{q+1}$. Thus we must stop the accumulator at the stage in which $P^{q} 2$ resides at $T_{0}{ }^{q+1}$. Using our formulas of Sec. 15-4, we have $T_{0}{ }^{q+1}=T_{w^{q}}$, whence $w-0(q-1)-2=w-2$ (since $\Delta=0$; why?). Since stage $w-1$ is the last stage, stage $w-2$ is next to the last stage as shown in Fig. 15-16. Next we want $P^{q} 1$ to be transmitted to the ier register at $T_{1}{ }^{q+1}$, whence it must be at position $w-1$ at $T_{0}{ }^{q+1}$.

Division. Binary division is accomplished in a serial computer by a method quite different from the familiar hand technique. Let us consider the case in which the quantity format places the binary point to the left of a word, i.e., in which all numbers are less than 1 . Let $N$ be the dividend, $D$ the divisor, and $Q$ the computed quotient; assume that $N$ and $D$ are positive, the sign of $Q$ being determined in a separate circuit. Thus we can write

$$
\frac{N}{D}=Q=Q_{1} 2^{-1}+Q_{2} 2^{-2}+Q_{3} 2^{-3}+\cdots+Q_{n} 2^{-n} \quad D>N
$$

where $Q_{1}$ is the most significant, $Q_{n}$ the least significant bit of the desired quotient. Now form

$$
\begin{aligned}
N^{\prime}=2 N-D & =D(2 Q-1) \\
& =D\left(Q_{1}-1+Q_{2} 2^{-1}+Q_{3} 2^{-2}+\cdots+Q_{n} 2^{-n+1}\right)
\end{aligned}
$$

Observe that, if $Q_{1}=1$, then $Q_{1}-1=0$ and since $Q_{2} 2^{-1}+Q_{3} 2^{-2}+$ $\cdots+Q_{n} 2^{-n+1}$ is positive, $2 N-D$ would be positive or zero. However, if $Q_{1}=0$, since $Q_{2} 2^{-1}+Q_{3} 2^{-2}+\cdots+Q_{n} 2^{-n+1}<1$, we have $2 N-D$ negative. Thus, depending on whether $2 N-D$ is positive or negative, we can determine that $Q_{1}$ is 1 or 0 .


Fig. 15-25. Flow chart of serial-division process.
Suppose that $Q_{1}=1\left(N^{\prime} \geq 0\right)$; then

$$
N^{\prime}=2 N-D=0+D\left(Q_{2} 2^{-1}+Q_{3} 2^{-2}+\cdots+Q_{n} 2^{-n+1}\right)=D Q^{\prime}
$$

Next form

$$
\begin{aligned}
N^{\prime \prime}=2 N^{\prime}-D & =D\left(2 Q^{\prime}-1\right) \\
& =D\left(Q_{2}-1+Q_{3} 2^{-1}+Q_{4} 2^{-2}+\cdots+Q_{n} 2^{-n+2}\right)
\end{aligned}
$$

whence $Q_{2}$ is determined to be 1 or 0 depending on whether $2 N^{\prime}-D$ is positive or negative.
However, suppose that $Q_{1}=0\left(N^{\prime}<0\right)$; then

$$
N^{\prime}=2 N-D=D\left(-1+Q_{2} 2^{-1}+Q_{3} 2^{-2}+\cdots+Q_{n} 2^{-n+1}\right)=D Q^{\prime}
$$

This time form

$$
\begin{aligned}
& N^{\prime \prime}=2 N^{\prime}+ D \\
&=D\left(2 Q^{\prime}+1\right) \\
&=D\left(-2+1+Q_{2}+Q_{3} 2^{-1}+Q_{4} 2^{-2}+\cdots+Q_{n} 2^{-n+2}\right) \\
&=D\left(Q_{2}-1+Q_{3} 2^{-1}+Q_{4} 2^{-2}+\cdots+Q_{n} 2^{-n+2}\right)
\end{aligned}
$$

which is exactly the same $N^{\prime \prime}$ as above. Hence we can flow-chart the division mechanism as in Fig. 15-25. The process ends when $Q_{n}$ has been determined (this not being shown in our flow diagram of Fig. 15-25).

Of course, when $N^{(i)}$ becomes zero, the division has come out even. The computer, however, continues the process, but each succeeding $N^{(i)}$ will be negative, so that each succeeding $Q_{j}$ will be zero.

As an example, suppose that $N=.10110110$ and $D=.11100000$. Then the calculations would proceed as follows:

Form $2 N-D$

$$
\begin{array}{r}
\frac{1.01101100}{-.11100000} \\
+.10001100
\end{array}=N^{\prime}>0 \quad \text { hence } Q_{1}=1
$$

Form $2 N^{\prime}-D$

$$
\frac{1.00011000}{\frac{-.11100000}{+.00111000}}=N^{\prime \prime}>0 \quad \text { hence } Q_{2}=1
$$

Form $2 N^{\prime \prime}-D$

$$
\begin{array}{r}
0.01110000 \\
\frac{-.11100000}{-.01110000}=N^{\prime \prime \prime}<0 \quad \text { hence } Q_{3}=0
\end{array}
$$

Form $2 N^{\prime \prime \prime}+D$

$$
\begin{array}{r}
-0.11100000 \\
+.11100000 \\
\hline+.00000000
\end{array}=N^{(\mathrm{iv})}=0 \quad \text { hence } Q_{4}=1
$$

and the process is complete for this case, with $Q=.110100 \ldots$


Fig. 15-26. Serial division: arrangement shown for division only.
Figure $15-26$ is a simplified block diagram of the circuitry used in serial division. During phase 1 the dividend $N$ enters the accumulator. During the first minor cycle of phase 2 the divisor $D$ enters both the adder and the icand register. In the icand register $D$ is recirculated each minor cycle, successively sending $D$ to the adder. Now during the first minor cycle of phase 2 we wish to form $2 N-D$. Forming $2 N$ is simple, for all we need do is shift $N$ to the left one position, or, equivalently, delay the entrance of $N$ into the adder for 1 unit of time. Thus effectively
$2 N$ enters the adder at the same time as $D$ enters the adder. In this way $N^{\prime}=2 N-D$ is formed in the adder during the first minor cycle. Next the addition-subtraction sign generator operates: if $N^{\prime}=2 N-D \geq 0$, $Q_{1}=1$; if $N^{\prime}<0, Q_{1}=0$. Since a positive sign is a unit and a negative sign a zero, the sign bit itself is equal to the value of $Q_{1}$ and therefore is put into the ier register, where the quotient will be formed 1 bit at a time.

During the second minor cycle of phase 2 we wish to form $N^{\prime \prime}$ as either $2 N^{\prime}-D$ or $2 N^{\prime}+D$ depending on the value of $Q_{1}$ (see above). By delaying $N^{\prime}$ as it recirculates from the accumulator to the adder $2 N^{\prime}$ is effectively formed. The recirculating icand register sends $D$ to the adder, where $N^{\prime \prime}=2 N^{\prime}-D$ (or $2 N^{\prime}+D$ ) is formed. The sign of $N^{\prime \prime}$ is determined and becomes $Q_{2}$. Now $Q_{2}$ is less significant than $Q_{1}$ and therefore must appear in the quotient adjacent to $Q_{1}$ on its right. To accomplish this, $Q_{1}$ has been recirculated around the ier register with an additional unit delay so that it will reenter the ier register just after $Q_{2}$ is placed there. Thus $Q_{2}$ will be to the right of $Q_{1}$ as desired. During the third minor cycle $Q_{3}$ is formed as usual, and the partial quotient $Q_{1} Q_{2}$ is recirculated again with a unit delay, enabling $Q_{3}$ to be placed to the right of $Q_{1} Q_{2}$, forming $Q_{1} Q_{2} Q_{3}$, and so forth.

Consider Table 15-2, Sum and Difference Conditions, as applied to the special case of division. The denominator $D$, which corresponds to the second operand $B$ of the table, will always be positive. If a given $N^{(i)}$, which corresponds to the first operand $A$ of the table, is positive, $N^{(i+1)}$ is formed by subtracting: $N^{(i+1)}=2 N^{(i)}-D$. From the table we see that the result is formed by differencing. If a given $N^{(i)}$ is negative, $N^{(i+1)}$ is formed by adding: $N^{(i+1)}=2 N^{(i)}+D$. Again the table shows that the result is formed by differencing. Hence in division the signal $P$ of both the table and Fig. 15-26 can be forced off during the entire operation.

## EXERCISES

(a) Design a sign generator for multiplication and division. (Hint: If the signs of the arguments are the same, the sign of the result is + ; if different, the sign is -.)
(b) Suppose that a continuously shifting register were used for the ier register for multiplication. How should the recirculation loop be designed?
(c) How many minor cycles does multiplication take during phase 2 ?
(d) How many minor cycles does division take during phase 2?
(e) Suppose that $N>D$ in division. How can this be detected in the division method described in this section?
( $f$ ) Check the method of recirculation of the accumulator and the ier register by means of the formulas of Sec. 15-4.
(g) How would serial division take place in a computer in which the binary point is to the right (i.e., every number is an integer)?
(h) Discuss serial decimal multiplication and division based on a serial decimal adder and subtractor. [Hint: Multiplication is rather straightforward. For division one simple method is to let $N / D=Q$, whence $N=D Q=D\left(Q_{1} 10^{-1}+Q_{2} 0^{-2}+\right.$ $Q_{3} 10^{-3}+\cdots \cdot$. Form $10 N-t D=D\left(Q_{1}-t+Q_{2} 10^{-1}+Q_{3} 10^{-2}+\cdots\right)$ for successive values of $t=1,2, \ldots, 10$, until $10 N-t D$ becomes negative, whence
$Q_{1}=t-1$. Then we have $N^{\prime}=10 N-t D=D\left(-1+Q_{2} 10^{-1}+Q_{3} 10^{-2}+\cdots\right)$. Now form $10 N^{\prime}+t D$ for successive values of $t=1,2, \ldots, 10$, until $10 N^{\prime}+t D=$ $\left((t-10)+Q_{2}+Q_{3} 10^{-1}+\cdots\right)$ becomes positive, whence $Q_{2}=10-t$. Then $N^{\prime \prime}=10 N^{\prime}+t D=\left(Q_{3} 10^{-1}+Q_{4} 10^{-2}+\cdots\right)$, and we are back to a situation analogous to that for $Q_{1}$.]
(i) What extra circuitry might be needed to detect "even" division, that is, $N^{(i)}=0$, or $2 N^{(i)} \pm D= \pm D$ ?

## 15-7. Additional Topics

a. Cyclic and Decimal-coded Binary Codes. We have alluded above to the cyclic code. The main property of this code is that successive numbers differ by only a single bit position, as can easily be seen from Table 15-5. The cyclic code given in this table can be derived from the corresponding binary number as follows: If the bit positions are indexed from right to left by $i$, then $c_{i}$, the $i$ th bit of the cyclic code, can be found from the $b_{i}$ and $b_{i+1}$ bits of the binary code by means of the following formula:

$$
c_{i}=b_{i} \cdot \bar{b}_{i+1}+\bar{b}_{i} \cdot b_{i+1}
$$

The conversion would then be accomplished from right to left. The reverse conversion, from cyclic to binary, can be accomplished by solving the above formula for $b_{i}$ in terms of $c_{i}$ and $b_{i+1}$,

$$
b_{i}=c_{i} \cdot \bar{b}_{i+1}+\bar{c}_{i} \cdot b_{i+1}
$$

The conversion in this case would be accomplished from left to right. The cyclic code is advantageous mainly in the use of relay circuits, for then a sticky relay will not give a false state as it is delayed in going from one cyclic number to the next. There are many other cyclic codes that have this property. Can you construct some of them?

Table 15-5. Examples of Cyclic and Decimal-coded Binary Codes

| Decimal | Binary | Cyclic | Excess-three | Biquinary | $5-421$ | $2-421$ | 5 -cyclic | Features |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0000 | 0000 | 0011 | 0 | 0000 | 0 | 000 |  | 0 |

The other codes shown in Table 15-5 are used for decimal-coded binary arithmetic. (We have already discussed such arithmetic for the excess-three codes.) The use of the biquinary code in this respect is typical. The binary part (i.e., the most significant bit) and the quinary part (the other 4 bits) are first added separately; then the quinary carry is added to tine binary part. If a binary carry is generated, this is propagated to the quinary part of the next decimal digit to the left. For example, consider the following work for adding 26 and 34 :

| Decimal | Biquinary |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 36 | 0 | 0100 | 1 | 0001 |  |
| $+24$ | 0 | 0010 | 0 | 1000 |  |
|  |  | $0000$ |  | $\overline{0000}$ | Quinary carry |
|  | 1 | 0000 |  | 0000 |  |
| 60 | 1 | 0001K | 0 | 0000 | carry |

Similarly addition in the 5-421, 2-421, and 5-cyclic codes is accomplished in two parts.

Only two of the codes enable binary addition. Having the binary carry the same as the decimal carry from one digit to the next digit on the left is useful in designing an adder. If the code admits constant weights, it is more convenient for rapid decimal interpretation [i.e., in the $2-421$ code 1011 means $(1 \times 2)+(0 \times 4)+$ $(1 \times 2)+(1 \times 1)=5]$. We have already seen the advantages of having the inversion of a binary number as its nines complement (nines complement of $x$ is $9-x$ ) when we discussed the excess-three code. Evidently there are many more possibilities for decimal-coded binary codes, which can be constructed to have various features. Can you construct a code that is 5 -cyclic and for which the nines complement is the inversion [i.e., for which $9999-\left(c_{4} c_{3} c_{2} c_{1}\right)=\overline{c_{4} c_{3} c_{2} c_{1}}$ ]? Further reading on this problem may be found in G. S. White, Coded Decimal Number Systems for Digital Computers, Proc. IRE, vol. 41, p. 1450, October, 1953; and in L. B. Wadel, Negative Base Number Systems, IRE Trans. on Electronic Computers, vol. EC-6, no. 2, p. 123, June, 1957.
b. Logically design the components of a digital differential analyzer, as described in Sec. 8-2.
c. Logically design the computing components of the small retrieval computer described in Sec. 8-4.
d. Logically design the functional part of the control computer described in Sec. 8-3.

## PARALLEL AND RAPID ARITHMETIC OPERATIONS

## 16-1. Introduction

In Chap. 15 we considered the basic ideas involved in the logical design methods and techniques of enabling a computer to perform arithmetic operations. In the present chapter we consider what may be referred to as refinements of those basic ideas that result in more rapid processing of these operations. Again we choose specific examples of parallel and rapid techniques, for it is felt that the student will gain more from a thorough discussion of one particular technique than from a cursory discussion of many methods. The addition and subtraction operations can be handled in parallel; i.e., all the bits of both arguments enter the adder at the same time, and all the bits of the result are formed simultaneously. However, complete parallel operation is not feasible for multiplication or division. Various observations will be made that allow short cuts eliminating some of the additions and subtraction required by the essentially serial character of the multiplication and division techniques. These short cuts for rapid multiplication and division can be used in conjunction with serial addition and subtraction, or with parallel operations for further speed in computation. At the end of the chapter is presented a discussion of how floating operation might be accomplished.

As will become quite apparent, the gain in speed arising from the parallel and rapid techniques is offset by the requirement of many more gates. In fact the great advantage of serial techniques is that a minimum of circuitry is necessary. In other words, speed costs money. On the other hand the ability to perform calculations rapidly is one of the primary purposes of computers, and hence the increased cost of building a more rapid computer may itself be offset by the greater potentialities the computer offers by its increased speed. Both serial and parallel computers have their places and their uses, and we believe that both types will continue to be designed.

## 16-2. The Parallel Adder : $\dagger$ Logical Design

Parallel Binary Carry Generation. In a parallel adder all the bits of both arguments enter the adder at once, and all the bits of the sum
$\dagger$ Sections 16-2 to 16-4 are based in part on A. Weinberger and J. L. Smith, Methods for High-speed Addition and Multiplication, NBS Circ. 591.
are formed at once. Recall that in Sec. 15-3 we found the $R_{i}$ bit of the result to be $R_{i}=\left(A_{i} \cdot \bar{B}_{i}+\bar{A}_{i} \cdot B_{i}\right) \cdot \bar{C}_{i-1}+\left(\bar{A}_{i} \cdot \bar{B}_{i}+A_{i} \cdot B_{i}\right) \cdot C_{i-1}$. Hence, if $A_{i}, B_{i}$, and $C_{i-1}$ were available, $R_{i}$ could be determined. Since all the bits of the arguments enter a parallel adder at once, we certainly have $A_{i}$ and $B_{i}$ available for every bit position $i$. However, we must still obtain $C_{i-1}=C_{i-1}\left(A_{1}, B_{1}, A_{2}, B_{2}, \ldots, A_{i-1}, B_{i-1}\right)$ and this carry generation becomes the fundamental problem of parallel addition.

In forming the carries there are three limitations, which are essentially electronic in nature but nonetheless do affect the logical design of parallel adders. The electronic aspects will be discussed in detail in Part 5; here we shall consider only the resulting limitations on the logical design. The first limitation is that the output of a single gate can be the input to only a limited number of other gates. The second is that there can be only a limited number of inputs to a single gate. The third concerns our previous approximation that no time is consumed when a pulse travels through a gating array. This approximation holds when a single pulse travels through a chain of just a few gates from the memory to the accumulator or other register. But when a pulse travels through a chain of many gates, the delay through the gating circuitry can no longer be neglected. This limits the number of gates in the chain through which a single pulse can travel within a unit time interval and precludes the use of a propagated carry.

In a serial computer these three limitations are usually less stringent than those of the logical design, and they can often be neglected. Even in parallel circuitry some of the limitations may be disregarded, depending on the electronic design of the gates. For example, the first limitation for certain tube and core-transistor circuitry is so large that it need not be considered as a limitation at all. On the other hand, for a transistor gate at high speeds, the number of outputs a single gate can have is frequently severely limited by the electronic design.

The method for generating $C_{i}$ is by direct substitution as follows:

$$
\begin{aligned}
C_{1}= & A_{1} \cdot B_{1} \\
C_{2}= & A_{2} \cdot B_{2} \\
& +\left(A_{2}+B_{2}\right) \cdot C_{1}= \\
& +\left(A_{2} \cdot B_{2}+B_{2}\right) \cdot A_{1} \cdot B_{1} \\
C_{3}= & A_{3} \cdot B_{3}= \\
& +\left(A_{3}+B_{3}\right) \cdot C_{2} \cdot B_{3} \\
& +\left(A_{3}+B_{3}\right) \cdot A_{2} \cdot B_{2} \\
& +\left(A_{3}+B_{3}\right) \cdot\left(A_{2}+B_{2}\right) \cdot A_{1} \cdot B_{1} \\
C_{4}= & A_{4} \cdot B_{4}= \\
& +\left(A_{4}+B_{4}\right) \cdot C_{3}= \\
& +\left(A_{4}+B_{4}\right) \cdot A_{3} \cdot B_{3} \\
& +\left(A_{4}+B_{4}\right) \cdot\left(A_{3}+B_{3}\right) \cdot A_{2} \cdot B_{2} \\
& +\left(A_{4}+B_{4}\right) \cdot\left(A_{3}+B_{3}\right) \cdot\left(A_{2}+B_{2}\right) \cdot A_{1} \cdot B_{1} \\
= & A_{5} \cdot B_{5} \\
& +\left(A_{5}+B_{5}\right) \cdot A_{4} \cdot B_{4} \\
& +\left(A_{5}+B_{5}\right) \cdot\left(A_{4}+B_{4}\right) \cdot A_{3} \cdot B_{3} \\
& +\left(A_{5}+B_{5}\right) \cdot\left(A_{4}+B_{4}\right) \cdot\left(A_{3}+B_{3}\right) \cdot A_{2} \cdot B_{2} \\
& \left.+\left(A_{5}+B_{5}\right) \cdot C_{4}\right) \\
& +\left(A_{5}+B_{5}\right) \cdot\left(A_{4}+B_{4}\right) \cdot\left(A_{3}+B_{3}\right) \cdot\left(A_{2}+B_{2}\right) \cdot A_{1} \cdot B_{1}
\end{aligned}
$$

and so forth. Thus a 5-bit parallel adder can be constructed as in Fig. 16-1.

Let us examine this adder with respect to the above limitations. Consider the first, the loading of each output. Table $16-1$ summarizes the number of outputs required


Fig. 16-1. Five-bit parallel adder. for some of the gates of the adder. If any gate could have six outputs, we would be safe. However, suppose, for example, that a gate could have no more than three outputs. We can still squeeze through, however, by paralleling gates, as shown


Fig. 16-2. Generating up to nine outputs $A_{3}+B_{3}$.
in Fig. 16-2 for $A_{3}+B_{3}$. No gate has more than three outputs, and yet we can generate up to nine functions $A_{3}+B_{3}$.

Consider next the second limitation. The gate that has the largest number of inputs in our parallel adder is the and gate that forms $\left(A_{5}+B_{5}\right) \cdot\left(A_{4}+B_{4}\right) \cdot\left(A_{3}+B_{3}\right) \cdot\left(A_{2}+B_{2}\right) \cdot A_{1} \cdot B_{1}$, which has six inputs. To see how this limitation can affect the design of our parallel adder, let us assume that a single gate can have no more than six inputs. This means that if we wanted to design, say, a parallel adder for more

Table 16-1. Number of Outputs Required for 5-bit Parallel Adder

| Function | Number of outputs needed |
| :--- | :---: |
| $A_{1} \cdot B_{1}$ | 5 |
| $A_{2} \cdot B_{2}$ | 4 |
| $A_{3} \cdot B_{3}$ | 3 |
| $A_{4} \cdot B_{4}$ | 2 |
| $A_{5} \cdot B_{5}$ | 1 |
| $A_{2}+B_{2}$ | 4 |
| $A_{3}+B_{3}$ | 6 |
| $A_{4}+B_{4}$ | 6 |
| $A_{5}+B_{5}$ | 4 |

than 5 bits, the complete expressions for $C_{6}, C_{7}$, etc., analogous to the expression given above for $C_{5}$, can no longer be used, since to construct $C_{6}$ would require a seven-input and gate, and to construct $C_{7}$


Fig. 16-3. Nine-bit parallel adder.
would require a seven- and an eight-input and gate, and so forth [i.e., corresponding to the partial expressions: $+\left(A_{6}+B_{6}\right) \cdot\left(A_{5}+B_{5}\right) \cdot$ $\left(A_{4}+B_{4}\right) \cdot\left(A_{3}+B_{3}\right) \cdot\left(A_{2}+B_{2}\right) \cdot A_{1} \cdot B_{1}$, etc.].

One way out of this dilemma is to note that

$$
\begin{array}{rlr}
C_{6}= & A_{6} \cdot B_{6} \\
& +\left(A_{6}+B_{6}\right) \cdot C_{5} \\
C_{7}= & A_{7} \cdot B_{7} & \\
& +\left(A_{7}+B_{7}\right) \cdot C_{6}= & A_{7} \cdot B_{7} \\
& & +\left(A_{7}+B_{7}\right) \cdot A_{6} \cdot B_{6} \\
& & +\left(A_{7}+B_{7}\right) \cdot\left(A_{6}+B_{6}\right) \cdot C_{5} \\
C_{8}= & A_{8} \cdot B_{8} & \\
& +\left(A_{8}+B_{8}\right) \cdot C_{7} \cdot B_{8} \\
& & +\left(A_{8}+B_{8}\right) \cdot A_{7} \cdot B_{7} \\
& & +\left(A_{8}+B_{8}\right) \cdot\left(A_{7}+B_{7}\right) \cdot A_{6} \cdot B_{6} \\
& & +\left(A_{8}+B_{8}\right) \cdot\left(A_{7}+B_{7}\right) \cdot\left(A_{6}+B_{6}\right) \cdot C_{5}
\end{array}
$$

and so forth. By this method we can extend our adder to 9 bits added in parallel within this limitation, as in Fig. 16-3.

However, a pulse may now have to travel through a longer chain of gates, which brings up the third limitation. For example, consider a pulse arising from $A_{5}$ that goes into the formation of $C_{5}$ and then eventually of $R_{7}$. Figure $16-4$ shows that it must travel through a chain of seven gates altogether.

Auxiliary Carry Functions. Suppose that we wanted to design an
adder of more than 9 bits but could not allow any pulse to go through a chain longer than seven gates. This problem is solved by the use of auxiliary carry functions as follows: It is clear that $C_{10}$ cannot be made based on $C_{5}$, because of the limitation on the number of inputs to a gate. It is also clear that we cannot base $C_{10}$ directly on $C_{9}$, for this would lengthen the chain of gates that a pulse must go through. However, note


Fig. 16-4. Chain of seven gates through which pulse $A_{5}$ must travel to contribute to the formation of $R_{7}$.
that the formation of $C_{6}, C_{7}, C_{8}$, and $C_{9}$ is delayed until $C_{5}$ has been produced. Thus perhaps we could break up the construction of $C_{10}, C_{11}$, etc., into two parts, one part of which would be made concurrently with $C_{1}, C_{2}, C_{3}, C_{4}$, and $C_{5}$ and the final part of which would be made simultaneously with $C_{6}, C_{7}, C_{8}$, and $C_{9}$. To see how this can be accomplished, let us write out $C_{10}$.


Call the function in the triangle $X_{10}$ and in the rectangle below $Y_{10}$. Then

$$
C_{10}=\frac{X_{10}}{+Y_{10} \cdot C_{5}}=X_{10}+Y_{10} \cdot C_{5}
$$

The auxiliary carry function $X_{10}$ satisfies our requirements on the number of inputs to a single gate (no more than six), and so does $Y_{10}$. Thus we


Fig. 16-5. Fourteen-bit parallel adder using auxiliary carry functions.
can form $X_{10}$ and $Y_{10}$ first, and then form $C_{10}$ from these. Using these auxiliary carry functions, we can also form

$$
\begin{aligned}
C_{11}= & A_{11} \cdot B_{11} \\
& +\left(A_{11}+B_{11}\right) \cdot C_{10}= \\
& \\
& +\left(A_{11}+B_{11}\right) \cdot X_{10} \\
& +\left(A_{11}+B_{11}\right) \cdot Y_{10} \cdot C_{5} \\
C_{12}= & A_{12} \cdot B_{12} \\
& +\left(A_{12}+B_{12}\right) \cdot C_{12} \cdot B_{12} \\
& \\
& +\left(A_{12}+B_{12}\right) \cdot A_{11} \cdot B_{11} \\
& \\
& +\left(A_{12}+B_{12}\right) \cdot\left(A_{11}+B_{11}\right) \cdot X_{10} \\
& \\
& +\left(A_{12}+B_{12}\right) \cdot\left(A_{11}+B_{11}\right) \cdot Y_{10} \cdot C_{5}
\end{aligned}
$$

and similarly $C_{13}$ and $C_{14}$. Hence we have the 14 -bit parallel adder as shown in Fig. 16-5.

Generating $C_{15}$ again raises a problem, for this would involve a seven-
input gate even with the use of our auxiliary carry functions $X_{10}$ and $Y_{10}$. However, we can construct, as follows, other carry functions, called $X_{15}$ and $Y_{15}$, which will do the job. Writing out $C_{15}$, we find

$$
C_{15}=\begin{aligned}
& \begin{array}{l}
A_{15} \cdot B_{15} \\
+\left(A_{15}+B_{15}\right) \cdot A_{14} \cdot B_{14} \\
+\left(A_{15}+B_{15}\right) \cdot\left(A_{14}+B_{14}\right) \cdot A_{13} \cdot B_{13} \\
+\left(A_{15}+B_{15}\right) \cdot\left(A_{14}+B_{14}\right) \cdot\left(A_{13}+B_{13}\right) \cdot A_{12} \cdot B_{12} \\
+\left(A_{15}+B_{15}\right) \cdot\left(A_{14}+B_{14}\right) \cdot\left(A_{13}+B_{13}\right) \cdot\left(A_{12}+B_{12}\right) \cdot A_{11} \cdot B_{11} \\
\hline+\left(A_{15}+B_{15}\right) \cdot\left(A_{14}+B_{14}\right) \cdot\left(A_{13}+B_{13}\right) \cdot\left(A_{12}+B_{12}\right) \cdot\left(A_{11}+B_{11}\right) \\
+\left(A_{15}+B_{15}\right) \cdot\left(A_{14}+B_{14}\right) \cdot\left(A_{13}+B_{13}\right) \cdot\left(A_{12}+B_{12}\right) \cdot\left(A_{11}+B_{11}\right)
\end{array} \\
& \hline
\end{aligned}
$$

whence we write

$$
C_{15}=X_{15} \quad=X_{15}+Y_{15} \cdot\left(X_{10}+Y_{10} \cdot C_{5}\right)
$$

where $X_{15}$ and $Y_{15}$ can be formed concurrently with $X_{10}, Y_{10}$, and $C_{5}$.
Summarizing, we observed three possible limitations on the logical design of the parallel adder and discussed methods and techniques for overcoming these difficulties. It is clear that the exact form of the logical design of a parallel adder depends on the specific values of the limitations involved and can be no more than the best possible compromise with these limitations.

## EXERCISES

(a) Draw the logical details of the circuits represented by boxes $C_{1}, C_{2}, C_{8}, C_{4}$, and $C_{5}$ of Fig. 16-1.
(b) Draw the logical details of the circuit represented by box $R_{4}$ of Fig. 16-1.
(c) If $C_{6}$ had been made directly from $A_{5}, B_{5}, A_{4}, B_{4}, \ldots, A_{1}, B_{1}$, how many more gates would be in the chain that the pulses $A_{5}$ would have to travel to contribute to the formation of $R_{6}$ ?
(d) By using additional auxiliary carry functions, show how Fig. 16-5 can be extended to add two 21-bit binary numbers in parallel under the limitations of no more than six inputs to a single gate. Explicitly display the additional auxiliary carry functions necessary.

## 16-3. Parallel Arithmetic Units

The Parallel Adder-Subtractor Combination. When forming the difference between two numbers, we have seen that $R_{i}$ is the same as for the sum. However, consider the parallel generation of the carry for subtraction. We shall in this section continue to use $C_{i}$ for the carry for subtraction as well as addition. We then have by successive substitution
the carries for subtraction:

$$
\begin{array}{rlrl}
C_{1}= & \bar{A}_{1} \cdot B_{1} & \\
C_{2}= & \bar{A}_{2} \cdot B_{2} & & \\
& +\left(\bar{A}_{2}+B_{2}\right) \cdot C_{1} \cdot B_{2} \\
C_{3}= & \bar{A}_{3} \cdot B_{3} & & +\left(\bar{A}_{2}+B_{2}\right) \cdot \bar{A}_{1} \cdot B_{1} \\
& +\left(\bar{A}_{3}+B_{3}\right) \cdot C_{2} & = & \bar{A}_{3} \cdot B_{3} \\
& & +\left(\bar{A}_{3}+B_{3}\right) \cdot \bar{A}_{2} \cdot B_{2} \\
& & +\left(\bar{A}_{3}+B_{3}\right) \cdot\left(\bar{A}_{2}+B_{2}\right) \cdot \bar{A}_{1} \cdot B_{1}
\end{array}
$$

and so forth. It becomes immediately clear that if $\bar{A}_{i}$ is replaced by $A_{i}$ these expressions become identical with those for addition given above. Thus, in order to subtract, all we need do is replace $A_{i}$ by $\bar{A}_{i}$ in the carry and auxiliary carry functions and use the same circuitry as was used for parallel addition. Hence, with this added feature, the parallel adder designed above becomes a parallel subtractor also.

To incorporate our parallel adder-subtractor combination into an arithmetic unit, we must be able to take the subtractive complement of our result when necessary. This can easily be performed in parallel by making use of the parallel circuitry already available, for the subtractive complement of $R$ is simply $2^{p}-R$. Thus we send the result $R$ back into the parallel adder via the route used previously by $B$ and form the difference $2^{p}-R$. Note that we did not reuse the serial adder for this purpose, because it would have required recirculating the contents of the accumulator back through the adder again, using up another minor cycle; it was more convenient to perform this operation in serial as the contents of the accumulator was being transferred to the memory. However, in our parallel arithmetic unit, it requires only an extra unit time interval to form the subtractive complement in the adder, and has the added advantage of using no further circuitry except for control purposes.

Parallel Decimal Addition and Subtraction. Again considering binarycoded decimal in the excess-three system, we shall show how the circuitry of our parallel binary adder can be extended to handle parallel decimal addition as well. As was shown in Sec. 15-5, the carry from one 4-bit coded decimal digit to the successive one during addition is the ordinary binary carry produced in the binary addition of the digit codes. Not only that, but the decimal sum was obtained by adding the arguments as if they were binary numbers, and then adjusting each 4-bit group of the result by adding or subtracting 3 to form the decimal-coded result. The method for extending our binary parallel adder to become a decimal parallel adder now becomes clear. First add the two arguments in parallel as if they were binary numbers, but recording the carries $C_{4}, C_{8}$, $C_{12}, C_{16}$, etc. Now send the result back to the adder, and this time operate only on the successive groups of 4 bits independently; subtract 3 if no carry from this group occurred; add 3 if a carry from this group did occur. The trick then is to operate in this way on the groups independ-
ently. This may be accomplished simply by cutting out any contribution to the result, carry, or auxiliary carry functions from any place other than these four positions. In Fig. 16-6, which is an adaptation of Fig. 16-5, we have indicated which pulses would be stopped from propagating for this $\pm 3_{b}$ adjustment phase of decimal addition. With a carry $C_{i}=1, \bar{C}_{i}=0$, and we add $\bar{C}_{i} \bar{C}_{i} C_{i} 1 \equiv 0011$ to the corresponding 4 bits. With no carry $C_{i}=0, \bar{C}_{i}=1$, and we add $1101=\left(2^{4}-3\right)_{b}$


Fig. 16-6. Binary parallel adder illustrated during its use for $\pm 3_{b}$ adjustment when adapted for a 3 -digit decimal parallel adder. The crosses indicate which pluses are to be stopped from propagation.
(without carry). In adjusting the third decimal digit ( $R_{9}$ to $R_{12}$ ), $C_{12}=1$ indicates overflow in the addition.

Parallel decimal subtraction can be accomplished by means of an adaptation of our binary parallel adder in a clearly straightforward manner, using the appropriate rules for the $\pm 3_{b}$ adjustment.

Another technique would be to add or subtract $3_{b}$ from each digit (as indicated by the carry in summing or differencing) by means of special circuitry for each group of 4 bits. It turns out that if $R_{4}, R_{3}, R_{2}, R_{1}$ represent an unadjusted group of 4 bits, then, whether differencing or summing, the only conditions when $-3_{b}$ adjustment may be required are given by the following constrained basis (see Exercise c), where the
adjusted values of the digits appear below:

| $R_{1}$ | 01 | 0101 | 0101 |
| :--- | :--- | :--- | :--- |
| $R_{2}$ | 11 | 0011 | 0011 |
| $R_{3}$ | 11 | 0000 | 1111 |
| $R_{4}$ | 00 | 1111 | 1111 |
| $R_{1}^{d}$ | 10 | 1010 | $1010=\bar{R}_{1}$ |
| $R_{2}^{d}$ | 10 | 0110 | $0110=R_{1} \cdot \bar{R}_{2}+\bar{R}_{1} \cdot R_{2}$ |
| $R_{3}^{d}$ | 01 | 1110 | $0001=R_{1} \cdot R_{2} \cdot R_{3}+\left(\bar{R}_{1}+\bar{R}_{2}\right) \cdot \bar{R}_{3}$ |
| $R_{4}{ }^{d}$ | 00 | 0001 | $1111=R_{1} \cdot R_{2} \cdot \bar{R}_{3}+R_{3} \cdot R_{4}$ |

This then is the circuitry required for the $-3_{b}$ adjustment. Similarly it can be shown that, whether differencing or summing, the conditions when $+3_{b}$ adjustment may be required are the same for either case. Then (see Exercise d) we find for the circuitry that will form the $+3_{b}$ adjusted group of 4 bits:

$$
\begin{aligned}
& R_{1}{ }^{d}=\bar{R}_{1} \\
& R_{2}^{d}=R_{1} \cdot R_{2}+\bar{R}_{1} \cdot \bar{R}_{2} \\
& R_{3}=\left(R_{1}+R_{2}\right) \cdot \vec{R}_{3}+\bar{R}_{1} \cdot \vec{R}_{2} \cdot R_{3} \\
& R_{4}{ }^{d}=\left(R_{1}+R_{2}\right) \cdot R_{3}+R_{4}
\end{aligned}
$$

If $P=1$ means sum, $P=0$ means difference, and $C$ is the carry, then the signal that tells which set of circuitry to use, i.e., whether to add 3 ( $Z=1$ ) or subtract $3(Z=0)$, becomes (according to Sec. 15-5)

$$
Z=P \cdot C+\bar{P} \cdot \bar{C}
$$

## EXERCISES

(a) Draw a detailed schematic of a parallel arithmetic adder-subtractor unit, and discuss the function and operation of each of the necessary components.
(b) Describe in detail parallel decimal subtraction.
(c) Find the constrained basis representing all possible conditions on the unadjusted group of 4 bits $R_{4} R_{3} R_{2} R_{1}$ after summing two excess-three decimal digits that can require $-3_{b}$ adjustment. Show that the conditions after differencing that can require $-3_{b}$ adjustment are the same. (Hint: The smallest unadjusted sum of 2 digits is $6_{b}$; the largest unadjusted sum of 2 digits that generates no carry is $15_{b}$, etc.)
(d) Derive equations for circuitry that will form the $+3_{b}$ adjusted group of 4 bits after summing or differencing 2 decimal excess-three digits.
(e) What are the advantages and disadvantages of the two methods shown in the text for forming the $\pm 3_{b}$ adjustment?

## 16-4. Rapid Multiplication

Short Cuts for Rapid Multiplication. The methods for short-cut multiplication depend on the following observations: First note, for example, 76543210 that the binary number 00100100 can be written as $2^{5}+2^{2}$. Hence, to form $(00100100)(N)$, we need merely add $2^{5} N+2^{2} N$. Second observe 6543210
that, for example, the binary number 0011111 can be written as $2^{5}-2^{0}$,
that is, $0100000-1=0011111$. In general it follows that

Thus, when a multiplier has a string of units, we need not form the partiai product for each unit, but merely subtract $\left(2^{\alpha}\right)$ (multiplicand) from 6543210 $\left(2^{\beta+1}\right)$ (multiplicand). Third consider a binary number, say 0011011; this can be written in the form $2^{5}-2^{2}-2^{0}$, since it is the same as 0011111 reduced by $2^{2}$. Hence 0011011 is said to have a string of units with an included zero. Note that the effect of an included zero is a subtraction of the corresponding power of 2 . Clearly this holds for more than one included zero: thus, for example, if a string of units from positions $\alpha$ to $\beta$ has included zeros in positions $\gamma$ and $\delta$, then it can be written as $2^{\beta+1}-2^{\gamma}-2^{\delta}-2^{\alpha}$.
Our three observations can be combined to write any binary number in terms of powers of 2 , where the object is to have the least number of powers of 2 in the representation. For example,

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $=2^{15}-2^{12}-2^{9}+2^{6}+2^{4}-2^{0}$ |

As an illustration, let us form the product


This may be checked by the long method.
Let us now discuss various problems that arise when choosing the appropriate powers of 2 for such a multiplier reduction. The problem is to determine when to add the multiplicand to the partial product, when to subtract it, and when to just shift the partial product and pass. A little notation can aid this discussion; rather than explicitly write out the powers of 2 , let + above a bit position of the multiplier indicate the fact that the multiplicand should be added to the partial product from that position, let - above a bit position indicate a subtraction from that position, and $\cdot$ above a bit position indicate a pass. In this
notation the multiplier of our above example becomes

The computer will sense the multiplier from right to left, i.e., from least toward successively more significant bits. At each bit it must decide whether to add, subtract, or pass. A good decision is one that will pass the largest number of bits, i.e., postpone or put off to the left as far as possible any addition or subtraction. For example, consider the number 01011. This may be interpreted as $00+1011$ or as $00+1 \overline{1} \overline{1}$. In the former case we considered the adjacent units to be a string, and in the latter case we considered all 3 units as belonging to a string with an included zero. However, the latter case was a better decision, for we postponed the addition farther to the left than in the former case (i.e., in the former case the addition was done at $P 3$ and in the latter at P4). Similarly consider $\stackrel{+\cdot}{0} 1 \overline{101}$ and $\stackrel{+\cdot \cdot 1}{0} 101$; the latter is considered better than the former.
These observations can best be summarized in terms of the concept of a string of units. Two or more adjacent units constitute a string of units, and as noted above, the least significant unit of a string is interpreted as $\overline{1}$, while the zero to the left of the most significant unit is interpreted as $\stackrel{+}{0}$, for example as in $\dot{+}+\stackrel{+}{0} 11111$. A string may include isolated zeros, i.e., zeros each of which is flanked by units; such zeros are interpreted as $\overline{0}$, for example as in $\dot{0}+\dot{+} \dot{1} 0101 \overline{1}$. Isolated units, i.e., units each of which is flanked by zeros and is not a member of a string, are interpreted as $\stackrel{+}{1}$, for example as in 0010100 . Thus working from right to left, as a string of units is met, a subtraction must take place, and only subtraction can take place within the string; in exiting from a string, an addition takes place, and only additions can take place outside a string. Finally let us note that our above discussion showed that, when working from right to left, we should not initiate a string until at least two adjacent units occur, that is, . . . $\mathrm{i}_{101}^{+1}$ is better than . . . i101, and we should not stop a

 clear that Table 16-2 gives the rules determining whether the computer should add, subtract, or pass in considering the $i$ th bit of the multiplicand.

Rapid Multiplication in Serial and Parallel Computers. Rapid multiplication can be designed into a serial computer provided that the icand register is of the shift-register type, i.e., is not a delay line. The procedure would be to examine each bit of the multiplier, together with the next most significant bit and a record of the previous operation, to determine whether to recirculate the partial product in the accumulator for an
addition or subtraction with the multiplicand, or just to shift. This process is clear, and no further description is necessary. However, let us consider the storing of the minor product in the ier register. When the partial product is negative, trouble arises, for what is effectively needed is the subtractive complement of those bits of the minor product formed in shifting a negative partial product (see Exercise $c$ ).

Table 16-2. Conditions Governing Addition or Subtraction of the Multiplicand to or from the Partial Product or Passing without an Operation $\dagger$

| Condition |  |  | Interpretation | Present operation to be performed |
| :---: | :---: | :---: | :---: | :---: |
| $P_{i+1}$ | $P_{i}$ | Last operation performed |  |  |
| 1 | 1 | Add | Initiating a string | Subtract |
| 0 | 0 | Subtract | Exiting a string | Add |
| 1 | 0 | Subtract | Within a string | Subtract |
| 0 | 1 |  | Outside a string | Add |
| All other conditions |  |  |  | Pass |

$\dagger$ Based on $P_{i+1}, P_{i}$ of the multiplier and a knowledge of the last operation performed (which reflects whether $P_{i}$ is in a string or not).

In a parallel computer an addition or subtraction takes only one unit time interval, and hence just the replacement of a shift for an addition or subtraction would not in itself save time. Thus, in order to take advantage of the rapid multiplication method in a parallel computer, the shift must be combined with the operation to be performed all in one unit time interval. For example, the computer may determine whether to add or subtract and then shift all the way to the bit where the next operation is to take place-during one unit time interval. As illustration, the arcs drawn below represent the processes completed during one unit time interval.


However, it is not always feasible to design a computer that can shift any number of positions all in one unit time interval, for to shift a word $n$ positions in one unit time interval means that direct connections must exist between each stage and all stages up to $n$ positions farther down the register. Thus the possible number of positions that can be shifted must be limited. J. L. Smith and A. Weinberger $\dagger$ have shown that a good choice for this limitation is to allow the shift register to shift one, two, three, or four stages. By "good" we mean that negligible additional savings in time would occur if shifts of five or more stages were allowed.
$\dagger$ Methods for High-speed Addition and Multiplication, NBS Circ. 591.


Fig. 16-7. Effectiveness of short-cut multiplication.
Figure 16-7 shows the effectiveness of short-cut multiplication as a function of the maximum number of stages allowed for a unit-time-interval shift.

We have seen above how the computer will decide when to add, subtract, or pass. The additional problem for parallel computers now is how far the computer should shift after the operation. As we have seen, there is good reason to allow the computer a choice of only one, two, three, or four positions. The first limitation on the number of positions is that, since the operation and the subsequent shift are to occur all in one unit time interval, the shift can only be up to the position where the next operation is required. If the next operation is required more than four positions away, then the shift is the maximum, or four positions; then, in the next unit time interval, the operation is passed, and the number of positions to shift recalculated and executed, etc. If the number of positions till the next operation is four, three, two, or one, then this is the number of positions to be shifted, of course. To determine the number of positions to be shifted after the operation is performed on $P_{i}$, the bits $P_{i+1}, P_{i+2}$, and $P_{i+3}$ must be sensed. It can be shown from Table 16-2 that Table 16-3 gives the shift conditions (see Exercise f).

## EXERCISES

(a) Design a circuit to determine whether to add, subtract, or pass during rapid multiplication (see Table 16-2). Suppose that only $P_{i+1}, P_{i}$, and the sign of the partial product are known; how can it be determined whether to add, subtract, or pass?
(b) Describe the functions and operation of the registers during rapid multiplication in a serial computer.
(c) Design the circuit that determines the proper bits of the minor product that are generated in serial operation when a negative partial product is shifted.

Table 16-3. Rules for Shifting

| $P_{i+3}$ | $P_{i+2}$ | $P_{i+1}$ | $\begin{gathered} P_{i} \\ \dagger \end{gathered}$ | Operation performed on $P_{i}$ (and past condition other than shift) | Action |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 0 | Pass (if last operation was add) | Shift 1 position |
|  |  | ${ }_{0}^{+}$ | 1 | Pass (if last operation was subtract) |  |
|  | 1 | $\dot{0}$ | $\stackrel{+}{1}$ | Add | Shift 2 positions |
|  | 0 | i | $\overline{0}$ | Subtract |  |
|  |  | $\dot{0}$ | $\pm$ | Add; pass (if last operation was add) |  |
|  |  | i | i | Subtract; pass (if last operation was subtract) |  |
| 1 | 0 | 0 | $\pm$ | Add | Shift 3 positions |
| 0 |  | i | $\overline{0}$ | Subtract |  |
| 1 | $\dot{0}$ | 0 | $\pm$ | Add; pass (if last operation was add) |  |
| 0 | 1 | i | $\bar{i}$ | Subtract; pass (if last operation was subtract) |  |
| 0 | 0 | $\dot{0}$ | $\pm$ | Add | Shift 4 positions |
| 1 | 1 | 1 | $\overline{0}$ | Subtract |  |
| 0 | $\dot{0}$ | $\dot{j}$ | $\pm$ | Add; pass (if last operation was add) |  |
| : | i | i | ; |  |  |
| 1 | 1 | 1 | 1 | Subtract; pass (if last operation was subtract) |  |

$\dagger$ The superscript plus or minus sign indicates the operation to be performed on $P_{i}$; the superscript dot indicates a shift.
(d) How are the rules of Table 16-2 to be interpreted when $i$ is the least significant bit of a word and when $i$ is the most significant bit of a word?
(e) Design a 12 -bit shift register that can shift ahead one, two, or three positions, respectively, within one unit time interval.
(f) Derive the rules given by Table 16-3.

## 16-5. Rapid Division

The Method. We shall first present the method of rapid division and then discuss why it works. The method takes advantage of sequences of
adjacent units that may occur in the quotient and generates them all at once. The flow chart of Fig. 16-8 summarizes the procedure, which ends when $i$ equals the number of bits in a word.

We shall assume that the binary point of the computer word is to the left and that for $N / D=Q, D>N, D$ is normalized (i.e., the most significant bit is a unit: $D=.1 \cdots$ ). The first step is to form

$$
N^{\prime}=N-D
$$

Since in this first step $N^{\prime}$ is negative, we follow the negative loop. If $N^{\prime}$ has $\alpha$ zeros to the right of the binary point, then $Q$ has at least $\alpha-1$ units to the right of the point. In this initial step, $Q_{i}=0$ for $i=0$ merely means that $Q<1$. Now we form $N^{\prime \prime}=N^{\prime}+D$ with our normalized $N^{\prime}$. If the result is negative, we can complete $Q_{\alpha}=0$ and place units for additional bits of $Q$. If the result is positive, we can complete $Q_{\alpha}=1$ and place zeros for additional bits of $Q$. The procedure continues in this way, differencing and normalizing each time, and determining $Q_{i}$ and $Q_{i+1}$ through $Q_{(i+\alpha)-1}$ at each step. For example, consider

| Dividend | $\begin{aligned} N & =.1001 \\ -D & =.11111\end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Divisor |  |  |  |  |  |
| $N^{\prime}$ | - $\times 00.11$ | 0000 | 1111 | 0100 | 0.1 ? |
|  | + $\quad .11$ | 0100 | 0000 | 0000 | $\downarrow$ |
| $N^{\prime \prime}$ | $\pm \quad x^{00}$ | 00.11 | 0000 | 1100 | .11000? |
|  | $-$ | . 11 | 0100 | 0000 | $\downarrow$ |
| $N^{\prime \prime \prime}$ | - | $\times 00$ | 00.11 | 0100 | .110000111? |
|  | $+$ |  | . 11 | 0100 | $\downarrow$ |
| $N^{(\text {iv) }}$ |  |  | . 00 | 0000 | . 11000011110 |

As a further example consider

| Dividend | $N=.1011$ | 0000 | 0101 | $Q$ quotient |
| :---: | :---: | :---: | :---: | :---: |
| Divisor | $-D=.1101$ | 0000 | 0000 |  |
| $N^{\prime}$ | $\times 000.1$ | 1111 | 1011 | 0.11 ? |
|  | + $\quad 1$ | 1010 | 0000 | $\downarrow$ |
| $N^{\prime \prime}$ | - $x^{0}$ | 0.101 | 1011 | .1101? |
|  | $+$ | . 110 | 1000 | $\downarrow$ |
| $N^{\prime \prime \prime}$ | + | $\times 000$ | . 1101 | . 1101100 ? |
|  | - |  | . 1101 | $\downarrow$ |
| $N^{(\text {(iv) }}$ | - |  | . 0000 | . 11011001000 |

Rapid Division in Computers. For a serial computer we again must have a shift register rather than a delay line for this rapid-division technique. The normalizing and differencing would occur in the same recirculation time. A circuit must sense the zeros of the result so as to form the proper bits of the quotient. For a parallel computer, again, as in rapid multiplication, the only way time can be saved is by shifting and adding or subtracting all in one unit time.


Fig. 16-8. Flow chart for rapid division.
Rationale of Rapid Division. Some preliminary observations will aid the subsequent discussion of rapid division. First note that
$2^{-\alpha}=. \stackrel{1}{0} \stackrel{2}{0} \cdots{ }_{0}^{\alpha} \stackrel{\alpha}{1} 00 \cdots \quad$ and $\quad 1-2^{-\alpha}=. \stackrel{1}{1} \stackrel{2}{1} \cdots 1 \stackrel{\alpha}{1} 00$
Next note that, if $(.1 \cdots) \times(X)=.00 \cdots{ }_{0}^{\alpha} \cdots$, then

$$
X=.00 \cdots 0\left\{\begin{array}{lll}
\stackrel{\alpha}{2} & \cdots \\
0 & 1 & \cdots \\
1 & \cdots
\end{array}\right.
$$

For example, if $(.1 \cdots) \times(X)=.00001 \cdots$, then

$$
\begin{array}{r}
.1 \cdots \\
\times \quad .0001 \cdots \\
\hline .00001 \cdots
\end{array}
$$

or else

$$
\begin{array}{r}
.1 \cdots \\
\times \quad .00001 \\
\hline .00001
\end{array}
$$

Next observe that
$1-\left(.00 \cdots 0{ }^{\alpha} \cdots\right.$ followed by at least one other unit in any place)

$$
=(.11 \cdots \cdots 1 \stackrel{\alpha}{0} \cdots \cdot)
$$

whereas
$1-\left(.00 \cdots{ }_{0}^{\alpha} \begin{array}{l}\alpha \\ 1\end{array} 0 \cdots\right.$ followed by all zeros)

$$
=\left(.11 \cdots \cdots 1 \begin{array}{lllll}
\alpha & 1 & 0 & 0 & \cdots
\end{array}\right)
$$

Our initial conditions are $N=D Q, D>N, 2 N>D, D=.1 \cdots$. The first step is to form $N^{\prime}=N-D=D(Q-1)$, where $N^{\prime}<0$. Suppose that $N^{\prime}=-. . \begin{array}{r}1 \\ 0\end{array}{ }_{0}^{2} \cdots{ }_{0}^{\alpha}{ }_{0}^{\alpha} 1 \cdots$; then we have

$$
\left.Q-1=-. \begin{array}{llll}
1 & 2 \\
0 & \cdots
\end{array}\right)\left\{\begin{array}{llll}
\alpha \\
0 & 1 & \cdots \\
1 & \cdots
\end{array}\right]
$$

whence $Q=. \begin{array}{ll}1 & 2 \\ 1\end{array} \cdots 1\left\{\begin{array}{l}\alpha \\ 0 \\ 1\end{array}+2^{-\alpha} Q^{\prime}\right.$, where $Q^{\prime}<1$. Thus we have determined the first $\alpha-1$ bits of $Q$.

Next form $N^{\prime \prime}=N^{\prime}+2^{-\alpha} D=D\left(Q-1+2^{-\alpha}\right)$, where $D>0$. Three cases may arise:

1. $N^{\prime \prime}=0$. Then $Q=1-2^{-\alpha}$, whence $Q=.11 \cdots 1 \stackrel{\alpha}{1}+2^{-\alpha} Q^{\prime}$, where clearly $Q^{\prime}$ is zero and the division is concluded.
2. $N^{\prime \prime}>0$. Then $Q>1-2^{-\alpha}$, or $Q>.11 \cdots{ }_{1}^{\alpha}$, whence

$$
Q=. . \begin{aligned}
& 1 \\
& 1
\end{aligned} \cdots 1 \stackrel{2}{1}+2^{-\alpha} Q^{\prime}
$$

Hence $Q-1+2^{-\alpha}=.11 \cdots 1 \stackrel{\alpha}{1}+2^{-\alpha} Q^{\prime}-1+2^{-\alpha}=2^{-\alpha} Q^{\prime}$ and $2^{\alpha} N^{\prime \prime}=D Q^{\prime}$. If $2^{\alpha} N^{\prime \prime}=\stackrel{1}{0}_{0}^{1} 0_{0}^{2} \cdots{ }_{0}^{\beta} 1 \cdots$, then
3. $N^{\prime \prime}<0$. Then $Q<1-2^{-\alpha}$, or $Q<0.1 \stackrel{1}{1} \cdots \stackrel{\alpha}{\alpha}$, whence

$$
Q=.11 \cdots{\stackrel{\alpha-1}{1} 0+2^{-\alpha} Q^{\prime}, ~}^{\prime}
$$

Hence

$$
\begin{aligned}
Q-1+2^{-\alpha} & =.11^{2} \cdot \frac{\alpha-1}{1} 0+2^{-\alpha} Q^{\prime}-1+2^{-\alpha} \\
& =1-2^{-(\alpha-1)}+2^{-\alpha} Q^{\prime}-1+2^{-\alpha} \\
& =2^{-\alpha}\left(1-2+Q^{\prime}\right)=2^{-\alpha}\left(Q^{\prime}-1\right)
\end{aligned}
$$

whence $2^{\alpha} N^{\prime \prime}=D\left(Q^{\prime}-1\right)$. If $2^{\alpha} N^{\prime \prime}=-.0_{0}^{2} \cdots \stackrel{.}{0-1}_{0}^{0} 1 \cdots$, then

$$
Q^{\prime}-1=-.0 \stackrel{1}{2}_{0}^{2} \cdots ._{0}^{\beta-1}\left\{\begin{array}{lll}
0 & 1 & \cdots \\
1 & \cdots
\end{array}\right.
$$

and

$$
Q^{\prime}=. \stackrel{1}{1}_{1}^{2} \ldots ._{1}^{\beta-1}\left\{\begin{array}{l}
0 \\
1
\end{array}+2^{-\beta} Q^{\prime \prime}\right.
$$

Thus we have now completely determined at least $\alpha+(\beta-1)$ positions of $Q$. Consider $N^{\prime \prime}>0$, and form

$$
N^{\prime \prime \prime}=N^{\prime \prime}-2^{-(\alpha+\beta)} D=2^{-\alpha} D\left(Q^{\prime}-2^{-\beta}\right)
$$

Three cases may arise:
4. $N^{\prime \prime \prime}=0$. Then $Q^{\prime}=2^{-\beta}=. \stackrel{1}{0}_{0}^{2} \cdots ._{0}^{\beta-1} 1+2^{-\beta} Q^{\prime \prime}$, where clearly $Q^{\prime \prime}$ is zero, and the division is concluded.
5. $N^{\prime \prime \prime}>0$. Then $Q_{2}^{\prime}>2^{-\beta}$, or $Q^{\prime}=+0.0 \stackrel{1}{0}_{0}^{2} \cdots 0{ }_{1}^{\beta}+2^{-\beta} Q^{\prime \prime}$. Hence, $Q^{\prime}-2^{-\beta}=.00 \cdots 01+2^{-\beta} Q^{\prime \prime}-2^{-\beta}=2^{-\beta} Q^{\prime \prime}$, and

$$
2^{\alpha+\beta} N^{\prime \prime \prime}=D Q^{\prime \prime}
$$

which is just like case 2 over again.
6. $N^{\prime \prime \prime}<0$. Then $Q^{\prime}<2^{-\beta}, Q^{\prime}=+.{ }_{0}^{1} \stackrel{2}{0}_{0} \cdots 0 \stackrel{\beta}{0}+2^{-\beta} Q^{\prime \prime}$. Hence
and

$$
\begin{gathered}
Q^{\prime}-2^{-\beta}=. \stackrel{1}{0} \stackrel{2}{0} \cdots 0^{\beta} 0_{0}^{\beta}+2^{-\beta} Q^{\prime \prime}-2^{-\beta}=2^{-\beta}\left(Q^{\prime \prime}-1\right) \\
2^{\alpha+\beta} N^{\prime \prime \prime}=D\left(Q^{\prime \prime}-1\right)
\end{gathered}
$$

which is just like case 3 over again. Thus for $N^{\prime \prime} \geq 0$ we have completely determined at least $\alpha+\beta+(\gamma-1)$ positions of $Q$, where $\gamma$ is the number of zeros beginning $N^{\prime \prime \prime}$; we have noted that case 4 refers to case 1 and case 6 refers to case 3 to complete the loops in these cases.

Consider $N^{\prime \prime}<0$, and form

$$
N^{\prime \prime \prime}=N^{\prime \prime}+2^{-(\alpha+\beta)} D=2^{-\alpha} D\left(Q^{\prime}-1+2^{-\beta}\right)
$$

Again three cases may arise, which are just like cases 1,2 , and 3 . This completes the rationale for our rapid-division method.

## EXERCISES

(a) Design a circuit that counts the zeros and generates the appropriate bits of the quotient during the rapid-division process.
(b) Describe in detail rapid division in serial and parallel computers.
(c) Construct an example where the rapid-division method presented in this example does not reduce the number of differences taken over that of the previous method given. Additional Topic $e$ (Sec. 16-7) shows how to overcome this slowness.

## 16-6. Floating Operations

Addition and Subtraction. As described in Chap. 4, a word in a floating-point computer is divided into a "mantissa" and an exponent. In performing summation the exponents of the two arguments must be the same. In order that the least amount of significance be lost, the best procedure is to normalize both arguments first (i.e., adjust the exponent and shift the mantissa so that the most significant bit is a unit) and then shift the mantissa of the argument with the smallest exponent to the right until its exponent is the same as the largest of the previously normalized exponents. For example, for a mantissa having 8 bits, consider $00001101 \times 2^{4}+01101000 \times 2^{-3}$. On normalizing, these become $11010000 \times 2^{0}+11010000 \times 2^{-4}$; adjusting the smallest exponent to equal the largest, we have

$$
11010000 \times 2^{0}+00001101 \times 2^{0}=11011101 \times 2^{0}
$$

as the sum. In the event that there is an overflow, the exponent of the result must be increased by 1 and the resulting mantissa shifted right one position so that the overflow digit assumes the most significant position. Note that with this operation the result will always be normalized automatically. If an unnormalized result is desired, it is understood by convention (see Chap. 4) that the exponent of the result is to be that of the largest exponent of the original arguments. Thus an additional right shift would be necessary until the appropriate exponent is reached. Differencing is performed in the same way, normalizing first and then subtracting.

The process of normalizing a number consists in shifting the number to the left until a unit appears in the most significant position. The number of positions shifted is recorded on a counter, and the final count is subtracted from the exponent.

Multiplication and Division. In floating-point multiplication there is no need to normalize the numbers first, although there is no harm in doing so (why?). The exponents that are to be attached to the unnormalized major and minor products depend on the location of the binary point in the mantissa part of the word. For example, suppose that the point is to the left; then we would have, say, for a 5 -bit mantissa:

|  | $.01010 \times 2^{a}$ |
| :---: | :---: |
|  | $.01101 \times 2^{b}$ |
|  | 01010 |
| 0 | 0000 |
| 01 | 010 |
| 010 | 10 |
| . 0000 | 0 |
| . 00100 | $00010 \times 2^{a+b}$ |
| Major | Minor |

Thus the major product would become $.00100 \times 2^{a+b}$, while the minor product would have to be written as $.00010 \times 2^{a+b-5}$. Hence the exponent of the major product is just the sum of the exponents of the arguments, while the exponent of the minor product is the sum of the exponents of the arguments minus the number of bits in the mantissa part of the word format. On the other hand suppose that the binary point was to the right; then we would find, for example,

$\underbrace{00100}_{\text {Major }} \underbrace{00010 . \times 2^{a+b}}_{\text {Minor }}$| $01010 . \times 2^{a}$ |
| :--- |
| $01101 . \times 2^{b}$ |

Here the major product becomes $00100 . \times 2^{a+b+5}$, while the minor product becomes 00010. $\times 2^{a+b}$ (see Exercise b). When normalized major or minor products are desired, the exponent of the respective product is adjusted accordingly. For example, in the former example, the normalized major product would be $.10000 \times 2^{a+b-2}$, and the normalized minor product would be $.10000 \times 2^{a+b-5-3}$.

Division, on the other hand, requires more analysis in order to obtain the maximum significance in the result. Suppose, for example, that the binary point of the mantissa is always understood to be at the left; i.e., all mantissas are less than 1. Now, to obtain the maximum significance, we desire the quotient to have a unit in the most significant position. This can be arranged as follows: First normalize both arguments; then compute $2 N-D$, which will be positive. $\dagger$ If $2 N-D<1$, proceed; if $2 N-D \geq 1$, shift $N$ to the right one position. Again compute $2 N-D$, which is positive $\ddagger$ and less than 1 . With $2 N-D>0$, $Q_{1}=1$, and the division then proceeds as usual. The exponents and $N$ and $D$ must be adjusted after each shift. The quotient has thus been automatically normalized. The adjusted exponents are subtracted.

The Exponent Unit. In order to facilitate handling the exponents, it is sometimes desirable to have a separate exponent unit in which the exponents can be added and subtracted. Since the normalization and other shifting operations require addition (or subtraction) of a count to an exponent, this process may be accomplished in the exponent unit also. The exponent unit should also be capable of sensing an exponent overflow or underflow, which may only occur during multiplication and division. It is probably wisest to have an error halt in this event, since if the computer tries to fix up the mantissas to avoid the overflow, they may be cleared or otherwise undesirably altered. Such overflows or underflows would indicate an error in coding in any event.
$\dagger$ Normalized, $1 / 2 \leq N<1$, and $1 / 2 \leq D<1$, or $-1<-D \leq-1 / 2$; thus $0<2 N-D<3 / 2$.
$\ddagger$ Shifted $N$ is $N / 2$; doubling gives $N$ again. Thus $-1 / 2<N-D<1 / 2$. But $2 N-D \geq 1$, or $N<1 / 2+D / 2$. Hence $N-D \geq 1 / 2+D / 2-D=1 / 2-D / 2$. But $-D>-1$; so $-D / 2>-1 / 2$. Therefore $N-D>0$.

## EXERCISES

(a) Design a parallel 4-bit exponent unit.
(b) Formulate a general rule for determining the exponent of the major product and the minor product for words of $w$ bits in the mantissa and with binary point $p$ positions from the right.
(c) How might significance be lost if in addition or subtraction the arguments were not normalized first? Give specific examples of each.
(d) How might significance be lost in division if $Q$ was not normalized as it was formed? Give examples.
(e) In unrounded addition and subtraction is it necessary to normalize the arguments first to ensure maximum significance?
( $f$ ) For unnormalized division could significance be lost by not first preparing $N$ and $D$ as described above? Give an example.
(g) In what common computing device are mantissas of the arguments of division prepared automatically as the division starts? Explain.
( $h$ ) Discuss the design of floating operations in a decimal-coded binary computer.

## 16-7. Additional Topics

a. Derive a formula giving the effectiveness of the rapid-multiplication scheme of Sec. 16-4 as summarized in Fig. 16-7. See, for example, J. L. Smith and A. Weinberger, Shortcut Multiplication for Binary Digital Computers, in NBS Circ. 591.
b. Design a 53 -bit parallel binary adder so that no single pulse need travel through more than 12 gates, under the limitations given in Sec. 16-2. See, for example, A. Weinberger and J. L. Smith, A Logic for High-speed Addition, in NBS Circ. 591 (see also their A One-microsecond Adder Using One-megacycle Circuitry, IRE Trans. on Electronic Computers, vol. EC-5, no. 2, pp. 65-72, June, 1956).
c. Design a 12 -bit parallel comparator.
d. Utilizing only or-not gates (that is, $A$ nor $B=\overline{A+B}$ ), design a 36 -bit parallel adder. Assume that each gate can drive at most six additional gates and that no gate can have more than six inputs (other than a clock pulse). (For notation see Sec. 18-2, Fig. 18-3.) Show that no pulse need travel through more than nine gates.
$e$. The method for rapid division given in Sec. 16-5 was developed by R. S. Ledley and J. B. Wilson. Modification of the techniques presented there is necessary if full advantage is to be taken of the possibilities of the method. To see this, work out
and

$$
.01100001000000001 \div .10000001=.110000001
$$

following the flow chart of Fig. 16-8 exactly.
Case 1. The first example above illustrates overshifting. Work the example again, but this time shift the arguments one place less before the second differencing. Observe that, if $D=.10 \cdots, N^{(i)}=.01 \cdots$ with $Q^{(i)}=.10 \cdots$ or $.11 \cdots$, for $N^{(i)}=Q^{(i)} D$. (Show this by multiplying maximum and minimum values.) The effect of this is that normalizing $N^{(i)}$ shifts it one place beyond the first bit of $Q^{(i)}$. If $Q^{(i)}=.10 \cdots$, this is desired (explain, considering the 1 as an isolated unit), but not if $Q^{(i)}=.11 \cdots$ Note, however, that if $2 / 3<Q^{(i)}<3 / 4$, the first 1 may be considered either as an isolated unit or as the first of a string of units with an isolated zero as the next bit (why?). Thus if it can be shown that $1 / 2 \leq Q^{(i)}<3 / 4$,
then $N^{(i)}$ should be normalized; if it can be shown that $2 / 3<Q^{(i)}<1$, then $N^{(i)}$ should be shifted one place less than to normalize; but if it can be shown that $2 / 3<$ $Q^{(i)}<1$, then either shift is permissible. With this in mind, show (by computing the maximum and minimum possible values for $Q^{(i)}$ in each case) that for $D=.10 \cdots$ the following rules apply:

Shift one place less than to normalize

1. If $D=.1000 \cdots$ and $N^{(i)}$ begins $11 \cdots$
2. If $D=.100 \cdots$ and $N^{(i)}$ begins $111 \cdots$
3. If $D=.10 థ 0 \cdots$ and $N^{(i)}$ begins $1111 \cdots$
4. If $D=.100 \cdots$ and $N^{(i)}$ begins $11 \$ 11 \cdots$ or If $D=.10010 \cdot \cdots$ and $N^{(i)}$ begins 11\$1ゅ . . .
Otherwise normalize
Case 2. The second example above illustrates undershifting. Work the example again, but this time shift the arguments one place more before each differencing. Note that, if $D=.11 \cdots$ and $N^{(i)}=.011 \cdots$, then $Q^{(i)}=.10 \cdots$; normalizing $N^{(i)}$ shifts beyond this first unit of $Q^{(i)}$, as is desired. If $D=.11 \cdots$ and $N^{(i)}=.11$ $\cdots$, then $Q^{(i)}=.11 \cdots$; normalizing $N^{(i)}$ shifts to the first unit of $Q^{(i)}$, as is desired. However, if $D=.11 \cdots$ and $N^{(i)}=.10 \cdots$, we desire to shift beyond the first unit of $Q^{(i)}$ whenever that unit is an isolated unit. Remembering that, if $2 / 3<Q^{(i)}<3 / 4$, the first unit of $Q^{(i)}$ may be considered isolated or not, as is convenient, show that the following rules apply for $D=.11 \cdots$ :

Shift one place more than to normalize

1. If $D=.11 \cdots$ and $N^{(i)}$ begins $1000 \cdots$
2. If $D=.111 \cdots$ and $N^{(i)}$ begins $100 \cdots$
3. If $D=.1111 \cdots$ and $N^{(i)}$ begins $10 ゅ 0$
4. If $D=.11 \Phi 11 \cdots$ and $N^{(i)}$ begins $100 \cdots$ or If $D=.11 \Phi 1 \Phi \cdot \cdots$ and $N^{(i)}$ begins $100 \Phi 0 \cdots \cdot$
Otherwise normalize
Show that the rules apply equally well for negative $N^{(i)}$, and hence for $Q^{(i)}$ beginning with a zero. (The above modifications of the rapid-division method are the work of J. B. Wilson.)

## f. References on Rapid Arithmetic Operations

Burtsev, V. S.: "Accelerating Multiplication and Division in High-speed Digital Computers," Institute of Exact Mechanics and Computing Technique, Academy of Science of USSR, Moscow, 1958.
Lehman, M.: High-speed Digital Multiplication, IRE T'rans. on Electronic Computers, vol. EC-6, no. 3, pp. 204-205, September, 1957.
Leiner, A. L., A. Weinberger, and J. L. Smith: System Design of Digital Computers at the National Bureau of Standards: Methods for High-speed Addition and Multiplication, NBS Circ. 591.
Nadler, M.: Division in Digital Computers by the Radix Method, Stroje na Zpracovani, Sbornik IV, pp. 79-100, Prague, 1956. (In Czechoslovakian.)
Reitwiesner, G. W.: Summary Discussion of Performing Binary Multiplication with the Fewest Possible Additions, BRL Tech. Note 113, Ballistic Research Laboratories, Aberdeen, Md., February, 1957.
Robertson, J. E.: A New Class of Digital Division Methods, IRE Trans. on Electronic Computers, vol. EC-7, no. 3, p. 218, September, 1958. (The method for rapid
division given in Sec. 16-5 can also be developed by extending Robertson's methods as applied to binary numbers.)
Tocker, K. D.: Techniques of Multiplication and Division for Automatic Binary Computers, Quart. J. Mech. Appl. Math., August, 1958, pp. 364-384.
Univ. Ill., Digital Computer Lab., Tech. Progr. Rept., October, 1956.
g. Arithmetic Units. Further information concerning arithmetic units may be found in the following references:

Gillies, D. B., R. E. Meagher, D. E. Muller, R. W. McKay, J. P. Nash, J. E. Robertson, and A. H. Taub: On the Design of a Very-high Speed Computer, Univ. Ill., Digital Computer Lab., Rept. 80, October, 1957.
Greenwald, S., R. D. Heuter, S. N. Alexander: SEAC, NBS Circ. 551, January, 1955.
Grisamore, N. T., L. S. Rotolo, and G. Uyehara: Logical Design Using the Stroke Function, IRE Trans. on Electronic Computers, vol. EC-7, no. 2, p. 181, June, 1958.

Leiner, A. L., W. A. Notz, J. L. Smith, and A. Weinberger: System Design of the SEAC and DYSEAC, IRE Trans. on Electronic Computers, vol. EC-3, no. 2, June, 1954.
Lubkin, S.: Decimal Location in Computing Machines, Math. Tables and Other Aids to Computation, vol. 3, pp. 44-50, 1948.
Phister, M., Jr.: "Logical Design of Digital Computers," John Wiley \& Sons, Inc., New York, 1958.
Richards, R. K.: "Arithmetic Operations in Digital Computers," D. Van Nostrand Company, Inc., Princeton, N.J., 1955.
Smith, C. V. L.: "Electronic Digital Computers," McGraw-Hill Book Company, Inc., New York, 1959.
Staff of Engineering Research Associates Inc.: "High-speed Computing Devices," McGraw-Hill Book Company, Inc., New York, 1950.
Staff of Harvard Computing Laboratory: "Synthesis of Electronic Computing and Control Circuits," Harvard University Press, Cambridge, Mass., 1951.

## GHAPTER 17

## CONTROL

## 17-1. Introduction

Orientation. In the previous two chapters we considered how arithmetic operations can be performed by a digital computer. Our discussions were limited solely to the examination of various gating configurations that can produce the sum of two arguments, the difference, the product, the quotient, and so forth. The present chapter is concerned with necessary control that enables a computer to perform those operations automatically, directed by a sequence of instructions.

There are two aspects to the control functions: arithmetic operation control and instruction sequencing control. The former is concerned with the arithmetic unit, which needs control signals to perform each of the various operations as directed by the instruction. Some of these signals are generated within the arithmetic unit itself as the operation is being performed; others are generated external to the arithmetic unit, in the so-called "operations signal generator." The instruction sequencing control is concerned with control signals that must be generated to direct the automatic execution and sequencing of instructions so that a complete program can be computed. The sequencing-control functions involve both the sequencing of the chain of instructions that constitute a program and the sequencing of phases during the execution of a single instruction.

Role of the Phases. . The design of control circuitry takes place in two steps. In the first, control signals are designed that enable the computer to perform all the necessary functions that take place within each phase; the second step is to design controls for properly sequencing the phases. Before proceeding with the present chapter, let us review the functions performed in each phase, as defined for each of the four-, three-, two-, and one-address systems. Of course the naming of the phases is arbitrary; the assignment of functions to the different stages is also arbitrary to a large extent. However, to be specific, we have given in Table 17-1 a summary of the conventions to be used in this text. The table illustrates the function assigned to each phase for "typical" instructions, based on the instruction definitions given in Chap. 3.

The functions to be distributed among the phases are of five kinds. First there is the function of determining the address of the next instruction. For the four-address system this is $\delta$ unless the instruction was a comparison, when it might be $\gamma$. For the three-, two-, and one-address

Table 17-1. Summary of the Functions Assigned to the Phases of the Four-, Three-, Two-, and One-address Systems Illustrated for "Typical" Instructions $\dagger$

|  | Phase 1 | Phase 2 | Phase 3 | Phase 4 |
| :---: | :---: | :---: | :---: | :---: |
| Four-address: Add. | Select $\alpha$; read ( $\alpha$ ) into accumulator | Select $\beta$; read ( $\beta$ ) into arithmetic unit, and perform operation | Select $\gamma ;$ put (acc) into $\gamma$ | Select $\delta$; read ( $\delta$ ) into instruction register; decode operation |
| Compare. | Select $\alpha$; $\operatorname{read}(\alpha)$ into accumulator | Select $\beta$; read $(\beta)$ into arithmetic unit, and perform operation; determine address of next instruction |  | Select next instruction from ( $\delta$ ) or ( $\gamma$ ); read it into instruction register; decode operation |
| Three-address: <br> Add......... | Select $\alpha$; read ( $\alpha$ ) into accumulator | Select $\beta$; read $(\beta)$ into arithmetic unit, and perform operation; update currentaddress counter | Select $\gamma ;$ put (acc) into $\gamma$ | Select next instruction; read it into instruction register; decode operation |
| Compare. | Select $\alpha$; $\operatorname{read}(\alpha)$ into accumulator | Select $\beta$; $\operatorname{read}(\beta)$ into arithmetic unit, and perform operation; determine address of next instruction |  | Select next instruction; read it into instruction register; decode operation |
| Two-address: Add. | Select $\alpha$; read ( $\alpha$ ) into accumulator | Select $\beta$; $\operatorname{read}(\beta)$ into arithmetic unit, and perform operation; update currentaddress counter |  | Select next instruction; read it into instruction register; decode operation |
| Compare. |  | Select $\alpha ; \operatorname{read}(\alpha)$ into arithmetic unit, and perform operation; determine address of next instruction |  | Select next instruction; read it into instruction register; decode operation |
| Transfer..... |  |  | Select $\alpha$; put (acc) into $\alpha$ | Select $\beta$; read ( $\beta$ ) into instruction register; decode operation |

Table 17-1. Summary of the Functions Assigned to the Phases of the
Four-, Three-, Two-, and One-address Systems Illustrated for "Typical" Instructions $\dagger$ (Continued)

|  | Phase 1 | Phase 2 | Phase 3 | Phase 4 |
| :---: | :---: | :---: | :---: | :---: |
| One-address: Add....... | Select instruction; read it into instruction register; decode operation; update currentaddress counter for next instruction | Select $\alpha$; read $(\alpha)$ into arithmetic unit, and perform operation |  |  |
| Jump.... | Select instruction; read it into instruction register; decode operation; determine address of next instruction |  |  |  |
| Transfer. | Select instruction; read it into instruction register; decode operation; update currentaddress counter for next instruction |  | Select $\alpha$; put (acc) into $\alpha$ |  |

$\dagger$ Note that in the one-address system phase 1 really corresponds to what is called phase 4 in the four-, three-, and two-address systems.
systems this address depends on the operation: for all operations other than compare or jump, the address of the next instruction is obtained simply by adding 1 to the current-address counter, i.e., updating the current-address counter. On the other hand, for a jump or compare instruction in three-address, depending on the outcome of the operation, the address of the next instruction can be $\gamma$; for two-address it can be $\beta$; for one-address it can be $\alpha$. Second there is the function of the selection of an address. Having determined an address, the computer must locate this address in the memory. The address selected may be the address of an argument, such as $\alpha$ or $\beta$; or it may be the address into which a word is to be transferred; or it may be the address of the next instruction. Third there is the function of actually transferring a word between the
memory and the computing unit, e.g., reading the contents of the selected address into the computing unit, or writing the contents of the accumulator into the selected address. Fourth is the operation decoding function; and fifth is the performance of the operation.

In the four-, three-, and two-address systems the functions are generally assigned to the phases so that phase 1 is concerned with reading the first argument into the arithmetic unit; phase 3 is concerned with writing a word out of the arithmetic unit; phase 2 is concerned with reading the second argument from the memory into the arithmetic unit, performing the operation, and subsequently determining the address of the next instruction; and phase 4 is concerned with the next instruction and decoding its operation. In the one-address system phase 1 never occurs in the sense just mentioned. On the other hand, since the naming of the phases is arbitrary, what corresponds to phase 4 in a multiaddress system is usually called phase 1 for a one-address system; phases 2 and 3 still keep their general characterization.

The one-address system also presents another peculiarity. Since phase 2 does not always occur, it is necessary to relegate the determination of the address of the next instruction to phase 1. However, since the negative jump instruction does not require an operation, the determination of the address of the next instruction can occur immediately following the decoding of the operation. This means that, for a negative jump instruction, the address of the next instruction is prepared even before the operation of the present instruction is performed.
It will be of use to recall that transferring a word between the computing unit and the memory consumes one minor cycle. Only phase 2, wherein operations are performed, may take more than one minor cycle. $\dagger$

Outline of This Chapter. Before considering the specific problems associated with control we first consider a type of logical gating structure that occurs frequently in control gating, namely, the decoding circuit (Sec. 17-2). Second, consideration is given to the various functions that control circuits must perform within the phases. The method of teaching is through illustration. The illustrations are chosen from the Pedagac design, which has a one-address format. It is felt that the general characteristics and problems involved in control-circuit design can best be obtained by examining in detail a few specific but typical examples (Secs. 17-3 to 17-5). The discussion of the functions that occur within the phases ends with the consideration of memory-selection techniques (Sec. 17-6). Next the sequencing control of the phases themselves is considered (Sec. 17-7). Finally the problems involved in designing the counters and timing generating signals are considered.

## EXERCISES

(a) In Table $17-1$ what is the difference between the three- and four-address system with regard to the functions of the phases?
$\dagger$ An exception to the rule occurs in the Pedagac, whose shift instruction takes two minor cycles in phase 3.
(b) Why does the compare operation have no phase 3 ?
(c) Could the decoding of the operation be accomplished as well in phase 1 in the four-address system? In the three-address system? In the two-address system?
(d) In the two-address system why is there no phase 1 or 3 for the comparison instruction? Why is there no phase 1 or 2 for the transfer instruction?

## 17-2. The Decoding Circuit $\dagger$

Decoding Circuits. A decoding circuit has $n$ independent input wires $A_{1}, A_{2}, \ldots, A_{n}$ and $2^{n}$ output wires; each output corresponds to one of the $2^{n}$ possible elementary products (see Sec. 11-3) of $A_{1}, A_{2}, \ldots, A_{n}$.


Fig. 17-1. The simplest nontrivial decoding circuit.
For example, the simplest nontrivial decoding circuit has 2 input wires and $2^{2}=4$ output wires as shown in Fig. 17-1. In general partial decoding circuits are used, where not all the $2^{n}$ possible outputs are actually produced. However, for the purposes of this section we shall assume throughout that all $2^{n}$ outputs always appear. Note that, by definition, the outputs of a decoding circuit are mutually exclusive, i.e., only one at a time can have a unit voltage.

When a decoding circuit has more than two inputs, it can be constructed with more than one stage, as shown, for example, in Fig. 17-2, where four inputs are used. As is clear from the figure, the number of gates used is greater when the gating is accomplished in more than one stage. However, the total number of inputs to any gate is less when more than one stage is used. In Fig. 17-2 the one-stage circuit requires $4 \times 2^{4}=64$ inputs, whereas the other circuit requires only

$$
2 \times 2^{2}+2 \times 2^{2}+2 \times 2^{4}=48 \text { inputs }
$$

In this respect two situations can occur: the amount of electronic hardware needed to construct a circuit may be measured primarily by the number of gates or, on the other hand, by the number of gate inputs. In the former situation it is clearly more efficient to perform the decoding function all in one stage, while the reverse is true for the latter situation.

Diode Decoding Matrices. To see how this latter situation arises, consider diode gates, as discussed in Sec. 10-10. In Fig. 17-3 the top diagram
$\dagger$ This section is based on private communications with Chester Page of the National Bureau of Standards.
represents the circuit of Fig. 17-1 redrawn in terms of diode gates. It is easily seen that the positions of the diodes can be rearranged as in the bottom diagram of Fig. 17-3. In this arrangement the diodes are called diode jumpers, and such a circuit is called a diode decoding matrix. It is often found very convenient to place diodes at the crossings of the pairs


Fig. 17-2. Two ways of constructing a decoding circuit with four inputs $A_{1}, A_{2}, A_{3}$, and $A_{4}$. In our notation the top circuit is represented by $\left\{A_{1} A_{2} A_{3} A_{4}\right\}$, and the bottom circuit is represented by $\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\}$.
of wires, and such diode matrices are used extensively. In diode matrices it is often important to reduce to a minimum the number of diodes used, which corresponds to reducing the number of inputs to the gates to a minimum.

Computing the Number of Inputs to the Gates. The problem therefore arises as to what configuration of stages will result in the most efficient decoding circuit from the point of view of minimizing the total number of inputs to the gates. In order to facilitate this discussion, let us introduce some special notation. Let $\left\{A_{1} A_{2} \cdots A_{n}\right\}$ represent a circuit with $n$ inputs $A_{1}, A_{2}, \ldots, A_{n}$ and as many outputs as there are possible input states. The outputs are mutually exclusive, each having a


Frg. 17-3. The top diagram shows the use of diode gating in the circuit of Fig. 17-1. The bottom diagram shows the same circuit redrawn as a "jump" diode decoding matrix. (The crossed wires are not connected.)


Fig. 17-4. Circuit corresponding to the expression $\left\{R_{1} R_{2} R_{3} R_{4} S_{1} S_{2} S_{3} S_{4}\right\}$, wherein only one at a time of the $R_{i}$ and only one at a time of the $S_{i}$ can have a unit signal voltage.
unit signal voltage for only one corresponding input state. For example, if $A_{1}, A_{2}, \ldots, A_{n}$ are independent, then $\left\{A_{1} A_{2} \cdots A_{n}\right\}$ represents a one-stage decoding circuit, with $2^{n}$ outputs. As another example, if $R_{1}, R_{2}, R_{3}, R_{4}$ are mutually exclusive and $S_{1}, S_{2}, S_{3}, S_{4}$ are also mutually exclusive, then $\left\{R_{1} R_{2} R_{3} R_{4} S_{1} S_{2} S_{3} S_{4}\right\}$ will have $4 \times 4=16$ outputs (see Fig. 17-4).

Expressions with multiple braces are interpreted as circuits formed by stages "from inside out," similar to the use of parentheses in ordinary
algebra. For example, observe that the circuit $\left\{A_{1} A_{2}\right\}$ (that is, the circuit of Fig. 17-1) and the circuit $\left\{A_{3} A_{4}\right\}$ each have four mutually exclusive outputs. Then the expression $\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\}$ represents a circuit similar to that of Fig. 17-4, but where $R_{1} R_{2} R_{3} R_{4}$ and $S_{1} S_{2} S_{3} S_{4}$ are replaced by the mutually exclusive outputs of $\left\{A_{1} A_{2}\right\}$ and $\left\{A_{3} A_{4}\right\}$. This is just the lower circuit of Fig. 17-2. Similarly the multiple-braced expression $\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}$ represents the circuit of Fig. 17-5. More complicated multiple-braced expressions can similarly be unambiguously interpreted as decoding circuits.


Fig. 17-5. The circuit corresponding to the expression $\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}$.
Now observe that the number of gates and hence the number of inputs to the gates can be easily calculated from the braced expression of a decoding circuit. For example, $\left\{A_{1} A_{2} \cdots A_{n}\right\}$ clearly has $2^{n}$ gates and $n \times 2^{n}$ inputs to the gates (see Fig. 17-1 for $n=2$ and Fig. 17-2 for $n=4$ ). The circuit $\left\{R_{1} R_{2} \cdots R_{p} S_{1} S_{2} \cdots S_{q}\right\}$, where $R_{i}$ and $S_{i}$ are mutually exclusive within themselves, has $p q$ gates and $2 p q$ inputs to the gates (see Fig. 17-4 for $p=4, q=4$ ). For an expression with two levels of multiple bracing the number of gates in the last stage (and hence the number of mutually exclusive final outputs of the circuit) is given by
(Product of no. of mutually exclusive outputs

$$
\text { of each of } 1 \text { st-stage braced expressions) } \times 2^{\text {(no. of unbraced terms) }}
$$

For example, the number of gates in the last stage of $\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\}$ is $2^{2} \times 2^{2} \times 2^{0}=16$ (see Fig. 17-4) and of $\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}$ is $2^{2} \times 2^{1}=8$ (see Fig. 17-5); for the more complicated case $\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5}\right\} A_{6} A_{7} A_{8}\right\}$ we have $2^{3} \times 2^{2} \times 2^{3}=256$. We can now compute the number of inputs to the gates of the last stage as
(No. of 1 st-stage braced expressions + no. of unbraced terms)

$$
\times \text { (no. of gates in last stage })
$$

For example, for $\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\}$ the number of inputs to the gates in the last stage is $2 \times 16=32$, for $\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}$ we have $2 \times 8=16$, and for $\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5}\right\} A_{6} A_{7} A_{8}\right\}$ we have $5 \times 256=1,280$.

Of course for the entire circuit of a multiply braced expression the number of gates is the sum of the number of gates of each stage, and the number of inputs to the gates is the sum of the numbers for each stage. For more than two levels of bracing the process is continued in the same manner. Thus for $\left\{\left\{A_{1} A_{2}\right\}\left\{A_{1} A_{2}\right\}\right\}$ we find a total of

$$
2^{2}+2^{2}+2^{2} \times 2^{2}=24 \text { gates }
$$

and $\quad 2 \times 2^{2}+2 \times 2^{2}+2 \times 2^{2} \times 2^{2}=48$ inputs to the gates
For $\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}$ we find a total of

$$
2^{2}+2^{2} \times 2^{1}=12 \text { gates }
$$

and $\quad 2 \times 2^{2}+2 \times 2^{2} \times 2^{1}=24$ inputs to the gates
For the expression $\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5}\right\} A_{6} A_{7} A_{8}\right\}$ we have

$$
2^{3}+2^{2}+2^{3} \times 2^{2} \times 2^{3}=268 \text { gates }
$$

and $3 \times 2^{3}+2 \times 2^{2}+5 \times 2^{3} \times 2^{2} \times 2^{3}=1,312$ inputs to the gates
For a more complicated example including more than two levels of bracing consider the total number of inputs to the gates of the following expression (a more detailed discussion of brace or parenthesis interpretation can be found in Sec. 5-8) :

whence $2 \times 2^{2}+2 \times 2^{2}+2 \times 2^{2} \times 2^{2}+3 \times 2^{3}+2 \times 2^{2} \times 2^{2} \times 2^{3}$ $=328$ inputs to the gates are needed.

Minimizing the Number of Inputs to the Gates. We are now ready to give a general rule of thumb that will enable the design of a decoding circuit with a minimum number of inputs to the gates. The rule is as follows: Start with a single braced expression that contains all the input wires: $\left\{A_{1} A_{2} \cdots A_{n}\right\}$. Introduce another level of bracing that separates the input wires as closely as possible in half, thus:

$$
\left\{\left\{A_{1} A_{2} \cdots A_{n / 2}\right\}\left\{A_{n / 2+1} A_{n / 2+2} \cdots A_{n}\right\}\right\}
$$

if $n$ is even; on the other hand if $n$ is odd, then one of the two braces will have an extra wire. Continue the same process on each brace, until there remain only braces with either two or three wires. The reason it does not pay to break up a three-wire brace is that the number of
inputs to the gates for $\left\{A_{1} A_{2} A_{3}\right\}$ is the same as for $\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}$, that is, $3 \times 2^{3}=2 \times 2^{2}+2 \times 2^{2} \times 2^{1}=24$.

As an example, consider five input wires $A_{1}, A_{2}, A_{3}, A_{4}$, and $A_{5}$. The minimum decoding circuit is $\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5}\right\}\right\}$ according to the above rule, and has $3 \times 2^{3}+2 \times 2^{2}+2 \times 2^{3} \times 2^{2}=96$ inputs to the gates. For six inputs we have $\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5} A_{6}\right\}\right\}$, which has

$$
3 \times 2^{3}+3 \times 2^{3}+2 \times 2^{3} \times 2^{3}=176 \text { inputs to the gates }
$$

For seven input wires we have $\left\{\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\}\left\{A_{5} A_{6} A_{7}\right\}\right\}$, which requires 328 inputs to the gates, as was computed above. It is instructive to display all the possible decoding circuits for five input wires. This is done in Table 17-2. The proof of our rule of thumb is beyond the scope of this text.

Table 17-2. All Possible (Essentially Different) Decoding Circuits with Five Input Wires

## Circuit expressions

$\left\{A_{1} A_{2} A_{3} A_{4} A_{5}\right\}$
$\left\{\left\{A_{1} A_{2} A_{3} A_{4}\right\} A_{5}\right\}$
$\left\{\left\{A_{1} A_{2} A_{3}\right\} A_{4} A_{5}\right\}$
$\left\{\left\{A_{1} A_{2}\right\} A_{3} A_{4} A_{5}\right\}$
$\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\} A_{5}\right\}$
$\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5}\right\}\right\}$
$\left\{\left\{\left\{A_{1} A_{2} A_{3}\right\} A_{4}\right\} A_{5}\right\}$
$\left\{\left\{\left\{A_{1} A_{2}\right\} A_{3} A_{4}\right\} A_{5}\right\}$
$\left\{\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\} A_{4} A_{5}\right\}$
$\left\{\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}\left\{A_{4} A_{5}\right\}\right\}$
$\left\{\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\} A_{5}\right\}$
$\left\{\left\{\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\} A_{4}\right\} A_{5}\right\}$

## Total number of inputs to the gates

| $5 \times 2^{5}$ | $=160$ |
| :--- | :--- |
| $4 \times 2^{4}+2 \times 2^{5}$ | $=128$ |
| $3 \times 2^{3}+3 \times 2^{5}$ | $=120$ |
| $2 \times 2^{2}+4 \times 2^{5}$ | $=136$ |
| $2 \times 2^{2}+2 \times 2^{2}+3 \times 2^{5}$ | $=112$ |
| $3 \times 2^{3}+2 \times 2^{2}+2 \times 2^{5}$ | $=96$ |
| $3 \times 2^{3}+2 \times 2^{4}+2 \times 2^{5}$ | $=120$ |
| $2 \times 2^{2}+3 \times 2^{4}+2 \times 2^{5}$ | $=120$ |
| $2 \times 2^{2}+2 \times 2^{3}+3 \times 2^{5}$ | $=120$ |
| $2 \times 2^{2}+2 \times 2^{3}+2 \times 2^{2}+2 \times 2^{5}=96$ |  |
| $2 \times 2^{2}+2 \times 2^{2}+2 \times 2^{4}+2 \times 2^{5}=112$ |  |
| $2 \times 2^{2}+2 \times 2^{3}+2 \times 2^{4}+2 \times 2^{5}=120$ |  |

## EXERCISES

(a) Draw the gating circuit for $\left\{\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\} A_{5}\right\}$.
(b) Draw the diode decoding matrix corresponding to $\left\{\left\{\left\{A_{1} A_{2}\right\}\left\{A_{3} A_{4}\right\}\right\} A_{5}\right\}$.
(c) Form all possible essentially different braced expressions for a decoding circuit with four input wires, and find the number of inputs to the gates of each.
(d) Why do the expressions $\left\{\left\{A_{1} A_{2} A_{3}\right\}\left\{A_{4} A_{5}\right\}\right\}$ and $\left\{\left\{\left\{A_{1} A_{2}\right\} A_{3}\right\}\left\{A_{4} A_{5}\right\}\right\}$ both have 96 inputs to the gates (see Table 17-2)?
(e) For a decoding circuit with six input wires form the braced expression that will minimize the number of inputs to the gates, and determine what this minimum number is.
(f) For a decoding circuit with nine input wires form the braced expression that will minimize the number of diodes necessary in the diode matrix decoding circuit, and determine how many diodes are required.
(g) List all possible (essentially different) braced expressions for a decoding circuit with seven input wires, and determine the total number of inputs to the gates for each expression.
(h) Every decoding circuit has associated with it an encoding circuit which when attached to the decoding circuit will yield the original inputs. Find the encoding circuit associated with the decoding circuit of Fig. 17-1. [Hint: Solve the equation $B_{0}=\bar{A}_{1} \cdot \bar{A}_{2}, B_{1}=A_{1} \cdot \bar{A}_{2}, B_{2}=\bar{A}_{1} \cdot A_{2}$, and $B_{3}=A_{1} \cdot A_{2}$ for $A_{1}=f_{1}\left(B_{0}, B_{1}, B_{2}, B_{3}\right)$ and $A_{2}=f_{2}\left(B_{0}, B_{1}, B_{2}, B_{3}\right)$.]

## 17-3. Arithmetic Control: Instruction Decoder and Operations Signal Generator

Instruction Decoder. Control of an arithmetic operation starts in the instruction decoder, where the operation is decoded. The bits stored in the operation positions of the instruction register are the inputs for the

Instruction register


Fig. 17-6. Arithmetic control.
decoder, and the decoder has one output for each operation that can be performed by the computer. In the previous section we have discussed aspects of the design of such decoding circuits. The outputs of the instruction decoder are the inputs to the operations signal generator. Here the control signals necessary for each arithmetic operation are generated. These control signals then become inputs to the circuits of the arithmetic unit, together with the arguments of the operation (see Fig. 17-6).

The word detail characterizes the essential nature of most control circuits. Their design depends on the circumstances of the computer characteristics and of the particular function to be controlled. The instruction decoder and operations signal generator are no exceptions to the generalization. Therefore it is felt that the nature of the fundamental problems involved can best be described in terms of a specific example of a particular control circuit. We choose for our illustration the control of certain arithmetic operations of the Pedagac (see Chap. 9).

The operations (and their codes) under consideration will be: addition (53), subtraction (54), major multiplication (42), minor multiplication (32), division (41), and circular shift (70).

Starting with the instruction decoder, recall that the leftmost 6 bits represent the operation of the instruction word. Calling these $\omega_{6}, \omega_{5}$, $\omega_{4}, \omega_{3}, \omega_{2}$, and $\omega_{1}$, respectively, a possible decoder appears in Fig. 17-7. The method used is to decode each octal position separately and then to

Instruction register


Fig. 17-7. Example of an instruction decoder.
combine the proper octal digits to form the operation signal wire output, labeled with the respective operation code followed by the letter $D$.

The Operations Signal Generator. Continuing with our illustration, these six operation signals become inputs to the operations signal generator. Here they are gated with each other and with unit-time-interval pulses and with minor-cycle pulses to form the control signals that control the operations under consideration. The gating performed on the input signals in the operations signal generator varies in complexity from no gating at all to extensive gating combinations. The simplest of the signals in our illustration is the shift signal, called SHS, which is on whenever the shift instruction is called for, that is, $[\mathrm{SHS}]=[70 D] \dagger$; thus no gating is necessary. Another simply generated control signal is required whenever major or minor multiplication is called for; let this be called the multiplication decode signal MDS; thus, $[\mathrm{MDS}]=[42 D]+[32 D]$. A similar signal is on whenever multiplication or division is on, namely, $[\mathrm{PQS}]=[42 D]+[41 D]+[32 D]$ (see Fig. 17-8).
$\dagger$ The brackets on the multiletter symbols are for clarity; they have no intrinsic meaning.

A more complicated type of control signal often generated is exemplified in the division control signal, called DCS. This signal is on during the computational part of the division process. Since there are 18 bits (plus a sign) in the word under consideration, it takes 18 minor cycles to form the quotient. On the other hand the computation proceeds only during $T_{1}$ through $T_{18}$ of each minor cycle, even though the minor cycle is 23 unit time intervals in length. Thus we desire DCS to be off during $T_{0}$ and $T_{19-22}$ of each of the 18 minor cycles. The one-address division instruction actually takes 19 minor cycles, the 19 th minor cycle being


Fig. 17-8. Part of control signal generator.
utilized to transfer the quotient from the ier register where it was formed to the accumulator where the result is to be found. However, we do not want DCS to be on during this 19 th minor cycle when no actual computing is done. Hence we have

$$
[\mathrm{DCS}]=\left[\overline{T^{19}}\right] \cdot\left[T_{1}\right] \cdot[41 D]+\left[\bar{T}_{19}\right] \cdot[\mathrm{DCS}]_{d}
$$

where $[\mathrm{DCS}]_{d}$ represents the recirculation of [DCS]. The left-hand product loads the circuit at $T_{1}$ of every minor cycle except $T^{19}$ during the divide instruction (41); the right-hand product keeps this signal on from $T_{1}$ through $T_{18}$ and turns it off at $T_{19}$. We have here of course a dynamic flip-flop (see Fig. 17-8).

A signal similar in nature to DCS is the multiply control signal MCS. This signal is to be on during the computational part of major or minor multiplication, i.e., from $T_{1}$ through $T_{18}$ of minor cycle $T^{1}$ through $T^{18}$. Thus we have

$$
[\mathrm{MCS}]=\left[\overline{T^{19}}\right] \cdot\left[T_{1}\right] \cdot[32 D]+\left[\overline{T^{19}}\right] \cdot\left[T_{1}\right] \cdot[42 D]+\left[\bar{T}_{19}\right] \cdot\left[\mathrm{MCS}_{d}\right.
$$

The product-quotient transfer signal PQT controls the transfer of the quotient or the minor product from the ier register to the accumulator
during $T_{1-18}$ of the 19th minor cycle, thus:

$$
[\mathrm{PQT}]=\left[T^{19}\right] \cdot\left[T_{1}\right] \cdot[32 D]+\left[T^{19}\right] \cdot\left[T_{1}\right] \cdot[41 D]+\left[\bar{T}_{19}\right] \cdot[\mathrm{PQT}]_{d}
$$

For major multiplication the 19th minor cycle is used only to shift the accumulator to the right one position, i.e., at $T_{0}{ }^{19}$, to transfer the most significant bit of the minor product which remains in the accumulator at the end of the 18th minor cycle. Hence for major multiplication a signal is needed that inhibits the accumulator from shifting after $T_{0}$ of the 19th minor cycle, called the major multiplication inhibit signal, MMI; whence $[\mathrm{MMI}]=\left[T^{19}\right] \cdot[42 D]$ (see also Fig. 17-8), which will later be inhibited by $T_{0}$.

One of the most complicated operation control signals generated is the shift control signal. Here the number of positions to be shifted is found in the $\alpha$ address of the instruction. In order to control the number of positions to be shifted, a "count-down" is made from $\alpha$ each time the accumulator is shifted; when the count reaches zero, a signal is generated that inhibits any further shifting of the accumulator. This inhibiting signal is called SCC (see Exercise b).

Initial Clearing of the Recirculation Loops. When a recirculation loop, or flip-flop, is to be used, the loop must be cleared to ensure that initially there is no bit recirculating in it. This can be accomplished in a manner similar to the clearing of a shift-register stage when it is being loaded, by gating the loading with a $T_{i}$ signal and at the same time inhibiting any recirculation with a $\bar{T}_{i}$ signal. Often the clearing of a recirculation loop takes care of itself; i.e., it becomes cleared automatically because of the particular nature of the recirculation gates.

## EXERCISES

(a) How are the dynamic flip-flops for the signals DCS, MCS, and PQT initially cleared? (Hint: Remember the sequencing of instructions.)
(b) Design a count-down circuit that starts with 5 bits, $\alpha 5, \alpha 4, \alpha 3, \alpha 2, \alpha 1$, for the shift control signal for an 18 -bit word. Note that the initial count $\alpha$ can never be greater than 18, the maximum number of positions that can be shifted. Thus a constraint appears which can introduce significant simplifications. Assume that the count-down starts at $T_{5}$ (that is, since the length of the accumulator is 22 stages and the word length 18 bits, we have $22-18+1=5$ ). Hence at $T_{5}$ "load" each stage of the count-down circuit with $\alpha i$, as the initial count. The circuit should then reduce the count by one each unit time interval. Call the count at any time $A_{5} A_{4} A_{3} A_{2} A_{1}$; then SCC, which is to come on when the count reaches zero, becomes SCC $=\bar{A}_{5} \cdot \bar{A}_{4} \cdot \bar{A}_{3} \cdot \bar{A}_{2} \cdot \bar{A}_{1}$. However, then SCC must remain on until the end of the minor cycle, whence $\operatorname{SCC}=\bar{A}_{5} \cdot \bar{A}_{4} \cdot \bar{A}_{3} \cdot \bar{A}_{2} \cdot \bar{A}_{1}+\left[\bar{T}_{0}\right] \cdot[\mathrm{SCC}]_{d}$. One further remark must be made: The recirculation loops of the count-down circuit and of SCC must be cleared at $T_{5}$ to ensure that no miscellaneous pulses have preloaded the loops. Thus we have $\operatorname{SCC}=\bar{A}_{5} \cdot \bar{A}_{4} \cdot \bar{A}_{3} \cdot \bar{A}_{2} \cdot \bar{A}_{1}+\left[\bar{T}_{5}\right] \cdot\left[\bar{T}_{0}\right] \cdot[\mathrm{SCC}]_{d}$. For the recirculation loops the "loading" gate is $[\alpha i] \cdot\left[T_{5}\right]$, while each recirculation gate must have a $\bar{T}_{5}$ in its and gates.
(c) Design a signal generator that will present an output for multiplication or division during $T_{1}$ through $T_{18}$ of each minor cycle $T^{11}$ through $T^{18}$.

## 17-4. Arithmetic Control: Internally Generated Signals and Register Control

Internally Generated Signals. Some of the control signals used in the arithmetic unit are generated there during the execution of the operation. For example, as we have seen in Chap. 15, whether the adder-subtractor will form the sum or difference depends on a signal generated in the arithmetic unit from the signs of $A$ and $B$ and the operation signals for add or subtract. Also used to control processes within the arithmetic unit are the carry of the adder-subtractor, the overflow signal (which indicates that the subtractive complement of a number has been produced), the signal indicating that a result is zero (i.e., the zero signal), the multiply control signal (which controls whether or not the contents of the icand register or zero is to be added to the partial sum), and so forth, all generated within the arithmetic unit. The sign of the result may be considered as an internally generated signal; in a one-address system this sign will control a negative jump instruction.

As a specific example, consider the multiply control signal that determines whether to add zero or the multiplicand to the partial product. In the Pedagac this signal is called MUS. Because the Pedagac is a one-address computer, during the first minor cycle of a multiplication operation the multiplier is the recirculating contents of the accumulator, denoted by $B$. However, during this first minor cycle, $B$ is also transferred to the ier register, and hence, during all minor cycles except the first, the multiplier is the contents of the multiplier register. Thus the first bit of the multiplier, sensed at $T_{1}{ }^{1}$, appears as the least significant bit of $B$, whereas the $i$ th bit of the multiplier, sensed at $T_{1}{ }^{i}$ (that is, $T_{1}$ of the $i$ th minor cycle), appears as the end bit of the (ier). If the bit of the multiplier sensed at $T_{1}{ }^{i}$ is a unit, then signal MUS remains on for the rest of that minor cycle, opening the gate for the multiplicand to be added to the partial product; if the multiplier bit is a zero, then MUS remains off for the rest of that minor cycle. Hence we have for MUS

$$
\begin{aligned}
{[\mathrm{MUS}]=} & {[B] \cdot\left[T^{1}\right] \cdot\left[T_{1}\right] \cdot[\mathrm{MDS}] \cdot[F 2] } \\
& +\left[\bar{T}^{1}\right] \cdot\left[T_{1}\right] \cdot(\mathrm{IER}) \cdot[\mathrm{MDS}] \cdot\left[F^{2}\right] \\
& +\left[\bar{T}_{0}\right] \cdot\left[\mathrm{MUS}_{d} \cdot[F 2]\right.
\end{aligned}
$$

The MDS signal is used to generate MUS during a multiplication instruction. The least significant bit of the ier register that keeps MUS on (or off) during a complete minor cycle is cleared at $T_{0}$ of every minor cycle so that a new control bit can be presented at $T_{1}$.

Register Shift Control. The shift registers of the arithmetic unit, such as the accumulator, icand, and ier registers, need two types of control, which are generated within the arithmetic unit. First there must be a control that shifts the register as required, called the register shift control; second, there must be control of the input to the register, called the register input control.

Continuing with our example started in Sec. 17-3, consider the accumulator shift control. Let us analyze all the circumstances under which the accumulator should be shifted. For addition, multiplication, and division (phase 2 operations) the accumulator should be shifted each unit time interval of a minor cycle, except at each $T_{0}$ when the signs of the arguments are sensed. Observe that for multiplication, but not division, the accumulator must be shifted at $T_{0}$ for minor cycles $T^{2-19}$, because at $T_{0}{ }^{i+1}$ the $i$ th bit of the minor product is transferred to the ier register. During the 19th minor cycle the shifting is continued throughout $T_{1-22}^{19}$ for division and minor multiplication but not major multiplication, as observed in Sec. 17-3.

The shift instruction (a phase 3 operation) takes two minor cycles in the Pedagac. In the first minor cycle, (acc) is just recirculated through the output subtractive complementer; during the second minor cycle the shifting takes place. In this way the shifted result will always be complemented whenever necessary. For the shift instruction the accumulator should be shifted during $T_{1-22}^{1}$, and during the second minor cycle it should be shifted from $T_{5}$ until the count is zero.
We have collected in the previous paragraphs all the information needed to construct the accumulator shift control signal ASP. First observe that the term $\left[\bar{T}_{0}\right] \cdot[F 2] \cdot[\overline{M M I}]$ will take care of addition and subtraction ( $F 2$ being on in this case for $T^{1}$ only) and multiplication and division during $T^{1-19}$ (except for major multiplication, which is inhibited at $T^{19}$ ). However, we must add the term $\left[\overline{T^{1}}\right] \cdot\left[T_{0}\right] \cdot[F 2] \cdot[\mathrm{MDS}]$ so that $T_{0}$ will be on during $T^{2-19}$ for multiplication and division. The term $\left[T^{1}\right] \cdot\left[\bar{T}_{0}\right] \cdot[F 3] \cdot[\mathrm{SHS}]$ shifts the accumulator for the first minor cycle of $F 3$, and $\left[T^{2}\right] \cdot\left[\bar{T}_{0}\right] \cdot[F 3] \cdot[\mathrm{SHS}] \cdot[\overline{\mathrm{SCC}}]$ shifts the accumulator appropriately during the second minor cycle, i.e., as directed by SCC. Thus we have all together

$$
\begin{aligned}
& {[\mathrm{ASP}]=\left[\bar{T}_{0}\right] \cdot[F 2] \cdot[\overline{\mathrm{MMI}}]+\left[\overline{T^{1}}\right] \cdot\left[T_{0}\right] \cdot[F 2] \cdot[\mathrm{MDS}] } \\
&+\left[T^{11}\right] \cdot\left[\bar{T}_{0}\right] \cdot[F 3] \cdot[\mathrm{SHS}]+\left[T^{2}\right] \cdot\left[\bar{T}_{0}\right] \cdot[F 3] \cdot[\mathrm{SHS}] \cdot[\overline{\mathrm{SCC}}]
\end{aligned}
$$

Adder Input Control. The direct input to the accumulator is particularly simple, being merely the output of the adder-subtractor. However, the input to the adder-subtractor is nontrivial and can be thought of as the virtual input to the accumulator. There are two inputs to the addersubtractor, which we shall denote by $A$ and $B^{\prime}$.

Consider first the $A$ input for our simplified example of six instructions of a one-address serial computer. Looking at the first minor cycle of phase 2 instructions, clearly $A$ is ( $\alpha$ ) except for the multiplication instructions. For the multiplication instructions $A$ is ( $\alpha$ ) provided that MUS is on, as was discussed above. Thus we have the following terms for $A$ :

$$
\left[T^{1}\right] \cdot[F 2] \cdot(\alpha) \cdot[\overline{\mathrm{MDS}}]+\left[T^{1}\right] \cdot[F 2] \cdot(\alpha) \cdot[\mathrm{MCS}] \cdot[\mathrm{MUS}]
$$

During botb multiplication and division for the minor cycles after $T^{1}$,
$A$ becomes the recirculating output of the icand register, except during multiplication when MUS is off. Hence we have the following terms:
$\left[\overline{T^{11}}\right] \cdot\left[F^{2}\right] \cdot(\mathrm{ICN}) \cdot[\mathrm{DCS}]+\left[\overline{T^{1}}\right] \cdot\left[F^{2}\right] \cdot(\mathrm{ICN}) \cdot[\mathrm{MSC}] \cdot[\mathrm{MUS}]$
The shift instruction presents no input to $A$; that is, during phase 3 , there is no $A$ input. Hence

$$
\begin{aligned}
A= & {\left[T^{1}\right] \cdot[F 2] \cdot(\alpha) \cdot[\overline{\mathrm{MDS}}]+\left[T^{1}\right] \cdot\left[F^{2}\right] \cdot(\alpha) \cdot[\mathrm{MCS}] \cdot[\mathrm{MUS}] } \\
& +\left[\overline{\left.T^{1}\right]} \cdot[F 2] \cdot(\mathrm{ICN}) \cdot[\mathrm{DCS}]+\left[\overline{T^{1}}\right] \cdot[F 2] \cdot(\mathrm{ICN}) \cdot[\mathrm{MCS}] \cdot[\mathrm{MUS}]\right.
\end{aligned}
$$

For the $B^{\prime}$ input to the adder-subtractor, during addition or subtraction, we have the recirculating contents of the accumulator, called $B$ : this gives $B^{\prime}$ the term $[F 2] \cdot\left[T_{1-18}^{1}\right] \cdot[B] \cdot[\overline{\mathrm{PQS}}]$. For division the $B^{\prime}$ input is the recirculating contents of the accumulator, which is the partial dividend delayed by 1 , that is, $B_{d}$, during $T^{1-18}$; hence we have the term $[F 2] \cdot[B]_{d} \cdot[\mathrm{DCS}]$ (since DCS is only during $\left.T^{1-18}\right)$. For multiplication the $B^{\prime}$ input is the recirculating contents of the accumulator, i.e., the partial sum, and this holds for minor cycles $T^{2-18}$, but not for $T^{1}$; hence we have the term $[F 2] \cdot\left[\overline{T^{1}}\right] \cdot[B] \cdot[\mathrm{MSC}]$. Finally, for minor multiplication or division, during $T^{19}$ the transfer from the ier to the accumulator takes place; hence the term $[F 2] \cdot(I E R) \cdot[P Q T]$. The recirculation of the contents of the accumulator for the shift instruction also passes through the $B^{\prime}$ input; this gives the term $[F 3] \cdot[B] \cdot\left[\bar{T}_{0}\right]$. Hence

$$
\begin{aligned}
B^{\prime}= & {[F 2] \cdot\left[T_{1-18}^{1}\right] \cdot[B] \cdot[\overline{\mathrm{PQS}}]+[F 2] \cdot[B]_{d} \cdot[\mathrm{DCS}] } \\
& +[F 2] \cdot\left[\overline{\left.T^{1}\right]} \cdot[B] \cdot[\mathrm{MCS}]+[F 2] \cdot(\mathrm{IER}) \cdot[\mathrm{PQT}]+[F 3] \cdot[B] \cdot\left[\bar{T}_{0}\right]\right.
\end{aligned}
$$

## EXERCISES

(a) Construct the signal that determines whether the adder-subtractor will form the sum or difference for a one-address serial computer with the instructions discussed in this section.
(b) Explain why no addition or subtraction control signal explicitly appears in the expression constructed for ASP.
(c) Why are signals MDS and MCS both necessary for the construction of $A$ ?
(d) In the construction of $B^{\prime}$ why is there no input during $T^{1}$ of multiplication?
(e) Describe the shift control of the icand register for a one-address serial computer with the operations considered in this section.
$(f)$ Describe the icand-register shift control for a one-address serial computer with the operations considered in this section.

## 17-5. Control of Memory Address Selection and Instruction Sequencing

Instruction Register and Current-address Register. The control of memory selection and instruction sequencing takes place in the instruction register, current-address counter, and associated circuitry. Three basic functions are performed here: (1) determination is made of the addresses to be used during any phase; (2) the normal sequencing of
instructions is controlled; and (3) the abnormal sequencing of instructions, the jump, is accomplished.

Consider the first of these functions. Memory addresses to and from which words are transmitted are found in only two locations: Addresses of operands or for results are found in the instruction register; addresses of instructions are found in the current-address counter. Whether an address is selected from the instruction register or from the currentaddress counter depends on the phase during which the selection is made. As an illustration, consider a one-address computer in which the next instruction is selected during phase 1 , and an operand is obtained from the memory during the first minor cycle of phase 2 or returned to the memory during the first minor cycle of phase 3 . We let $\alpha i$ be the $i$ th bit of the $\alpha$ in the instruction register, and $\alpha^{\prime} i$ be the $i$ th bit of the current-address counter. Then, for $\alpha^{*} i$, the $i$ th bit of the address upon which the selection is made, we have

$$
\left[\alpha^{*} i\right]=[F 1] \cdot\left[\alpha^{\prime} i\right]+[F 2] \cdot\left[T^{1}\right] \cdot[\alpha i]+[F 3] \cdot\left[T^{1}\right] \cdot[\alpha i]
$$

Now consider the second and third functions taken together. For a three-, two-, or one-address system the current-address register is an actual counter, so that, in the normal sequencing of instructions, the address of the next instruction is obtained by adding 1 to the count. For a jump an address recorded in the instruction register must be transferred to the current-address counter, to replace the previous contents of the counter.

As a specific illustration, let us consider a simplified version of a one-address instruction register, current-address register, and associated circuitry. In Fig. 17-9 the current-address register is a counter; when a jump is made, the signal $J$ clears the counter and inserts the bits of the $\alpha$ address of the instruction register. $N$ is the signal that increases the count by 1 for the normal sequencing of instructions. It can be shown (see Exercises $a$ and $b$ ) that

$$
\left[\alpha^{\prime} 1\right]=[\alpha 1] \cdot J+\left[\overline{\alpha^{\prime} 1}\right]_{d} \cdot N+\left[\alpha^{\prime} 1\right]_{d} \cdot \bar{N} \cdot \bar{J}
$$

The $\alpha^{*} i$ are formed as described above. For our simplified example the shift control for the instruction register is $\left[T_{1-18}\right] \cdot[F 1]$, and the input control is simply ( $\alpha$ ) $\cdot[F 1]$.

Serial and Parallel Systems, and Relative Counters. The operation of the instruction register and current-address counter as described above is adequate for parallel operation provided that the counter is a parallel counter and that the instruction register is loaded in parallel.

The instruction register may be a recirculating delay line. In such a case the instruction decoder must end in flip-flops, which are set as the instruction enters the instruction register. The current-address counter need not be a counter at all, but merely a shift register, which may also recirculate. The recirculation must pass through an adder so that a unit can be added to the current address to determine the address
of the next instruction in normal sequence and so that an address from the recirculating instruction can be inserted into the current address in case of a jump. The bits of $\alpha^{*} i$ would be gated with $F 1, F 2$, and $F 3$ as above, except that now only a single set of gates would be necessary through which the $\alpha i$ and $\alpha^{\prime} i$ pass.

The operation of a relative counter becomes clear at this point. For serial operation, as the instruction enters the instruction register it


Fig. 17-9. The instruction register, current-address register, and associated circuitry. passes through a special single-address adder; if the appropriate control signals are present, this adder adds the contents of the relative counter to one or more addresses of the instruction. For parallel operation a parallel adder having the same length as the address is necessary. Occasionally the instruction format is so arranged that the relative count cannot be added to the instruction as it enters the instruction register. In such a case the addition of the relative count to the address would be accomplished as a separate function.

## EXERCISES

(a) Show that $\left[\alpha^{\prime} 1\right]=[\alpha 1] \cdot J+\left[\overline{\alpha^{\prime} 1}\right]_{d} \cdot N+\left[\alpha^{\prime} 1\right]_{d} \cdot \bar{N} \cdot \bar{J}$.
(b) Derive an expression for $\alpha^{\prime} i$.
(c) Draw in detail two more stages of the current-address counter, instruction register, and $\alpha^{*} i$ generator, as indicated by the rectangles of Fig. 17-9.
(d) Draw a block diagram to show in detail all associated circuitry necessary for a recirculating delay-line serial instruction register and similar current-address counter. Describe its operation and the flow of words and addresses.
(e) Describe in detail the operation of a relative counter in a parallel computer. Draw a block diagram of the system.

## 17-6. Memory Selection

Obtaining a Word from the Memory. In the previous sections we have seen how the address to be selected, called $\alpha^{*}$, is chosen either from the instruction register or from the current-address counter. The topic under consideration in this section is how this address is used to obtain a word from the memory or to


Fig. 17-10. Layout of memory cells on a rotating drum. replace a word into the memory. However, for a moment let us first consider the following question: Suppose that a word has been obtained from the memory; how does the computer know where to send it, to the arithmetic unit or to the instruction register? In essence we have already given the answer to this question in Secs. 17-4 and $17-5$. In the arithmetic unit in our illustrations, ( $\alpha$ ) was always gated with $F 2$. In other words, as ( $\alpha$ ) comes out of the memory it goes to both the arithmetic unit and the instruction register, but it is the phase that determines which location it enters.

Serial Memories. Before describing how $\alpha^{*}$ selects a word from the memory, we must first briefly describe the physical layout of the memory cells. We shall use a rotating magnetic drum as an illustration, but all serial memories pose the same basic problems. As mentioned in Chap. 2 , a rotating magnetic drum consists of a cylindrical surface with a coating of a magnetizable substance. We shall consider the electronic aspects of the drum in Part 5 of this book. The cylindrical surface of the drum is divided into bands called channels, and each channel is divided into lengths called sectors. The bits of a single word are recorded on this drum as a chain, or sequence, of small magnetized areas in one sector of a channel (see Fig. 17-10). Thus, by specifying its particular channel and sector, a word can be located, i.e., addressed. There is one reading-andwriting head for each channel which can sense the magnetic pulses, or bits, as they pass under the head (reading) or can place magnetic spots on the rotating-drum surface as it passes the head (writing).

As we shall describe in detail in a later section of this chapter, the computer is so synchronized with the drum that 1 bit passes underneath a head each unit time interval. The words (or sectors) are spaced so
that precisely one minor cycle elapses between the passage of the first bit of one word under a head and the passage of the first bit of the next word. Ordinarily this means that there is some blank space between words (see crosshatched areas in Figs. 17-10 and 17-11). For example, the Pedagac has an 18 -bit word plus a sign bit, but a 23 -unit-timeinterval minor cycle. Thus there will be four spaces after one word before the next word starts.

Consider the unrolled surface of a hypothetical drum, shown in Fig. 17-11. The columns represent the channels and the rows the sectors. The numbers appearing in each word location (each channel-sector location) are the addresses. Here there are four channels of eight sectors each. Any address can be formed by placing the binary column (channel) number adjacent to the binary row (sector) number, the most significant 2 bits of the address specifying the channel, the least significant 3 bits the sector. Thus address 5 becomes 00101, address 21, 10101, and


Fig. 17-11. The organization of addresses on the drum memory. so forth. This illustration is not realistic, for even the small drum used for the Pedagac has 32 channels with 128 sectors per channel, making a total of $2^{5} \times 2^{7}=2^{12}=4,096$ words. There are drums having as many as 100,000 words.
Serial Memory Selection. Given an address $\alpha^{*}$, the proper word is located on the drum as follows: The proper channel is selected by choosing the corresponding read-write head; the proper sector is selected by counting each sector as it passes under the head. (The former is a space, the latter a time, selection.) Let us consider the sector selector first. The count of a counter synchronized with the drum increases by 1 each time the first bit of a new word comes under the head; i.e., it increases by 1 at $T_{0}$ of every minor cycle. If we wished to read from or write into the fifth sector, we would compare 101 (of $\alpha^{*}$ ) with the reading of this sector counter. When the count equals 101, the reading (or writing) would commence. The sector counter will be reset to zero when the start of the zero sector passes under the heads. In Fig. 17-12, $\alpha^{*} 3$, $\alpha^{*} 2, \alpha^{*} 1$ represent the sector-selector bits of $\alpha^{*}$ and $C 3, C 2, C 1$ the count of the sector counter. The circuit shown will produce the coincidence signal COI only when $\left[\alpha^{*} 1\right]=C 1,\left[\alpha^{*} 2\right]=C 2$, and $\left[\alpha^{*} 3\right]=C 3$. The signal is needed only at $T_{0}$ and is therefore gated with $T_{0}$. As we shall see in the following section, this coincidence signal chooses the sector by initiating the read or write process.

Having shown how to choose the proper sector, we now turn our attention to how the proper channel is chosen. The method is simply to decode the channel-selecting bits of $\alpha^{*}$ (see Sec. 17-2 for a detailed
discussion of decoding circuits). The output of each channel is gated with the corresponding output of the decoder, and only the signals to or from the selected channel will enter or leave the drum (see Fig. 17-13). The output ( $\alpha$ ) is gated with $T_{0-18}^{1}$ since only during the first minor cycle of a phase is a word read out of the memory. This may occur only during phase 1 or 2 for a serial one-address computer. Writing into the memory occurs only during phase 3 during $T_{0-18}$ of one minor cycle. $\dagger$


Fig. 17-12. Generation of the sector-selector coincidence signal.
The waiting time from when $\alpha^{*}$ is first produced to when the proper sector has been selected (i.e., to when the sector-counter bits agree with the $\alpha^{*}$ bits) is called the memory access time. For the drum we have described, the shortest access time is zero, i.e., when the first bit of the desired word is under the head at $T_{0}$ of the minor cycle in which $\alpha^{*}$ is formed. The longest access time occurs when the desired word has just been missed, since the drum must rotate a complete revolution minus one sector before the word comes round again. The average access time is often taken as half the longest access time.

Parallel Memories and Selection. In parallel memory selection all the bits of a word enter the instruction register or the accumulator at the same time. Similarly, in replacing a word in the memory, all the bits are replaced simultaneously. A drum memory can be used in a parallel fashion, when a word is recorded on the drum cylinder parallel to the axis instead of round the circumference. If only one word can be fitted along the length of the drum, then in this arrangement each of the drum heads reads (or writes) 1 bit of the word, and there must be as many heads as bits in the word format. This eliminates the need for channel selection. The need still remains for sector selection, but now there are

[^10]

Frg. 17-13. The channel selector with associated read-in and -out circuitry.
as many sectors as words (see Fig. 17-14). Of course, if there are two or more words on the axial length of the drum, group selection is necessary.

The most common parallel memory in use is composed of magnetic cores; each core stores a single bit. Magnetic cores are made from ferrite, which has a relatively square hysteresis loop (see Fig. 17-15). They are usually formed in the shape of tiny rings which are magnetized in one direction to record, say, a unit, and in the other direction to record a zero. In Part 5 there are more detailed descriptions of the magnetic properties of cores and of the elec-trical-engineering aspects of their use. For our present purpose, namely, logical design, it suffices to


Fig. 17-14. Parallel access to a drum. observe that the direction of the magnetic flux in the core can be changed or detected by means of wires placed through the hole of the core.

In Fig. 17-15 we have illustrated a core that requires a current $I_{c}$ to be flipped (i.e., change of polarity); note that $1 / 2 I_{c}$ or $2 / 3 I_{c}$ will not fip the core if it is initially at zero. The simplest method of wiring a mag-
netic-core memory requires the use of three wires through each core (see Fig. 17-16). The cores are arranged as the points of a three-dimensional coordinate system; the $X$ and $Y$ coordinates of a core represent the address of the word of which that core is a member; the $Z$ coordinate determines which bit of the word the core stores. Thus a single column of cores (i.e., all cores with the same $X$ and $Y$ coordinates) represents a single word. Through each core there is a wire representing its $Z$ coordinate or bit number. The wiring is so arranged that all cores with the same $X, Y$, or $Z$ coordinate have the same $X, Y$, or $Z$ wire through them. The $X$-coordinate wires are the outputs of a decoding



Magnetic core with magnetic flux in clockwise direction
circuit (see Sec. 17-2) that decodes (i.e., has as inputs) half the bits of an address; the $Y$-coordinate wires are outputs of a decoding circuit for the other half. The $Z$ wires are the parallel input to the registers of the computer.

To select a word with this system, a current of $-1 / 2 I_{c}$ is passed through the $X$ wire corresponding to the $X$ half of the desired address; another current of $-1 / 2 I_{c}$ is passed through the $Y$ wire corresponding to the $Y$ half of the address. Only cores in the proper $X, Y$ column will then have the full current $-I_{c}$ passing through them; and of these cores only those which are recording units will flip to zero, while the zero cores will stay at zero. Only the $Z$ wires through those cores which flip will have induced voltage to operate the registers, all the bits of the stored word being sensed at the same time (see Fig. 17-16). Since reading a word from the memory clears this word, the word must be immediately written back into the memory.

To write into the memory, the selected address must first be cleared as above, with $-1 / 2 I_{c}$ in the corresponding $X$ and $Y$ wires. Then a current of $1 / 3 I_{c}$ is passed through each of these wires, while $1 / 3 I_{c}$ is also passed through only those $Z$ wires which correspond to unit bits of the word being read in. The only cores flipped will be those receiving the current $I_{c}$, that is, those in the selected address corresponding to the unit bits in the word which was read in.

There are many variations to the wiring arrangements and the current values described above. For example, in writing into the memory all the $X$ wires may carry $-1 / 2 I_{c}$ except the selected $X$ wire, which would not carry current. The selected $Y$ wire would carry $1 / 2 I_{c}$ and the


Fig. 17-16. Access and sensing wires of a core memory. The figure represents a memory with 4 -bit addresses containing ninc words each of 4 bits length. The dark wires indicate the selection of the word that is the contents of address $\begin{array}{ll}x & y \\ 0\end{array} 0$.
other $Y$ wires no current. A current of $1 / 2 I_{c}$ through the $Z$ wires corresponding to unit bits of the word being read in would cause a total current of $I_{c}$ to pass through only the corresponding cores of the selected word (since outside the selected word the $-1 / 2 I_{c} X$ currents will cancel the $+1 / 2 I_{c} Y$ currents). Alternatively the bits of the address can be sep-
arated into three sets instead of two. We then would have a fourdimensional array, with $W, X$, and $Y$ wires selecting the word and $Z$ the bits of the word and three decoding circuits instead of two.
Note that with a magnetic-core memory there is no time selection; only decoders are used. (Hence there are no idling phases in selecting a word-see next section.)

## EXERCISES

(a) Diagram the control gates through which ( $\alpha$ ) must pass when being transmitted from the memory (1) to the instruction register and (2) to the arithmetic unit and (3) when being transmitted from the arithmetic unit to the memory; consider serial four-, three-, two-, and one-address computers. (Hint: During what phases are these gates open?)
(b) What would be the diameter of a drum that in a single channel stores 128 words of 23 bits each, if the bits are stored 100 to the inch?
(c) How long (in microseconds) would a unit time interval be if the drum described in Exercise $b$ rotated at $1,800 \mathrm{rpm}$ ?
(d) What would be the average access time of the drum of Exercise $c$ ?
(e) In Fig. 17-12 a parallel comparator is illustrated for use in selecting the proper sector; i.e., all the bits of $C$ and $\alpha^{*}$ are compared simultaneously. How would a serial comparator be constructed, to compare 1 bit of $C$ and $\alpha^{*}$ at a time? (Hint: At what $T_{i}$ would the sector counter have to be increased in order that the serial comparison be completed by the time $T_{0}$ ?)
( $f$ ) Compare the selection problems involved in serial-drum, parallel-drum, and magnetic-core memories with respect to time and space.
(g) How can the currents be arranged in a three-dimensional core memory so that the currents through the cores of nonselected words are only $1 / 3 I_{c}$ ? (Hint Try different directions of currents for selected and nonselected $X$ and $Y$ wires.)
( $h$ ) Repeat Exercise $g$ for a four-dimensional core memory.

## 17-7. Control of Instruction Execution

Sequencing of Phases. Up to now we have studied the controls that act once we are in a particular phase. The subject of the present section is how we control the phases themselves; i.e., what are the controls that sequence the phases during the execution of an operation? The answer to this problem completes the control picture.

There are three aspects to the control of a phase signal: (1) it must be turned on; (2) it must be kept on for the duration of the phase; and (3) it must be turned off. Consider phase 1 for a four-address system (see Table 17-1). During this phase the address $\alpha$ is selected and read into the accumulator, in one minor cycle. In order to construct the phase 1 signal, we observe that phase 4 , which precedes it, is only one minor cycle in length. Thus we have for phase 1

$$
[F 1]=[F 4]_{d} \cdot\left[T_{0}\right]+[F 1]_{d} \cdot\left[\bar{T}_{0}\right]
$$

Here by delaying $F 4$ by one unit time interval we initiate $F 1$ at $T_{0}$ just as $F 4$ goes off; the right-hand product keeps $F 1$ on until the next $T_{0}$, which is the start of phase 2. Note that if $F 4$ had been longer than one
minor cycle this formula for $F 1$ would not work but would make $F 1$ go on during the second minor cycle of phase 4.

Remember that phase ( 2 and $3 \dagger$ ), the operation computing phase, can last for more than one minor cycle. For these phases a special pulse called the operation ending pulse OEP is needed; it comes on only during the last unit time interval of the operation computing phases. Now consider $F 1$ for a one-address system (see Table 17-1), which may follow either phase 2 or phase 3, depending on the previous instruction. Hence it must be initiated by OEP,

$$
[F 1]=[\mathrm{OEP}]_{d}+[F 1]_{d} \cdot\left[\bar{T}_{0}\right]
$$

In the case of phases, such as $F 2$, that may last for more than one minor cycle, signal OEP must be used to end them,

$$
[F 2]=[F 1]_{d} \cdot\left[T_{0}\right]+[F 2]_{d} \cdot[\overline{\mathrm{OEP}}]_{d}
$$

Signal OEP is delayed so that $F 2$ remains on throughout its last minor cycle.

Thus the sequencing of phases rests with the construction of the signal OEP, produced in the operations signal generator. We shall illustrate the construction of this signal for the simplified one-address example that we were following in Secs. 17-3 and 17-4. Signal OEP is to come on at $T_{22}$ of the last minor cycle of the operation being performed in phase 2 or 3 . For addition and subtraction this is $T_{22}{ }^{1}$; for multiplication and division this is $T_{22}{ }^{19}$; for shift this is $T_{22}{ }^{2}$. In our example we assumed that in phase 2 the only operations performed are the arithmetic; hence $\overline{\mathrm{PQS}}$ can be used for the addition and subtraction signal:
$[\mathrm{OEP}]=[F 2] \cdot[\overline{\mathrm{PQS}}] \cdot\left[T_{22}{ }^{1}\right]+[F 2] \cdot[\mathrm{PQS}] \cdot\left[T_{22^{19}}\right]+[F 3] \cdot[\mathrm{SHS}] \cdot\left[T_{22^{2}}{ }^{2}\right]$
where PQS is on during multiplication and division and SHS is on during shift.

The Selection or Idling Phases. As we have seen in Sec. 17-6, when using a drum memory the computer must wait for the drum to rotate to the proper sector; this waiting period must be some integral number of minor cycles. It is convenient to denote such a period as an idling phase, because the primary components of the computer merely idle until the proper sector is selected. The coincidence signal COI comes on at $T_{0}$ of the minor cycle that coincidence is made; hence this signal can be used to end an idling phase and to initiate the next functional phase in sequence. Such an idling phase will precede any phase that requires drum memory access. For example, suppose that an idling phase preceded phase 2; call this phase IF2 (idling phase 2):

$$
[\mathrm{IF} 2]=[F 1]_{d} \cdot\left[T_{0}\right]+[\mathrm{IF} 2]_{d} \cdot[\overline{\mathrm{COI}}]
$$

$\dagger$ See footnote on page 546.

Then we would have for $F 2$ itself

$$
[F 2]=[\mathrm{IF} 2]_{d} \cdot[\mathrm{COI}]+[F 2]_{d} \cdot\left[\overline{\mathrm{OEP}}_{d}\right.
$$

For a one-address system where an idling phase IF1 would precede phase 1, we have

$$
\begin{array}{lll} 
& {[\mathrm{IF} 1]=[\mathrm{OEP}]_{d}+[\mathrm{IF} 1]_{d} \cdot[\overline{\mathrm{COI}}]} \\
\text { and also } & {[F 1]=[\mathrm{IF} 1]_{d} \cdot[\mathrm{COI}]+[F 1]_{d} \cdot\left[\bar{T}_{0}\right]}
\end{array}
$$

By initiating the change of phase from an idling phase, COI selects the proper sector. For as soon as the computer changes from the idling phase, COI opens the gates that read $B$ into the memory or ( $\alpha$ ) out of the memory, and the reading or writing proceeds.

The Input-Output Phases and Synchronization. Transmitting words between the outside world and the computer's memory by means of the input-output equipment presents a special problem, because the inputoutput external equipment generally operates at much slower speeds than does the computer. This problem is often solved by the use of an input-output buffer, which is a shift register designed in such a way that it may be controlled at times by the computer and at other times by the external equipment. For a computer with a drum memory three phases each for input and output can be distinguished as follows: (1) the IF phase during which an address is selected in the computer memory; (2) a phase FO during which a word is transmitted (in either direction) between the memory and the in-out buffer; and (3) a phase FB during which a word is transmitted between the in-out buffer and an external input or output unit.

Let us consider as an example the input and output instructions of the Pedagac. For the read-out instruction, phase IF Out (signal IFO) is initiated after $F 1$ and lasts until COI comes on at coincidence. Then phase FO Out (signal FOO) is initiated. During this phase the buffer shift register is loaded by the computer proper, at its rapid speed, while the buffer is being shifted under the control of the computer; this phase lasts one minor cycle. The end of phase FO Out initiates FB Out. During this latter phase the word is read out of the buffer to the output unit, the buffer being shifted by the output equipment, at the slower speed. When the word has been completely read out, the output equipment notifies the computer; phase FB Out has ended, and the execution of the instruction "Read out one word from address $\alpha$ " has been completed. For phase signals IFO and FOO we have

$$
\begin{aligned}
{[\mathrm{IFO}] } & =[F 1] \cdot[21 D] \cdot\left[T_{0}\right]+[\mathrm{IFO}]_{d} \cdot[\overline{\mathrm{COI}}] \\
{[\mathrm{FOO}] } & =[\mathrm{IFO}]_{d} \cdot[\mathrm{COI}]+[\mathrm{FOO}]_{d} \cdot\left[\bar{T}_{0}\right]
\end{aligned}
$$

where $21 D$ is the instruction decode signal for read-out. For the genera-
tion of signal FBO let the signal EWO be initiated by the external output unit when the word has been read out of the buffer. Signal EWO need not come on at $T_{0}$, and so we must end phase FB Out only at [EWO] $\cdot\left[T_{0}\right]$. Thus

$$
\begin{aligned}
{[\mathrm{FBO}] } & =[\mathrm{FOO}]_{d} \cdot\left[T_{0}\right]+[\mathrm{FBO}]_{d} \cdot\left[\overline{\mathrm{EWO}] \cdot\left[T_{0}\right.}\right] \\
& =[\mathrm{FOO}]_{d} \cdot\left[T_{0}\right]+[\mathrm{FBO}]_{d} \cdot[\overline{\mathrm{EWO}}]+[\mathrm{FBO}]_{d} \cdot\left[\bar{T}_{0}\right]
\end{aligned}
$$

The problem remains of how to generate the signal EWO. One procedure is to have the output unit count each bit that it receives, presenting a signal to the computer when a complete word has been received. Let us assume that it is turned into a signal EWO'. This signal, which in general lasts several unit time intervals but less than a minor cycle, initiates EWO. Then EWO should stay on until the next $T_{0}$, at which time it stops FBO and initiates IF1, the next phase in sequence:

$$
[\mathrm{EWO}]=\left[\mathrm{EWO}^{\prime}\right] \cdot\left[\bar{T}_{0}\right] \cdot[\overline{\mathrm{IF} 1}]_{d}+[\mathrm{EWO}]_{d} \cdot[\overline{\mathrm{IF} 1}]_{d}
$$

The IF1 signal is used to inhibit EWO' if it stays on past $T_{0}$; it is used to stop EWO. (See Exercise $c$ below concerning the $\bar{T}_{0}$ in the left-hand product.)

This process for forming and using EWO is generally applicable to external signals from control-panel push buttons or from external in-out units. The original external signal is converted into one or more computer signals by electronic circuits called synchronizers. The synchronizer outputs initiate other signals to be used at specific times to initiate phases, etc. The signals so initiated can be used to turn off their initiating signal.

## EXERCISES

(a) Suppose that, in the one-address drum computer that we have been using for illustration, phase 3 also included the transfer instruction as well as the shift. Construct the signals for IF1, $F 1$, IF2, $F 2$, IF3, and $F 3$.
(b) Write expressions that for a one-address drum computer generate the input phase signals IF1, FOI, FBI, using the signal OOD, the instruction decode signal for "Read one word into address $\alpha$," and the signal EWI' produced by the input unit synchronizer when a complete word has been transferred into the buffer.
(c) Why must $T_{0}$ inhibit the initiation of EWO? (HINT: Suppose that it did not inhibit EWO, but that EWO were initiated at $T_{0}$; would FBO be turned off? What about IF1?)

## 17-8. Timing and Counters

Review. In Sec. $15-4$ we introduced the ideas of minor cycles and unit time intervals, based on the clock pulses described in Sec. 2-4. In this section we shall describe the generation of clock pulses. Let us
review again the over-all synchronous plan. The basic timing is kept by means of clock pulses which measure off the unit time intervals. A unit-time-interval counter counts these clock pulses, the count at any time being denoted by $T_{i}$. A certain number of these clock pulses constitute a minor cycle, and each time this number has been counted off the unit-time-interval counter is reset to zero. Another counter counts minor cycles, the count at any time being denoted by $T^{i}$. A signal $T^{i}$ is on during every unit time interval of the $i$ th minor cycle. A certain number of minor cycles constitutes a phase, the number depending on the particular phase and operation. A phase signal $F j$ is on during every


Fig. 17-17: Diagram of a drum showing drum synchronizing signal.
unit time interval of every minor cycle of phase $j$. At the end of the phase the minor-cycle counter is reset to its initial count.

Serial and Parallel Clocking. Basic to all the counters and timekeeping signals are the clock pulses, denoted by $c p$. For a serial or parallel access magnetic-drum memory these clock pulses may arise from evenly spaced unit bits prerecorded on a special channel of the magnetic drum, called the clock-pulse drum channel (see Fig. 17-17). Then, while the drum is rotating, these bits are read from the drum by a separate head to form the clock pulses. In this way the synchronization of the entire computer is based directly on the rotating-drum speed, a far easier accomplishment than adjusting the speed of the drum to some outside clock frequency.

Consider next the situation that arises when the computer is turned off for the night with information from some previous computations recorded on the drum. When the power is cut, the drum stops rotating but the contents of the memory remains. The next morning, when the power is turned on and the drum starts rotating again, it is often desired to use the information that remained on the drum during the night.

However, to read a word out of the drum, $T_{0}$ must be synchronized with $P 0$ (that is, the first bit of the word). The problem is: In starting the drum rotating how is synchronization reattained?

One common solution to this problem is to have on the drum a separate channel, called the drum-synchronizing channel, containing one single pulse (see Fig. 17-17). After the drum is started, the very first time this bit is recognized the unit-time-interval counter is started. Hence, as the unit-time-interval counter starts, the position of the readingwriting head is known to be at $P 0$ of the zeroth word on each channel; and this will be the same position each time the drum is started. Also at this very first $T_{0}$ time the sector counter starts. In this way the address locations on the drum remain invariant for the life of the drum.

For a computer with a parallel magnetic-core memory the clock is simply an oscillator with a fixed frequency. Since memory selection does not depend on time, the difficulties encountered with the drum do not occur.

The Unit-time-interval Counter. The unit-time-interval counter counts the time intervals during a minor cycle. As an illustration, consider the Pedagac, with time intervals $T_{0}$ through $T_{22}$. The Pedagac counter does not start to count until the drum-synchronizing pulse appears for the first time when the drum is started rotating, and then with each clock pulse the count is increased by 1 until it reaches 22 . Then after the $T_{22}$ signal the count must return to $T_{0}$ again; i.e., the count should be cleared after $T_{22}$.

The Sector Counter. The sector counter counts the words within each channel. The Pedagac is designed to have $128=2^{7}$ words per channel. The sector counter therefore has seven stages, whose outputs are compared with the last 7 bits of the $\alpha$ address in generating the coincidence signal. Starting at zero when the drum-synchronizing pulse first appears, the count is increased by 1 with each succeeding $T_{0}$. Since the total number of sectors is an integral power of 2 , the counter overflows, returning to zero, each time the drum-synchronizing pulse returns, and hence need not be specially reset.

The Minor-cycle Counter. As we have seen above, the minor-cycle counter presents signals for the operations signal generator, the arithmetic unit, and the phase generator. The minor-cycle count at which the counter is reset depends on the phase and operation being performed. The minor-cycle counter of the Pedagac starts with a count of 1 and can go up either to the count of 2 during the execution of the shift instruction or to the count of 19 during the execution of the multiplication and division instructions. Hence the main problem is to reset the counter at the proper time. This is done in phases 2 and 3 by using the OEP signal to reset the counter to 1 . Since during other phases (including the idling phases) we need never count past 1 , the count is forced to 1 at $T_{0}$ of every minor cycle of these phases as well as at $T_{0}$ of the first minor cycle of phases 2 and 3.

## EXERCISES

Consider the Pedagac with 128 word channels, a 23 -unit-time-interval minor cycle ( $T_{0-22}$ ), a word containing 18 bits plus a sign bit, and instructions as described. Suppose that the following three-instruction program is being computed:

| Address | Operation | $\alpha$ | Remarks |
| :---: | :---: | :---: | :--- |
| 0010 | 53 | 0000 | Add |
| 0011 | 42 | 3725 | Multiply |
| 0012 | 70 | 0016 | Shift |

(a) What is the count on the sector counter when the add instruction has been completed?
(b) What is the count on the sector counter when the multiply instruction has been completed?
(c) How many minor cycles have passed from the time that coincidence was made on the sector selector with address 0010 until the shift instruction has been completed?

## PACKAGING AND THE LOGICAL DESIGN OF THE PEDAGAC

## 18-1. Introduction

Thread of Continuity. In the preface we mentioned that to maintain the thread of continuity throughout this book a complete digital computer would be designed. To this end we have considered in Chap. 9 the systems design of the Pedagac. We consider now the logical design of the machine.

In the preceding three chapters we have described the operation of various computer components, such as the adder, the sign generator, counters, multiplication and division controls, and the instruction decoder. We shall now consider an integrated example of how all these components are organized and assembled to form an operating system. New principles will arise that are associated with the complete organization of such a system, and it is felt that these can best be displayed by means of specific examples.

Point of View. The ability to design a complete computer system results to a large extent from experience. Probably the only way the student can gain any such experience is by following through a detailed example. Such is the point of view of this chapter. However, we must add that although we shall spend much time on the particular details of our illustration, this by no means implies that logical designs are limited to the methods and techniques here used. We intend that through his detailed study the reader shall grasp the principles involved and the pitfalls encountered in a complete systems design. The Pedagac has been designed to emphasize such principles. In presenting the logical design of the Pedagac we shall utilize methods which may aptly be termed vertical and horizontal description. The vertical descriptions relate to the specific function and purpose of each gate during the different operations; the horizontal descriptions follow the path of a bit as it is propagated through the computer during the execution of the various instructions. However, merely reading these descriptions will not be sufficient to give the student the sought-after experience. Therefore included in this chapter are an extraordinarily large number of exercises. These exercises differ from those of other chapters in that they are not intended to give the student practice in the methods considered; rather their purpose is to guide the student in his study of the functioning of the

Pedagac. These exercises will illustrate the intricate details involved in complete logical-systems design. They are essential to the teaching method of this chapter.

Outline of the Chapter. Computers are usually constructed by connecting together preassembled combinations of and, or, and not gates. Such combinations are called packages. Thus, preliminary to the discussions of the Pedagac we consider packaging, in Sec. 18-2. The remainder of the chapter is then concerned with the details of the Pedagac. First (in Sec. 18-3) the phases and block diagram of the Pedagac are covered. This section is fundamental, since all that follows is based directly on its material.

In Sec. 18-4 is considered the operations signal generator, whose output signals determine the mode of operation of the arithmetic unit, wherein most operations are performed. In Sec. 18-5 the vertical description of the arithmetic unit is given, and Sec. 18-6 integrates these two preceding sections in the horizontal descriptions of the arithmetic unit.

Two methods are commonly employed for recording the detailed logical design of a digital-computer or -control system. One method is by use of logical circuit diagrams, the other by use of the corresponding Boolean equations. Since, as we have seen previously (Secs. 10-11 and $10-12$ ), the equations and their corresponding logical diagrams are equivalent, either method is completely satisfactory. It is felt, however, that the logical diagrams are probably easier for the student to grasp, and hence for the Pedagac these are given. Since for many purposes the Boolean equations may be more convenient, we have also included these in the text (see Appendix), using a symbolism consistent with the corresponding logical diagrams.

## 18-2. Packaging

The Package. The concept of a package must be discussed before considering the detailed logical design of the Pedagac. It has been found from experience that it is neither convenient nor economical to build a computer directly with the three basic building blocks, and gates, or gates, and not gates. Instead combinations of these building blocks are used as elementary modules. For example, a convenient package may consist of three and gates all feeding into an or gate (see Fig. 18-1). All these components are put in a single-circuit module, which in our example has nine inputs. Most often two outputs are used, one output being simply the negation of the other, as shown in Fig. 18-1. These packages are constructed in mass-production style, and the computer is made by wiring the packages together according to the logical design. Part 5 of this text will consider the electronic design of such package circuits. However, it is appropriate to point out here that, in addition to performing the logical gating of signals, the package also has the function of reshaping, amplifying, and resynchronizing the pulses.

The type of package shown in Fig. 18-1, called the and-or package,
has the advantage that it produces a sum-of-products form, that is,

$$
D=A_{1} \cdot A_{2} \cdot A_{3}+B_{1} \cdot B_{2} \cdot B_{3}+C_{1} \cdot C_{2} \cdot C_{3}
$$

and also $\bar{D}$. Another type of package, particularly suited for parallel adders, is the or-and-or package, as shown in Fig. 18-2. Here the output

$$
E=\left(A_{1}+A_{2}\right) \cdot\left(B_{1}+B_{2}\right)+\left(C_{1}+C_{2}\right) \cdot\left(D_{1}+D_{2}\right)
$$

There are many variations in the kinds of packages. An important class of packages involves the use of a transistor. These packages in general only have a single output instead of the usual inverse outputs.


Fig. 18-1. Example of an and-or package with nine inputs and two outputs.


Fig. 18-2. The or-and-or package.

There are two basic types. In the first, called the or-not circuit (sometimes also referred to as a nor circuit), if the inputs are $A_{1}, A_{2}, A_{3}$, the output is $\overline{A_{1}+A_{2}+A_{3}}$, or equivalently $\bar{A}_{1} \cdot \bar{A}_{2} \cdot \bar{A}_{3}$ (see Fig. 18-3). For the second type, called the and-not circuit (sometimes also referred to as a nand circuit), if the inputs are $A_{1}, A_{2}, A_{3}$, the output is $\overline{A_{1} \cdot A_{2} \cdot A_{3}}$, or equivalently $\bar{A}_{1}+\bar{A}_{2}+\bar{A}_{3}$. Of course these definitions are easily generalized to any number of inputs (see symbolism of Fig. 18-3).

Besides being advantageous from an electronics point of view, the advantage from a logical point of view is seen when combinations of these packages are considered. The sum of products, product of sums, straight and, and straight or can all be obtained.

Packaging Limitations. As was remarked in the discussion of the parallel adder, certain electronic limitations can affect the logical design. Using the and-or package for illustration, there are (1) the limitation on the number of and gates in a single package, (2) the limitation on the number of inputs allowed to a single and gate, and (3) the limitation on the number of packages to which the output can be sent, i.e., limitation on the "drive" of the output.

There is in addition a fourth electronic constraint, the delay time through the package. For the most part we have assumed, and will continue to assume throughout this chapter, that the gating of a signal


Or-not circuit (nor)


And-not circuit (nand)





Fig. 18-3. The or-not and and-not circuits and their resulting combinations.
occurs instantaneously. The effect of the actual delay will be considered at the end of Part 5, when its electronic nature and causes can be more thoroughly understood. The alteration of the computer design to take


Fig. 18-4. And-or package showing the clock-pulse input to every and gate. account of these delays will then be straightforward.

The Clock Pulse and Packaging. The concept of the clock-pulse $c p$, used for synchronization, was introduced in Sec. 2-5, where it was noted that it enters every and gate. Let us use the and-or package to illustrate how this might be accomplished. One input to each and gate of every package is reserved solely for the clock pulse. Since the clock pulse is on in every unit time interval and is included as an input to every and gate, it is never indicated but always understood to be present. For example, the package illustrated in Fig. 18-1 really is as in Fig. 18-4. The clock pulse is logically nonfunctional; the reason for its use will be given in Part 5.

The Packages of the Pedagac. For the logical design of the Pedagac we shall choose the and-or package class. Five different types of pack-
ages will be used, having one and gate, two and gates, three and gates, four and gates, and five and gates, called types $A, B, C, D$, and $E$ respectively. We assume that each and gate is limited to no more than five inputs (other than the clock pulse). There will be two outputs, normal and inverted. Rather than draw the entire circuit, we symbolize a


Fig. 18-5. Package representation.


Logical


Packaged

Fig. 18-6. Example of the packaging of a counter stage.
package with only the and gates indicated, it being understood that there is an or gate before the output (see Fig. 18-5). The inverted output is not shown, however; when the inverted output is to be used, it is indicated where it is used in the usual way. This convention reduces the number of lines on the drawing. For example, a counter stage drawn with the package convention appears in Fig. 18-6. Here one package of type $A$ and one of type $B$ are used (cf. Fig. 15-6).

## EXERCISES

(a) Package the circuits shown in Fig. 17-8, using and-or packages.
(b) Package a counter stage, using and-not and or-not packages. (Hint: Compare Figs. 15-6 and 18-6.)
(c) Package a counter stage, using only or-not packages.
(d) Package the 5-bit parallel adder shown in Fig. 16-1, using or-and-or packages.
(e) Package the 5-bit parallel adder of Fig. 16-1, using and-or packages.
(f) Package the 5-bit parallel adder of Fig. 16-1, using and-not and or-not packages.
(g) Package the 5-bit parallel adder of Fig. 16-1, using only or-not packages.

## 18-3. Phases and Block Diagram of the Pedagac

Outline of Phase Sequencing. A thorough understanding of Fig. 18-7 is basic to an understanding of the logical design of the Pedagac. The general plan is as follows: During phase 1 the instruction to be executed is read into the instruction register, and the decoding of the operation is performed. In this phase also, after the operation has been decoded, the current-address register is set to the address of the next instruction, either by advancing it 1 or in the case of a jump instruction by inserting in it the $\alpha$ address from the instruction register. The arithmetic, logical, and input and output operations involve the address $\alpha$ in the memory, so that for these operations phase 1 will be followed by an idling phase, which ends when address $\alpha$ has been located on the drum. (For a stop instruction the idle stop phase ISF is initiated. This phase is analogous to the other idle phases in that the computer does not perform any functions except marking time; this phase will continue until the run or start buttons are pushed.) When the coincidence signal, which indicates that address $\alpha$ has been found, ends the idling phase, the operation called for by the instruction is performed, during phase 2 or phase 3 . In phase 2 computation commences simultaneously with the reading of the second argument from address $\alpha$ into the adder-subtractor. Performing a typical arithmetic operation such as add consumes two phases: the memory selector phase IF2 and the computation phase $F 2$. The input or output instructions, however, require three phases, for, besides the idling phase (IFO or IFI) and the phase required to transfer the word between the drum and the buffer (FOO or FOI), a third phase (FBI or FBO) is needed for transferring the word between the buffer and the input or output equipment. After an instruction has been executed, the next instruction must be selected. The proper drum address is selected during IF1 (for the current-address counter already contains the address of this next instruction); the instruction is read into the instruction register during $F 1$, and the process continues as before.

Phase 1. At the start of phase 1 , (a) the instruction to be executed is read into the instruction register from the address on the drum held in the current-address counter (see Fig. 18-14). Thereafter during this phase the following functions are performed: (b) the operation is decoded in the operations decoder (see Fig. 18-14); (c) the control signals are generated by the operations signal generator (see Fig. 18-10); (d) the current-address counter is set to the address of the next instruction (see Fig. 18-14); and (e) the signal for the phase that should follow is produced in the phase generator (see Fig. 18-17).

The decoding and operations-signal generating functions take place


Fig. 18-7. Flow chart showing the sequencing of phases during the execution of ar instruction.
immediately after the instruction is read in. If the instruction is not a jump, the current-address counter is increased by 1 . If a jump is to be made, then the contents of the current-address counter is replaced by the $\alpha$ part of the instruction register. In the Pedagac the functions performed during phase 1 after the instruction register is loaded are each essentially performed as parallel operations and therefore consume only a few unit time intervals. During $T_{1-18}$ of phase 1 the instruction register is loaded; then during $T_{19-22}$ the other functions are performed. Updating the current-address counter is left until $T_{22}$ to ensure that a possible jump instruction will have been decoded.

When the instruction is a jump, normal or conditional, the entire operation (i.e., setting the current-address counter) is completed in phase 1 and $F 1$ is followed directly by the idling phase IF1 for the next instruction. If the instruction is one of the arithmetic or logical operations, which involve another argument in addition to the contents of the accumulator, phase IF2 will follow $F 1$. Of the phase 3 operations the computer need select an address only for the transfer instruction and in that case IF3 follows $F 1$. For the shift or clear instructions phase 3 follows directly after phase 1. For a stop instruction the idling phase ISF follows phase 1. For a read-out instruction a memory address must be selected, and so phase IFO follows phase 1; for read-in there follows phase FBI, in which a word is read into the buffer from the input unit.
phases IF1, IF2, IF3, IFO, and IFI. The appropriate drum sector is selected during these phases by the drum sector selector (see Fig. 18-15). The result of this selection process is the coincidence signal COI, which indicates that the drum has rotated to the proper word. Since it takes one minor cycle for each word in a channel to pass under the read-write head, the duration of these phases will be some integral number of minor cycles. For the Pedagac there are $2^{7}=128$ words in a channel, and the duration of such a phase can be as short as $1 \dagger$ or as long as 128 minor cycles. Then during the following phase ( $F 1, F 2, F 3$, FOO, and FOI, respectively) a channel is selected by the drum channel selector (see Fig. 18-15), and the word is transferred to or from the drum.
phases $F 2, F 3, \mathrm{FOO}$, and FOI. As we have seen, phase $F 2$ can be from 1 to 19 minor cycles in duration, depending on the operation. During the first of these minor cycles the selected word is read into the addersubtractor (see Figs. 18-11 to 18-13), and the operation is initiated. Addition, subtraction, and the four logical operations are completed in this first minor cycle; the others take 19 minor cycles each. At $T_{22}$ of the final minor cycle a signal OEP appears, which is generated in the operations signal generator (see Fig. 18-10) to initiate the following phase, IF1 (see the phase generator, Fig. 18-17). For the transfer instruction the coincidence signal ends IF3, opening the writing gates to the proper channel; phase 3 then lasts one minor cycle. For the clear and shift instructions no memory reference is made, and $F 3$ follows $F 1$ immediately.
$\dagger$ The (delayed) idling-phase signals are used to initiate the following operating phases, and hence each must last at least one minor cycle.

The clear instruction requires only one minor cycle; the shift requires two, the first to ensure that the contents of the accumulator will be complemented, if necessary, and the second for the shifting itself. During phases FOO and FOI one word is transferred between the drum and the buffer, with the buffer under the control of the computer.
phases ISF, FBI, and FBO. These are atypical phases. The ISF phase is an idling phase during which no functions are performed except time-interval and sector counting, i.e., during which the computer simply


Fig. 18-8. Detailed block diagram of the Pedagac.
and literally marks time. It can be initiated by the stop instruction or by the stop button; it can be ended by the run button or the start button. (See the discussions of the stop, start, and run buttons in Sec. 18-8.) This phase is used in debugging a program or adding additional data to a program or to initiate a manual read-out, etc. The FBI (or FBO) phase takes place when a word is to be read from (to) the input (output) unit to (from) the buffer (see Fig. 18-18). During these phases the input or output unit has control of the buffer shifting pulse. When the shifting has been completed, the computer must wait for the next $T_{0}$ before beginning the next phase, in order that the machine will remain synchronized with the drum.

Block Diagram of the Pedagac (see Fig. 18-8). The heart of a computer is the arithmetic unit; directly or indirectly, all other parts of the computer service the arithmetic unit. The unit-time-interval and minorcycle counters supply it directly with timing signals. The operations phase generator supplies it with phase pulses, in particular those of phases 2 and 3 during which it operates. The operations signal generator
supplies it with signals specific to the operation being performed. The drum sector selector and drum channel selector deliver to and receive from it the words that are being operated on. The current-address counter, the instruction register, and the instruction decoder are all needed to generate their various signals and may be thought of as indirectly servicing the arithmetic unit in this sense. Similarly the input-output unit, the in-out phase generator and buffer, and of course the memory are all necessary for the delivery and receipt of the words to be operated on and can therefore be considered as indirectly servicing the arithmetic unit.

The arithmetic unit generates one control signal that is used in the operations signal generator-the sign bit of the accumulator, used during a conditional jump instruction. Otherwise the operations signal generator receives most of its input signals from the instruction decoder and in a sense acts as the instruction-decoder output interpreter for the arithmetic unit. The operations phase generator also uses the outputs of the operations signal generator in determining phases. The operations phase generator in turn supplies the signal generator with signals used in forming the important instruction-ending pulse OEP and the conditional jump signal. The signal generator is also fed by the various counters.

The operations phase generator steps the computer through the proper phases. One phase signal, and only one, is on at all times when the computer is operating. A phase signal starts at $T_{0}$ of a given minor cycle and ends at $T_{22}$ of the same or some later minor cycle. In general the phases essentially sequence themselves; i.e., each phase signal is initiated by the termination of the previous phase signal. Since a phase signal begins in the next unit time interval after the previous phase signal ended, a phase signal must be delayed 1 unit of time before it enters the gate generating the next phase signal. In addition two other important phase-ending signals are supplied to the operations phase generator: OEP, generated by the operations signal generator, and COI, generated by the drum sector selector. The former determines the end of phase 2 or 3, while the latter determines the end of IF1, IF2, IF3, IFO, or IFI.

The drum channel selector receives its input directly from the currentaddress counter in phase 1 or from the instruction register in other phases. In the Pedagac there are $2^{5}=32$ channels, the gates to only one of which can be open at a time. By opening the proper gates a channel is selected directly. However, the proper sector, or word within a channel, is selected indirectly. The drum sector selector compares the sector counter with the current-address counter in phase IF1 or with the $\alpha$ part of the instruction register in other idling phases. When coincidence occurs, the word can be read out of (or into) the drum, starting immediately at the $T_{0}$ of coincidence. The coincidence signal COI does not open any gates directly, as do the signals generated by the channel selector; rather it simply steps the computer into the next phase, in which it reads into or from the drum. It is the signal for this
next phase that directly opens the proper gates--the gates to the arithmetic unit in $F 2$, from the arithmetic unit in $F 3$ (for transfer only), to the buffer in phase FOO, or from the buffer in phase FOI. In other words the channel selector opens the gate to the proper place or channel of the drum, but the sector selector, indirectly through the phase generator, opens the gates to or from the arithmetic unit or buffer at the proper time.

As noted above, besides supplying and receiving words the drum generates two signals, the clock pulses and the drum synchronizing pulse, which are considered again below in more detail.
Block Diagram of the Arithmetic Unit. In Fig. 18-9 the arithmetic unit has been divided arbitrarily into six sections. A combination addersubtractor is used, and hence the adder-subtractor control generator is


Fig. 18-9. Block diagram of the arithmetic unit.
needed. During multiplication or division the icand register is intimately associated with the adder-subtractor, since it holds the multiplicand or the divisor. Besides receiving input words directly from the memory and the icand register, the adder-subtractor receives words from the recirculation of the accumulator (through the output subtractive complementer) and from the ier register. The word from the ier register is the minor product or the quotient; it is recirculated through the adder when it must be transferred to the accumulator as the final result. Similarly there is a recirculation through the adder during a shift instruction and a transfer instruction. Hence the input gating to the adder becomes somewhat formidable.

Further complexity is added by the different shifting requirements of the various instructions and by the necessity for overflow determination. The sign generators, one for addition and subtraction and one for multiplication and division, are complicated by the zero sensor and the sign holder, and by the need for the sign-of-partial-dividend generator.

The accumulator feeds directly into the output subtractive complementer. The output of the complementer may be sent to the memory through the drum-address-selector unit; or within the arithmetic unit it may go to the adder-subtractor or, when multiplication is initiated, to the ier register. During multiplication the partial-product bits are
sent from the complementer to the ier register as they are generated, and the ier register supplies bits to the multiplier control-signal generator. During division the ier register receives the partial-quotient bits from the second stage of the accumulator.

Besides its receiving external control signals, some of the arithmetic unit's control signals are generated internally. These are indicated by the hollow-headed arrows between the boxes of the block diagram. The adder-subtractor receives the sign of the accumulator as a control signal during addition or subtraction; it also receives the multiplier control signal from the ier register (indirectly). The sign generators and the complementer receive the overflow as a control signal. In the zero sensor the result of an operation is used as a signal.

## EXERCISES

(a) Trace on Fig. 18-7 the phases involved in the execution of each of the 17 instructions of the Pedagac.
(b) Trace the phases involved if the stop button is pushed, and then the run button; the stop button, and then the start button.
(c) Trace the phases involved if a stop instruction is executed and then the run button is pushed; if then the start button is pushed.

From the logical diagrams associated with each of the boxes of Fig. 18-8, determine:
(d) Precisely what pulses are received by the arithmetic unit from each source indicated.
(e) Precisely what pulses are received by the counters from each source indicated.
(f) Precisely what pulses are received by the current-address counter and instruction register.
(g) Precisely what pulses are received by the operations signal generator.
(h) Precisely what pulses are received by the operations phase generator.
(i) Precisely what pulses are received by the channel and sector selectors.
(j) Precisely what pulses are received by the in-out phase generator and buffer.
(k) Precisely what pulses are received by the input and output units.
(l) During what phases are each of the boxes of Fig. 18-8 functioning?
( $m$ ) The solid arrows in Fig. 18-9 indicate the flow of words between the boxes of the arithmetic unit. What word does each arrow represent, and during what operation does such a word flow?

## 18-4. Operations Signal Generator

The operations signal generator of the Pedagac generates 5 trivial and 19 nontrivial signals. In essence these signals tell the arithmetic unit what time period of a phase the computer is passing through and hence direct the unit in initiating, ending, and changing its various operations.

A description of each output signal of the generator is given in the Appendix. The composition of each signal is best shown by its logical diagram, all of which are given in Fig. 18-10. The exercises below are to be used as a guide to understanding the figure. A detailed analysis of the operations signal generator might be postponed until the arithmetic unit has been studied. However, during his study of that unit the
student will need to know the general functions of the operations signals to understand why they are inputs to the various packages of the unit.

The operations signals can be classified broadly into four categories: First are signals which remain on throughout an operation and which serve to distinguish among the operations, namely, ADD, SUB, MDS,

Table 18-1. Operations Signals and Thlir Durations for Each Instruction

| Operation and decode signal | Category I, operationdetermining signals | Category II, minor-cycledetermining signals |  | Category III, unit-time-intervaldetermining signals |  | $\begin{aligned} & \text { Category } \\ & \text { IV, } \\ & \text { OEP } \end{aligned}$ | Phase |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Signal | Minor cycle | Signal | Time intervals | Time |  |
| Addition, 53D. <br> Subtraction, 54D <br> Major multiplication, 42D. | $\begin{aligned} & \mathrm{ADD}=53 D \\ & \mathrm{SUB}=54 D \\ & \mathrm{MDS} \\ & \mathrm{PQS} \end{aligned}$ | MMI | $\begin{array}{r} \dagger \\ \dagger \\ T^{19} \end{array}$ | $\ldots$ | ....... | $\begin{aligned} & T_{22^{1}} \\ & T_{22^{1}} \end{aligned}$ | $F 2$ |
|  |  |  |  |  |  |  | F2 |
|  |  |  |  |  |  | $T_{22^{19}}$ | $F 2$ |
|  |  |  | $T^{T^{-18}}$ | MCS | $T_{1-18}$ |  |  |
|  |  |  | $T^{1-18}$ | PQC | $T_{1-18}$ |  |  |
| Minor multiplication, 32D.... | $\begin{aligned} & \text { MDS } \\ & \text { PQS } \end{aligned}$ | $\ldots$ | $T^{19}$ | PQT <br> MCS <br> PQC | $\begin{aligned} & T_{1-18} \\ & T_{1-18} \\ & T_{1-18} \end{aligned}$ | $T_{22}{ }^{19}$ | F2 |
|  |  |  | $T^{1-18}$ |  |  |  |  |
|  |  |  | $T^{1-18}$ |  |  |  |  |
| Division, 42D. | PQS | DDS | $T^{1-18}$ | DRI | ${ }_{T} \ldots \ldots$. | $T_{22}{ }^{19}$ | F2 |
|  |  |  |  |  |  |  |  |
|  |  |  | $T^{19}$ | PQT | $T_{1-18}$ |  |  |
|  |  |  | $T^{1-18}$ | DCS | $T_{1-18}$ |  |  |
|  |  |  | T ${ }^{1-18}$ | PQC | $T_{1-18}$ |  |  |
| Logical multiplication, $71 \mathrm{D} . .$. | LDS (LMS) | $\ldots$ | $\dagger$ | LMS | $T_{1-18}$ | $T_{22}{ }^{1}$ | F2 |
| Logical addition, 72D.. | LDS (LAS) | …$\cdots \cdots$$\cdots \cdots$ | $\dagger$ | $\begin{aligned} & \text { LAS } \\ & \text { LES } \end{aligned}$ | $T_{1-18}$ | $T_{22^{1}}$ | F2 |
| Logical equivalence, 73D... | LDS (LES) <br> LDS (LIS) |  | $\dagger$ |  | $T_{1-18}$ | $T_{22^{1}}$ | $F 2$$F 2$ |
| Logical nonequivalence, 74D... |  | $\cdots$. | $\dagger$ | LIS | $T_{1-18}$ | $T_{22}{ }^{1}$ |  |
| Shift, 70D. | SHS $=70 \mathrm{D}$ | $\ldots$ | $T^{2}$ | SIC | $\begin{aligned} & \mathrm{As} \\ & \text { required } \\ & \text { As } \\ & \text { required } \end{aligned}$ | $T_{22}{ }^{2}$ | F3 |
|  |  |  |  |  |  |  |  |
|  |  |  | $T^{2}$ | SCC |  |  |  |
|  |  |  |  |  |  |  |  |
| Clear, 50D.. | CLS $=50 \mathrm{D}$ |  | $\dagger$ |  |  | $T_{22}{ }^{1}$ | F3 |
| Transfer, 52D. | TRS $=52 \mathrm{D}$ |  | $\dagger$ |  |  | $T_{22}{ }^{1}$ | F3 |
| Jump, 44D.................. | (JCS) |  | $\dagger$ | JCS | $T_{22}$ | .... | $F 1$ |
| Conditional jump, 43D....... | $\begin{aligned} & \text { (JCS if SOB } \\ & \text { is } 0 \text { ) } \end{aligned}$ |  | $\dagger$ | JCS | $T_{22}$ | $\ldots$ | $F 1$ |

$\dagger$ Single minor-cycle instructions.
PQS, LDS, SHS, CLS, and TRS. Of these, three are on during more than one operation, MDS, PQS, and LDS. Second are signals that distinguish among the minor cycles within a phase, namely, MMI and DDS. Third are signals that distinguish among the unit time intervals withix a minor cycle, namely, ASC, MCS, PQC, PQT, DRI, DCS, LMS, LAS, LES, LIS, SIC, SCC, and JCS. The five signals JCS, LMS, LAS, LES, and LIS also serve to distinguish among the operations, as did the signals of the first category (in Table 18-1 these signals are therefore entered


Fig. 18-10. Logical design of

the operations signal generator.
parenthetically in the "Category I" column). Signals MCS, PQC, PQT, DCS, SIC, and SCC are not on during every minor cycle of an operation and hence serve to distinguish among minor cycles, as did the signals of the second category (the minor cycles during which these signals are on are thus entered under the "Category II" column). Alone in the fourth category is the operations-ending pulse OEP. Table 18-1 shows the operations signals that are on during each instruction, and their durations.

The most complicated of the operations signals, the shift signals SIC and SCC, deserve a further word. During $T^{1}$ of the shift instruction while the contents of the accumulator is recirculating for complementation, the number of places to be shifted is held as the $\alpha$ address of the instruction register. During $T^{2}$, starting at $T_{5}{ }^{2}$, the countdown is made until all zeros are obtained; then the shift inhibit control signal SIC is initiated. Signal SIC in turn initiates SCC (in package GSCC of Fig. 18-10), which performs the actual shift control function.

## EXERCISES

(a) Discuss the functions of packages GASC, GMMI, GPQT, and GPQC.
(b) Describe the operation of the package GOEP. Give the function of each gate in detail.
(c) In package GMCS why is $\bar{T}_{19}$ used in the recirculation gate?
(d) Why does package GOEP include as inputs signals $F 2$ and $F 3$, whereas they do not appear as input signals to the other external signal-generating packages?
(e) The external control signals are used in the arithmetic unit only during phases $\overline{2}$ and $\overline{0}$. Winy inen are iney generaied during phase $\bar{i}$ in audiiion io phases 2 and 3 :
(f) Explain the operation of packages GLDS, GPQS, and GMDS.
(g) How does SCC control the shift instruction in the arithmetic unit during $T^{1}$ and $T^{2}$ ?

## 18-5. Arithmetic Unit: Vertical Description

This section gives the function of each input gate of each package of the arithmetic unit, in the form of an extended outline. It is not specifically intended that this be read before the horizontal description. The vertical description is intended rather to be used with Table 18-1 and the logical diagrams of Figs. $18-11$ to $18-13$ as reference material as the student follows the paths of the bits in the horizontal description. The reader is cautioned, however, that he will not understand the arithmetic unit fully until he understands both this section and the next and that, though he might postpone working the exercises below until after the next section has been examined, he should not therefore neglect them entirely.

The vertical description of the arithmetic unit (see Figs. 18-11 to 18-13, pages 596 to 600 ) is as follows:
( $\alpha$ ) Sign sensor SOAH
Gate 1 loads the sign of $(\alpha)$ at $T_{0}{ }^{1}$ of F2.
Gate 2 holds the sign of ( $\alpha$ ) until OEP.
Adder-subtractor control generator ASCG
Gates 1, 2, 3, and 4 form the appropriate sum or difference control signal for the add and subtract instructions. For multiplication we sum all the time, and gate 5 forces OPS on. For division we difference all the time; so all gates are inhibited with DDS.

Adder-subtractor ( $\alpha$ ) input package ASAI
Gate 1 allows ( $\alpha$ ) to enter the adder during addition, subtraction, the four logical instructions, and the first minor cycle $T^{1}$ of division, i.e., not during multiplication.

Gate 2 allows (icand) to enter the adder for division $T^{2-18}$. ( $\bar{T}_{0}$ is not needed since DCS can be on only during $T_{1-18}$, during division.)
Gate 3 allows ( $\alpha$ ) to enter the adder gated with MUS during $T^{11}$ of multiplication. (Like DCS above, MCS is off at $T_{0}$.)
Gate 4 allows (icand) to enter the adder gated with MUS during $T^{2-18}$ of multiplication.

Adder-subtractor $B$ input package ASBI
Gate 1 allows (acc) to enter the adder during phase 2 of addition, subtraction, and the four logical instructions (not during multiplication and division).
Gate 2 recirculates (acc) during $T^{1}$ of phase 3 of the shift and transfer; it forces (acc) to zero during phase 3 of clear. During $T^{2}$ of the shift, $T^{11}$ 's being off prevents the full-length recirculation of (acc).
Gate 3 allows $2 N^{i}$ to go into adder during division $T^{1-18}$.
Gate 4 passes (acc) into the adder during $T^{2-18}$ of multiplication [because $T^{1}$ in multiplication concerns only ( $\alpha$ )].
Gate 5 passes the minor product or quotient from the ier register into the accumulator during $T^{19}$ (the PQT signal).

Stage 1 of the icand register, S1IR
Gate 1 loads icand initially (during $T^{1}$ of $F 2$ ) in division or multiplication.
Gate 2 recirculates (icand) during $T^{12-18}$ of multiplication and division.
Gate 3 holds the bit until shifted, during $T_{19}-T_{0}$ of the appropriate minor cycles.

Stage $n$ of the icand register, $\mathrm{S} n \mathrm{IR}$ (S2IR is shown as an example)
Gate 1 receives bit from $\mathrm{S}(n-1)$ IR during shifting.
Gate 2 holds the bit until shifted.
Input to carry former ITCF (see Sec. 15-3)
Gate 1 passes $B^{\prime}$ to form sum ( $\mathrm{OPS}=1$ ).
Gate 2 passes $\bar{B}^{\prime}$ to form difference ( $\mathrm{OPS}=0$ ).

Gate 3 passes $\bar{B}^{\prime}$ during logical multiplication and addition, since for these operations the result is the additive carry $C^{\prime}$ (with the $C$ input to the carry former appropriately constant).

Carry input to adder-subtractor CIAS (see Sec. 15-3)
Gate 1 forms the carry input ( $C \equiv 1$ ) for logical addition and equivalence.
Gate 2 inhibits the delayed carry for logical multiplication and inequivalence ( $C \equiv 0$ ) but otherwise passes the regular carry.

Adder-subtractor result former ASRF
Gates $1,2,3$, and 4 form the sum-difference result (see Sec. 15-3).
Adder-subtractor carry former ASCF
Gates 1, 2, and 3 form the carry (see Sec. 15-3).
Result zero-detector generator RZDG
Gate 1 loads the result from the adder.
Gate 2 holds any unit found in the result until the next $T_{0}$.
Add-subtract sign generator ASSG
Gates 1 and 2 form the sign for addition and subtraction.
Gate 3 ensures a positive sign if the result is zero.
Product-quotient sign generator PQSG
Gates 1 and 2 form the sign of the product or quotient.
Gate 3 ensures a positive sign if the result is zero.
Sign of partial-dividend generator SPDG
Gate 1 forces SOD positive during $T^{1}$.
Gates 2 and 3 form the signs of the partial dividends during $T^{1-18}$.
Gate 4 ensures a positive sign if a partial dividend is zero.
Gate 5 holds SOD until the next sign is formed at $T_{21}$.
Sign of $B$ holder SOBH
Gate 1 loads the sign of the $a d d$ and subtract instruction result $B$.
Gate 2 loads the sign of the multiplication and division instruction result $B$.
Gate 3 holds the sign of $B$ for the nonarithmetic instructions.
Gate 4 ensures a positive sign when the accumulator is cleared.
Gate 5 holds the sign of $B$ during the arithmetic operations until the new sign is formed at OEP.

Accumulator-shift pulse signal generator ASPS
Gate 1 shifts the accumulator at each clock pulse except $T_{0}$ during every minor cycle of phase 2 , except the 19th minor cycle of major multiplication.
Gate 2 shifts the accumulator during the transfer and clear instruction, except at $T_{0}$.
Gates 3 and 4 shift the accumulator during $T^{1}$ and $T^{2}$ of the shift instruction, as directed by SCC from shift sensor (see Exercise $t$ ).

Gate 5 shifts the accumulator during first pulse period ( $T_{0}$ ) of each minor cycle of both multiplication instructions.

Stage 1 of the accumulator register S1AR
Gate 1 reads the result from the adder into the accumulator, except for logical multiplication and addition.
Gate 2 reads the additive carry into the accumulator as the result for the logical addition and multiplication instructions (see Sec. 15-3).
Gate 3 holds the bit until shifted.
Stage 5 of accumulator register S5AR
Gate 1 passes the shortened contents of the accumulator during $T^{2}$ of the shift instruction.
Gate 2 loads the signal from $P 4$ during $T^{1}$ of the shift instruction.
Gate 3 loads the signal from $P 4$ except during the shift instruction.
Gate 4 holds the bit until shifted.
Overflow holder OFLH
Gate 1 loads the overflow holder at each $T_{0}$.
Gate 2 holds the bit until the next $T_{0}$.
Output-complementer carry former OCCF (see Sec. 15-3)
Gates 1 and 2 form the carry for the complementer (see Exercise cc).
Output-complementer result former OCRF (see Sec. 15-3)
Gates 1,2 , and 3 form the result of the subtractive complementation (see Exercise $d d$ ).

Multiplier control signal generator MUSG
Gate 1 forms the multiplier control signal from $P 1$ of (acc) during $T^{1}$.
Gate 2 forms multiplier control signal from $P 1$ of (ier) during $T^{2-18}$.
Gate 3 holds the bit until the next minor cycle.
Ier-shift pulse signal generator ISPS
Gate 1 shifts the contents of accumulator into the ier register during $T^{1}$ of the multiplication instructions.
Gate 2 shifts in minor product bits during $T^{2-19}$ of the multiplication instructions.
Gate 3 shifts for the recirculation of (ier) during the division instruction.
Gate 4 shifts (ier) out to the accumulator during $T^{19}$ of minor multiplication and division.

Stage 1 of the ier register S1ER
Gate 1 loads the contents of accumulator into the ier register (see Exercise hh).
Gate 2 loads the least significant bit of the accumulator into the ier register (see Exercise ii).
Gate 3 recirculates (ier) during division.
Gate 4 holds the bit.

Stage 18 of the ier register S18ER
Gate 1 loads each quotient bit.
Gate 2 passes the normal output from stage 17 during normal shifting.
Gate 3 recirculates the contents of stage 18 during the division instruction.
Gate 4 recirculates the contents of stage 18 during instructions other than division.

## EXERCISES

(a) In package ASAI gate 1 , under what conditions will ( $\alpha$ ) enter the adder?
(b) For the clear instruction why is input CLS necessary only in gate 2 of package ASBI?
(c) How would the inputs to gate 2 of package ASAI be modified if DCS were replaced by DDS?
(d) Compare the functions of packages SOBH and SOAH.
(e) Explain the operation of the adder-subtractor control package ASCG during division.
(f) Explain the operation of package ASAI and ASBI during the transfer instruction.
(g) What occurs in each gate of packages ASAI and ASBI during phase 1?
(h) Explain the purpose of input $\overline{\mathrm{PQS}}$ to gate 1 of package ASBI.
(i) What are the functions of the $\overline{T^{1}}$ inputs to gates 2 and 4 of package ASAI and to gate 2 of package S1IR?
(j) What is the function of gate 3, package S1IR? When does the package act to store a bit?
( $k$ ) How is $B^{\prime}$ forced through package ITCF for logical multiplication and addition? Why is $F 2$ necessary at gate 2 but not at gate 1 ?
( $l$ ) How are the special cases of $C$ formed for the logical instructions?
( $m$ ) Show one condition in which $T_{0}$ is essential to the proper operation of the adder-subtractor result former.
( $n$ ) Explain the purpose of $T_{0}$ in package ASCF.
(o) Describe the operation of packages ASRF and ASCF during the transfer and shift instructions.
(p) What is the purpose of the $\overline{\mathrm{LES}}$ and $\overline{\mathrm{LIS}}$ signals of gate 2, package S1AR?
(q) What is the purpose of the LDS and $\overline{\mathrm{LDS}}$ signals of package CIAS?
(r) The countdown for the shift instruction starts at $T_{5}$. How is this arranged for in the logical design? (Hint: See packages ASPS and GSCC.) Describe the operation of package S5AR during a shift instruction.
(s) In package ASPS why are the inputs SHS and $F 3$ used in gates 2,3 , and 4 ?
( $t$ ) Describe the functions of gates 3 and 4 of package ASPS.
(u) Why can the zero detector be on during every minor cycle?
(v) Under what conditions is gate 3 of package ASSG essential?
(w) Why is a separate package SPDG necessary, in addition to package ASSG?
( $x$ ) Why must SOD of package SPDG be forced positive during $T^{1}$ of the division instruction (gate 1)?
(y) Why is recirculation necessary for package SPDG and not for package ASSG?
(z) What are the functions of gates 3 and 5 of package SOBH, and why are the two used instead of one?
(aa) Why is the sign of $B$ held?
(bb) Why must OF be held in package OFLH?
(cc) Construct a vertical description of package OCCF.
(dd) Construct a vertical description of package OCRT. Why is neither OF nor $\overline{\mathrm{OF}}$ an input to gate 2 ?
(ee) In package MUSG why are both gates 1 and 2 necessary?
(ff) Why must signal MUS be held in package MUSG?
(gg) What is the purpose of the $T_{1-17}$ input to gate 3 of package ISPS?
( $h \mathrm{~h}$ ) When is gate 1 of package S1ER used?
(ii) When is gate 2 of package S1ER used?
( $j$ j) What happens to the least significant bit of the ier register during $T^{2-18}$ of multiplication?
(kk) In gate 3 of package S18ER why are both $\bar{T}_{21}$ and $\overline{\text { SPI necessary? }}$
(ll) Why are both gates 3 and 4 necessary in package S18ER?
( mm ) Redesign the ier register so as to read the quotient bits into stage 1 instead of into stage 18. Include any additional changes in the computer, including generators for any additional control signals required.

## 18-6. Arithmetic Unit: Horizontal Description

Phase 1 of All Instructions. During phase 1 the next instruction is being read into the instruction register and decoded, etc. The arithmetic unit idles. The accumulator holds the result of the last operation; the icand register, the multiplicand of the last multiplication or the divisor of the last division; and the ier register, the minor product of the last major multiplication, unless it has been cleared by a minor multiplication or a division. (Since the icand and ier registers are cleared before they are reused, their contents are noted but hereafter ignored.) The sign of the accumulator is held in package SOBH, but package SOAH (holds the sign of the $\alpha$ operand) has been cleared at the end of the last operation. The zero detector was cleared after SOB was formed, but package OFLH will hold a bit if there was an overflow into the second stage of the accumulator (as the result of a differencing with a larger subtrahend). The input gates to the arithmetic unit will all be closed.

Addition and Subtraction Instructions. At $T_{0}{ }^{1}$ of phase 2 the sign of ( $\alpha$ ) is fed from package GMO $\alpha$ in the memory selection unit to the sign-of- $\alpha$ holder (package SOAH). The signals SOA and SOB along with signal ADD for addition or SUB for subtraction form signal OPS in package ASCG. OPS is fed to package ITCF, where it determines whether the sum or difference will be generated (see Sec. 15-5).

During $T_{1}{ }^{1}$ the least significant bit of ( $\alpha$ ) and the least significant bit of (acc), which will have been complemented if signal OF is present, are passed through the adder-subtractor input packages ASAI and ASBI. In package ITCF the input to the adder-subtractor carry generator is formed by gating signals $B^{\prime}$ (from package ASBI) and OPS as follows: $B^{\prime} \cdot$ OPS $+\bar{B}^{\prime} \cdot \overline{\text { OPS }}$ (Sec. 15-3). The outputs of packages ITCF, ASAI, ASBI, and CIAS are fed to ASCF, where the carry is formed. The output of package ASCF is delayed one unit time interval and fed back to package CIAS (which passes it during all arithmetic operations).


Fig. 18-11. Logical design of the arithmetic

register

unit: adder-subtractor and icand register.

To ASCG and GJCS


Fig. 18-12. Logical diagram of the arithmetic

register
unit: sign generator and accumulator.


Fig. 18-13. Logical diagram of the arithmetic unit: output complementer and ier register.

Since there is no previous carry during $T_{1}$, the least significant bit of ( $\alpha$ ) is gated with the least significant bit of (acc) in package ASRF to form the result $R$. Signal $R$ is fed to stage 1 of the accumulator (package S1AR) as well as to the zero detector (package RZDG).

During $T_{2}$ the next to least significant bits of ( $\alpha$ ) and (acc), with the carry formed during $T_{1}$, are fed to packages ASRF and ASCF, following the same path as the least significant bit. Again the output to package ASRF is fed to packages S1AR and RZDG, and the output of package ASCF is fed to package CIAS. Also during this unit time interval the (acc) is shifted one bit position to the right, thereby placing the least significant bit of the result in stage 2 of the accumulator.

This process continues for an additional 16 unit time intervals. At $T_{18}$ the most significant bit of the result is formed, with a possible carry. A carry at $T_{18}$ may be due either to an overflow in summing (i.e., a result greater than 1) or to an overlarge subtrahend in differencing. During $T_{19-22}$ the $A$ and $B$ inputs are zero, and the result $R$ is determined solely by $C$. Signal $R$ from package ASRF continues to be fed to packages S1AR and RZDG until $T_{22}$. At $T_{22}$ package GOEP forms signal OEP, which gates the sign of the result, formed in package ASSG, into package SOBH and concurrently kills the recirculation of signal SOA in package SOAH. Signal OEP also acts as an operation-ending pulse causing the machine to end the arithmetic operation and move on to phase IF1.

Multiplication Instructions. During $T_{0}{ }^{1}$ of phase 2 the sign of ( $\alpha$ ) is fed from package $\mathrm{GMO} \alpha$ to package SOAH, where it is stored. Operation signal MDS at gate 5 of package ASCG keeps signal OPS on until the end of the phase, and the adder-subtractor thus acts as an adder throughout this instruction. During $T_{1}$ the least significant bit of (acc) is sent through the output complementer (complemented if signal OF is present) to gate 1 of package MUSG and stage 1 of the ier register (gate 1 of package S1ER). Simultaneously signal $B$ is gated with signal MDS in package MUSG to form the multiplier signal MUS. This signal is held throughout the minor cycle by recirculation through gate 2 of MUSG. Also during $T_{1}{ }^{1}$ the least significant bit of ( $\alpha$ ) is passed into the icand register through gate 1 of package S1IR and fed to gate 3 of package ASAI. In that package it is gated with signal MUS such that $(\alpha)$ is allowed to enter the adder only if MUS is on. Then ( $\alpha$ ) (if MUS is present) and (acc) arefe $d$ to the adder-subtractor through packages ASRF, ITCF, and ASCF. In package ASRF the result of addition is formed, and in package ASCF the carry into the bit position is formed. The output of package ASRF is fed to the first stage of the accumulator, through gate 1 of package S1AR, and to the zero detector, package RZDG. The output of package ASCF is delayed by one unit time interval and fed into package CIAS, which passes it on to packages ASRF and ASCF to be combined with the next bits of ( $\alpha$ ) and (acc). During $T_{2}$ the second least significant bit of (acc) is fed to stage 1 of the ier register, as the least significant bit of (acc) previously stored there is
shifted one position. The second least significant bit of ( $\alpha$ ) is fed simultaneously, through the same paths as the least significant bit, to stage 1 of the icand register, the least significant bit being shifted once to make room for it, and to package ASAI, where it is gated with the MUS signal. During $T_{3-18}$ the remainder ( $\alpha$ ) and (acc) follow the same paths, forming the first partial product in the accumulator and storing the multiplier [the original (acc)] in the ier register. At $T_{19}$ the carry generated in $T_{18}$, if there was one, will be fed to the accumulator via the adder as the accumulator is shifted one position. During $T_{20-22}$ the accumulator will be shifted three positions, so that the least significant bit of the partial product (which is in fact the least significant bit of the minor product) will be in the least significant position of that register.

During $T_{0}{ }^{2}$ this least significant bit will be transferred out of the accumulator into gate 2 of package S1ER of the ier register, as the ier register is shifted one position to receive it. The least significant bit of the multiplier is thus "spilled over," and the second least significant bit assumes the end position of the register. During $T_{1}{ }^{2}$ this bit is fed to gate 2 of package MUSG, where the multiplier signal for the second minor cycle is generated. During this time interval the least significant bits of the accumulator and the icand register will be fed to the addersubtractor input packages. The least significant bit of the icand register will also be fed back into the icand register through gate 2 of package S1IR. The flow of the operands through the adder-subtractor during this minor cycle will proceed as described for the first minor cycle.

This procedure will continue for a total of 18 minor cycles, to complete the muliphication. Ait the end of the iobin minor cycle the major product, and the most significant bit of the minor product, will be in the accumulator; the rest of the minor product, with the most significant bit of the original (acc), will be in the ier register.

For either major or minor multiplication (instruction 42 or 32 ), the most significant minor-product bit will be transferred at $T_{0}{ }^{19}$ into the ier register as that last bit from the multiplier is spilled over from ier stage 18. If the instruction is minor multiplication, then at $T_{1}{ }^{19}$ the least significant bit of the minor product, stored in package S18ER, will be transferred to the most significant position of the accumulator, through gate 5 of package ASBI, gate 2 of package ASRF, and finally gate 1 of package $S 1 A R$, as the least significant bit of the major product is spilled over from the end of the accumulator. This process continues for an additional 17 unit time intervals, at the end of which the complete minor product will have been transferred to the accumulator. During $T_{19-22}^{19}$ the accumulator is shifted four more positions, to place the least significant bit of the minor product in the least-significant-bit position of the accumulator. If the instruction is major multiplication, the major product is left in the accumulator and the minor product in the ier register, with the machine idling for $T_{1-21}^{19}$. At $T_{22}{ }^{19}$ of either operation signal OEP comes on, gating the product's sign, which has been generated in package PQSG , into gate 2 of package SOBH , and killing the recircula-
tion of signal SOA in package SOAH. Signal OEP also acts as an opera-tions-ending pulse, causing the machine to move on to phase IF1.

Division Instruction. During $T_{0}{ }^{1}$ of phase 2 the sign of $(\alpha)$ is fed from package $\mathrm{GMO} \alpha$ to gate 1 of package SOAH. Operation signal DDS is fed to all gates of package ASCG to inhibit signal OPS. (The absence of signal OPS will cause the adder-subtractor to form the difference throughout this instruction; see Sec. 15-6.) Signal DDS is also fed to gate 1 of package SPDG, where it acts as a primer to set the sign of the partial difference (SOD) positive initially. During $T_{1}{ }^{1}$ the least significant bit of the accumulator is sent through the output complementer (complemented if signal OF is present), then into gate 3 of package ASBI, delayed by one pulse period to form $B^{\prime}$ (see Sec. 15-6). Also during $T_{1}{ }^{1}$ the least significant bit of ( $\alpha$ ) is passed into the icand register through gate 1 of package S1IR and through gate 1 of package ASAI into the adder-subtractor. Since package OCRF of the complementer was cut off at $T_{0}$, the $B^{\prime}$ input to the adder-subtractor will be zero at $T_{1}$. In package ASRF the first bit of $2(\mathrm{acc})-(\alpha)=B^{\prime}-A$ is formed as package ASCF forms the carry into the next position, which is delayed and fed into package CIAS. The result of the subtraction, signal $R$, is fed to the zero detector, package RZDG, and to the first stage of the accumulator, package S1AR. At $T_{2}{ }^{1}$ the second least significant bit of the original (acc) is routed through the same path as the least significant bit. As the second least significant bit of ( $\alpha$ ) is fed to the adder-subtractor and stage 1 of the icand register, the least significant bit of ( $\alpha$ ) is shifted to stage 2. In the adder-subtractor this bit is combined with the carry from $T_{1}{ }^{1}$, and with the delayed least significant bit of the original (acc), to form the second bit of $2(\mathrm{acc})-(\alpha)$. This second bit is fed to the zero detector and to stage 1 of the accumulator, as the first bit is shifted to stage 2. The carry formed during $T_{2}$ is delayed and sent to the carry input package CIAS. This process continues through $T_{18}$, at which time ( $\alpha$ ) will have been transferred to the icand register and the first 18 bits of the first partial dividend will have been formed and stored in the 18 most significant bit positions of the accumulator. At $T_{19}$ any carry generated in $T_{18}$ will be fed to the (shifted) accumulator through the adder-subtractor. Such a carry, indicating that 2(acc) - $(\alpha)<0$, will be propagated until $T_{22}$ (see Sec. $15-6$ ). At $T_{21}{ }^{1}$ the output of stage 2 of the accumulator (signal OFR) is gated with signal SOD in package SPDG to form the new SOD. This new SOD is fed to gate 1 of package S18ER, where it is stored temporarily as the most significant bit of the quotient.

During $T_{1-17}^{2}$ the most significant bit of the quotient which is stored in S18ER is shifted 17 positions circularly, to package S17ER. The generation of the next most significant bit of the quotient is formed in the same way as the most significant bit, except that $(\alpha)=$ (icand) is fed into the subtractor, through gate 2 of package ASAI, and is subtracted from the absolute value of (acc).

This process continues for an additional 16 minor cycles, at the end
of which we shall have formed the 18 most significant bits of the quotient, which are stored in the ier register.

At $T_{1}{ }^{19}$ the least significant bit of the quotient which is held in package S18ER will be transferred to the most-significant-bit position of the accumulator by way of gate 5 of package ASBI, then to gate 2 of package ASRF, and finally to gate 1 of package S1AR. This process continues for an additional 17 unit time intervals, at the end of which time the quotient will have been transferred to the accumulator. During $T_{19-22}^{19}$ the accumulator is shifted four positions, so that the least significant bit of the quotient is in the least significant position of the accumulator. Also at $T_{22}{ }^{19}$ signal OEP comes on, gating the sign of the quotient (generated in package PQSG) into gate 2 of package SOBH and killing the recirculation of signal SOA in package SOAH. Signal OEP also acts as an operation-ending pulse, causing the machine to move on to phase IF1.

Logical Instructions. During $T_{0}{ }^{1}$ of phase 2 of any logical instruction the sign of $(\alpha)$ is fed from package $\mathrm{GMO} \alpha$ to package SOAH. (This action will not have any effect on the logical instructions.)

In the logical-addition instruction, during $T_{1}$ the least significant bit of ( $\alpha$ ) is fed through gate 1 of package ASAI to package ASCF; the corresponding bit of (acc) (complemented if OF is present) is fed through gate 1 of package ASBI to package ITCF. Gate 3 of package ITCF allows (acc) to be fed to package ASCF. At the same time the carry input is held on by signal LDS at gate 1 of package CIAS. Then the outputs of packages ASAI, ITCF, and CIAS are gated together in package $\dot{A} \dot{S} \dot{C} \bar{F}$ to form the result of the logical addition, signal $C^{\prime \prime}$ (see Sec. 15-3) This signal is fed to the necumulator through gate 2 of pankage S1AR. This process continues until the most significant bit of the logical addition is formed at $T_{18}$. The sign of the result is SOB, the sign of the original (acc), recirculating through gate 3 of package SOBH. During $T_{19-22}$ the accumulator is shifted four positions, so that the least significant bit of the result is in the least significant position of the accumulator. At $T_{22}$ signal OEP comes on, ending the logical operation, inhibiting the recirculation of signal SOA in package SOAH, and moving the machine into phase IF1.

In the logical-multiplication instruction, during $T_{1}(\alpha)$ is started through gate 1 of package ASAI to package ASCF, and (acc) (complemented if signal OF is present) is started through gate 1 of package ASBI to package ITCF. Gate 3 of package ITCF allows (acc) to enter package ASCF. Signals $\overline{\mathrm{LMS}}$ and $\overline{\mathrm{LDS}}$ in gates 1 and 2 of package CIAS inhibit $C$ (see Sec. 15-3). In gate 3 of package ASCF, $(\alpha)$ and (acc) are gated together to form the result of logical multiplication, signal $C^{\prime}$. This signal is fed to the accumulator through gate 2 of package SIAR. This procedure continues until the most significant bit of the logical multiplication has been formed at $T_{18}$. The operation during $T_{19-22}$ is identical to that in logical addition.

In the logical-equivalence instruction, during $T_{1-18}(\alpha)$ is fed through
gate 1 of package ASAI to package ASRF, and (acc) (complemented if signal OF is present) is fed through gate 1 of package ASBI to package ASRF. The carry input is held on during this minor cycle by signal LDS at gate 1 of package CIAS (see Sec. 15-3). Signals $A, B^{\prime}$, and $C$ are combined in gates 3 and 4 of package ASRF to form the logical equivalence result, signal $R$. This result is fed to the accumulator through gate 1 of package S1AR. This process continues until the most significant bit of the logical equivalence is formed at $T_{18}$. The operation during $T_{19-22}$ is identical to that in logical addition.

In the logical-inequivalence instruction, during $T_{1-18}(\alpha)$ is fed through gate 1 of package ASAI to package ASRF, and (acc) (complemented if signal OF is present) is fed through gate 1 of package ASBI to package ASRF. Signals $\overline{\mathrm{LIS}}$ and $\overline{\mathrm{LDS}}$ in gates 1 and 2 of package CIAS inhibit $C$ (see Sec. 15-3). Then signals $A$ and $B^{\prime}$ are gated together in gates 1 and 2 of package ASRF to form the logical inequivalence result, signal $R$. This result is fed to the accumulator through gate 1 of package S1AR. The procedure continues until the most significant bit of the logical inequivalence is formed at $T_{18}$. The operation during $T_{19-22}$ is identical to that in logical addition.

Shift Instruction. During $T_{1-22}^{1}$ of phase 3 (acc) is sent to package OCRF, where it is complemented if signal OF is present. The output $B$ of package OCRF is fed through gate 2 of package ASBI, then through gate 2 of package ASRF, and back to the accumulator through gate 1 of package S1AR. Thus, at the end of the first minor cycle, the contents of the accumulator has been complemented if necessary and restored to its original position. The accumulator shift pulse signal ASP for the second minor cycle is generated in gate 4 of package ASPS. Starting again at $T_{5}{ }^{2}$, the accumulator is shifted until signal SCC from package GSCC prevents further shifting by killing signal ASP. The shortened shift is accomplished by feeding the output of stage 22 of the accumulator, package S22AR, to gate 1 of package S5AR. The arithmetic unit will idle from the time that signal SCC comes on until signal OEP comes on at $T_{22}{ }^{2}$. Signal OEP ends the operation and causes the machine to move on to phase IF1. The sign of the result is the original sign of (acc), recirculating through gate 3 of package SOBH .

Clear Instruction. During $T_{0}$ of phase 3 of the clear instruction the sign of $B$ is forced positive by gate 4 of package SOBH. During $T_{1-22}$ the accumulator shift pulse signal (ASP), generated in gate 2 of package ASPS, shifts the accumulator 22 positions. Since all inputs to the adder-subtractor are cut off during the operation, the accumulator is cleared. At $T_{22}$ signal OEP comes on, ending the operation and causing the machine to move on to phase IF1.

Transfer Instruction. During $T_{0}{ }^{1}$ of phase 3 signal SOB from package SOBH is transferred to the address of the memory through gate 3 of package GMIB (see Fig. 18-15). The sign of $B$ is still retained in package SOBH by recirculation through gate 3 . During $T_{1-18}$ (acc) is fed into output complementer package OCRF, where it is complemented
if signal OF is present. The output of the complementer, signal $B$, is transferred to address $\alpha$ through gate 2 of package GMIB. During $T_{1-22}$ signal $B$ is also fed through gate 2 of package ASBI, then through gate 2 of the adder-subtractor (package ASRF), and back into the accumulator through gate 1 of package S1AR. By $T_{22}$ the original (acc) will have been restored to its original position in the accumulator (complemented if necessary). At $T_{22}$ signal OEP comes on, ending the transfer operation and causing the machine to move on to IF1.

## 18-7. Instruction Register, Current-address Register, Instruction Decoder, Memory-selection Unit, and Counters

Instruction Register, Current-address Register, and Instruction Decoder (see Fig. 18-14). We have denoted the $\alpha$ bits of the instruction by $\alpha i$, the reading of the current-address counter by $\alpha^{\prime} i$, and the generated bits for memory selection, which may be $\alpha^{\prime} i$ during phases IF1 and $F 1$ or $\alpha i$ otherwise, by $\alpha^{*} i$.

The current-address counter is a straightforward cascading counter, which increases its count by 1 at each pulse from package 1CSG. This package will have an output at $T_{22}$ of each phase 1 , unless a jump is directed by signal JCS. When a jump is required, each $\alpha i$ is transferred to and loaded in the current-address counter, in a parallel fashion, by a pulse from package JCLG, as the previous $\alpha i$ are automatically erased.

The instruction register is a shift register stepped only during $F 1$ in receiving ( $\alpha$ ) from the drum. The 6 most significant bits of the instruction, $\omega 6$ to $\omega 1$, enter the instruction decoder, which is simply a decoding matrix (see Exercises $a$ through f). If the start button is pushed during the idling phane rep, the current addrecs sounter and the insturuction register are both completely cleared by signal STC from package STCG.

The Channel and Sector Selectors (see Fig. 18-15). The signals $\alpha^{*} 12$, $\alpha^{*} 11, \alpha^{*} 10, \alpha^{*} 9$, and $\alpha^{* 8}$ open one of the 32 gates to the channels. Both the read-in and read-out gates are opened at the same time. A word will be read in or out depending on the gates of packages GMIB and GMO $\alpha$.

The sector selector really chooses a time rather than a sector as directed by $\alpha * 7$ through $\alpha^{*} 1$. It chooses that time when all the pairs of bits $\left(C i, \alpha^{*} i\right)$ are identical. This will occur first at $T_{0}$ of the proper minor cycle and will continue until the sector counter is again stepped at $T_{0}$ of the next minor cycle. The signal generated, called COI, changes the phase from an idling phase to an active phase. The active phase signal opens GMIB or GMO $\alpha$ so that a word may be read in or out.

Since we have decided against having a large or-gate package for the Pedagac, to obtain ( $\alpha$ ) we must use the principle that

$$
X_{1}+X_{2}+X_{3}=\overline{\bar{X}_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}}
$$

Some complications arise, however, for package GMO $\alpha$. We need a function of the general form

$$
\left(X_{1}+X_{2}+X_{3}\right) \cdot T \cdot\left(Y_{1}+Y_{2}\right)=\overline{\bar{X}_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}+\bar{T}+\bar{Y}_{1} \cdot \bar{Y}_{2}}
$$

Hence we form $\bar{X}_{1} \cdot \bar{X}_{2} \cdot \bar{X}_{3}+\bar{T}+\bar{Y}_{1} \cdot \bar{Y}_{2}$ by means of our package format and invert the output to obtain the desired result (see Exercises $g$ through $n$ ).

The Unit-time-interval, Sector, and Minor-cycle Counters (see Fig. 18-16). These are all parallel counters. The unit-time-interval counter is started by means of the drum synchronizing signal. The sector counter is not a single counter but is composed of two cascaded parallel counters, one of 4 bits and one of 3 . This arrangement was necessary because each package has been allowed no more than five inputs to any and gate. The minor-cycle counter is stepped at $T_{0}$ by $T_{22}$ delayed, except when it must be reset. The minor-cycle counter is reset to 1 , not to 0 as are the other counters (see Exercises $o$ through $w$ ).

## EXERCISES

(a) Derive the expression for $\alpha^{\prime} i$ from $1 \mathrm{CS}, \mathrm{JCL}, \alpha i$, and its own recirculation. Remember that 1CS and JCL are mutually exclusive.
(b) Why are three gates needed to construct $\alpha^{*} i$ ?
(c) Where is $\alpha^{*} 10$ used? Where is $\alpha^{*} 3$ used?
(d) Why is it necessary that STC inhibit only gate 1 of the $\alpha i$ in the instruction register, whereas it inhibits both gates 1 and 2 of the $\alpha^{\prime} i$ in the current-address counter?
(e) As the instruction register is being loaded with ( $\alpha$ ), the instruction decoder generates a series of miscellaneous signals. Why is it that these generally erroneous miscellaneous signals do no harm? When do they become the correct signals?
(f) Redesign the current-address counter as a parallel counter (see Sec. 15-2).
(g) When should ( $\alpha$ ) be read into the arithmetic unit?
( $h$ ) When should ( $\alpha$ ) be read into the instruction register? Into the buffer?
(i) Why is no provision made in package GMO $\alpha$ for reading ( $\alpha$ ) into the arithmetic unit, the instruction register, or the buffer?
(j) Why is it necessary to invert only the output of $\mathrm{GMO} \alpha$ ?
(k) Derive the specific Boolean equation for ( $\alpha$ ) from the logical design drawing for GMO $\alpha$.
(l) Why are three levels of gating necessary to form COI?
(m) Why should COI occur only at $T_{0}$ ?
( $n$ ) How is the sign of $B$ read into the memory during the transfer instruction (i.e., through what gate of what package)?
(o) Does UTS come on at $T_{0}$ ? How do you explain this in the light of the fact that when DSS (the drum-synchronizing signal) comes on for the first time the count should start at $T_{0}$ ?
( $p$ ) Why does the package that forms $T_{1-19}$ have $T_{20}$ to inhibit the recirculation?
(q) Why need only signals $T_{0}, T_{1}, T_{18}, T_{19}, T_{20}, T_{21}$, and $T_{22}$ be formed?
(r) Why does the sector counter not have a clearing signal?
(s) Why is the sector counter stepped by a delayed $T_{22}$ rather than a $T_{0}$ ?
( $t$ ) How does the minor-cycle counter behave during phase IF2?
(u) How does the minor-cycle counter behave before UTS comes on?
(v) Describe the operation of package UTSG. (Hint: See Sec. 17-8.)
(w) Why is the minor-cycle counter reset to 1 at $T_{0}$ of every minor cycle except during phase 2 or 3 ?


Fig. 18-14. Control unit: current-address counter,

instruction register, and instruction decoder.


Fig. 18-15. Control unit: channel

selector and sector selector.



Frg. $^{2}$ 18-16. Control unit: unit-time-interval counter, sector counter, and minor-cycle counter.


Fig. 18-17. Logica design of the operations phase generator.

## 18-8. Phase Generater, Buffer, and Push Buttons

The vertical description of the operations phase generator (see Fig. 18-17, Exercises $a$ through $p$ ) is as follows:
Phase 1 signal generator F1SG
Gate 1 initiates $F 1$ after phase IF1 unless the stop button has been pushed.
Gate 2 holds $F 1$ until the next minor cycle begins.
Idling phase IF2 signal generator IF2G
Gate 1 initiates IF2 for the add instruction.
Gate 2 initiates IF2 for the subtract instruction.
Gate 3 initiates IF2 for all logical instructions.
Gate 4 initiates IF2 for the multiply and divide instructions.
Gate 5 holds IF2 until the proper sector has been selected.
Phase 2 signal generator F2SG
Gate 1 initiates $F 2$ after IF2.
Gate 2 holds $F 2$ from $T_{0}{ }^{1}$ until the end of the operation.
Idling phase IF3 signal generator IF3G
Gate 1 initiates 1F3 for the transfer instruction.
Gate 2 holds IF3 until proper sector is selected.
Phase 3 signal generator F3SG
Gate 1 initiates $F 3$ for the shift instruction.
Gate 2 initiates $F 3$ for the clear instruction.
Gate 3 initiates F3 after IF3, for the transfer instruction.
Gate 4 holds $F 3$ from $T_{0}{ }^{1}$ until the end of the operation.
Phase I*F1 auxiliary signal generator I*F1G
Gates 1 and 2 initiate IF1 after a jump instruction.
Gate 3 initiates IF1 after a phase F2 instruction.
Gate 4 initiates IF1 after a phase F3 instruction.
Gate 5 initiates IF1 for the run button.
Phase I'F1 auxiliary signal generator I'F1G
Gate 1 initiates IF1 after a word has been read into the output t: $\therefore$ from the buffer.
Gate 2 initiates IF1 after a word has been read into the drum fion: the buffer.

Idling phase signal IF1 generator IF1G
Gates 1 and 2 initiate IF1 from I*F1 or I'F1.
Gate 3 holds IF1 until the proper sector has been selected or the stop button has been pushed.
Stopped idling phase signal ISF generator ISFG
Gate 1 initiates ISF at the first $T_{1}$ pulse formed after the power is turned on.

Gate 2 initiates ISF for a stop instruction.
Gate 3 initiates ISF when the stop button is pushed.
Gates 4 and 5 stop ISF at the next $T_{0}$ after the run button or start button is pushed.

The vertical description of the in-out phase generator (see Fig. 18-18, Exercises $q$ through $w$ ) is as follows:

Output idling phase signal IFO generator IFOG
Gate 1 initiates IFO.
Gate 2 holds IFO until the proper sector has been selected.
Output operating phase signal FOO generator FOOG
Gate 1 initiates FOO after IFO.
Gate 2 holds IFO on for one minor cycle.
Output buffer phase signal FBO generator FBOG
Gate 1 initiates FBO after FOO.
Gates 2 and 3 hold FBO until $T_{0}$ of the first minor cycle after the complete word has been read out of the buffer.
Input buffer phase signal FBI generator FBIG
Gate 1 initiates FBI after phase 1 for a read-in (that is, 00) instruction.
Gate 2 initiates FBI at $T_{0}$ of the first minor cycle after the start button has been pushed after ISF.
Gates 3 and 4 hold FBI until $T_{0}$ of the first minor cycle after the word has been completely read into buffer.

Input idling phase signal IFI generator IFIG
Gate 1 mitiates $1 \mathrm{H}^{\prime} 1$ atter HB .
Gate 2 keeps IFI on until proper sector is selected.
Input operating phase signal FOI generator FOIG
Gate 1 initiates FOI after IFI.
Gate 2 holds FOI for one minor cycle.
The Start, Run, and Stop Buttons (see Fig. 18-18, Exercises $x$ through $a a)$. The start button is used in initiating a new program on the computer. After the stop button has been pushed or a stop instruction has been executed, the start button breaks the sequence of instructions that were being computed. The start button will have effect only if pushed when the computer is in the stopped idling phase ISF. When it is pushed during ISF, the computer reads one word from the input unit into address 0000 and then takes (0000) as its next instruction. If the word read in is a jump instruction, the computer can be made to jump to any desired memory location and proceed with a desired program. The advantage of such a procedure, besides its being used for the initial readin, is that it can be used for debugging purposes, as a manual method of jumping to different programs, and so forth.

Pushing the start button initiates signal $\mathrm{STB}^{\prime}$ in the start-button
synchronizer of the control panel. If the button is pushed during phase. ISF, STB' initiates STB in package STBG immediately (except not at the beginning of a minor cycle). Signal STB in turn initiates STC (package STCG of Fig. 18-14), which clears the current-address counter and the instruction register. At the beginning of the next subsequent minor cycle STB initiates FBI (package FBIG) and allows ISF to be killed (package ISFG). Then at $T_{1}$, FBI (delayed) kills STB. Now, since the instruction is all zeros, the instruction operation will appear as 00 and the computer will proceed to read one word into 0000 during the successive phases IFI and FOI. Next follows phase IF1, and since the current-address register is all zeros, (0000) will be taken as the next instruction, to be executed as usual. If the start button is pushed when the computer is not in ISF, it will have no effect.

The stop button forces the computer into the stopped idling phase. That phase will be initiated only during or after phase IF1, bypassing phase $F 1$. The reason for this will be made clear in the discussion of the run button.

The run button will have effect only if the computer is in the stopped idling phase. If the run button is pushed then, the computer will proceed with the computations from the point where it left off, taking the next instruction in proper sequence. If the stopped idling phase was initiated by a stop instruction, the current-address counter contains the address of the next instruction, for phase 1 had been completed. When the run button is pushed, this address will be taken as that of the next instruction. If the idling phase was entered via the stop button, the computer had gone from phase IF1 directly to the idling phase and had not brought the next instruction into the instruction register or increased the current-address counter, since phase 1 had been bypassed. Then, when the run button is pushed, the computer will read into the instruction register the instruction it would have read if the stop button had not been pushed.

The vertical description of the push buttons and in-out buffer (see Fig. 18-18, Exercises $b b$ through $j j$ ) is as follows:

Start-button signal generator STBG
Gate 1 initiates STB with signal STB' from the start-button synchronizer only when the computer is stopped.
Gate 2 holds STB on until FBI comes on.
Stop-button signal generator SPBG
Gate 1 initiates SPB with signal SPB $^{\prime}$ from the stop-button synchronizer unless the computer is already stopped.
Gate 2 holds SPB until ISF comes on.
Run-button signal generator RUBG
Gate 1 initiates RUB with signal $\mathrm{RUB}^{\prime}$ from the run-button synchronizer only when the computer is stopped.
Gate 2 holds RUB until IF1 comes on.

End of write-out signal EWO generator EWOG
Gate 1 initiates EWO when the buffer has been completely read into output unit.
Gate 2 holds EWO until IF1 has been initiated at the next $T_{0}$.
End of write-in signal EWI generator EWIG
Gate 1 initiates EWI when the buffer has been completely loaded from the input unit.
Gate 2 holds EWI until IF1 has been initiated at the next $T_{0}$.
Read into buffer from input unit RIBG
Gate 1 tells the input unit to start shifting (pulse RIB initiates SIU).
Read out of buffer to output unit ROBG
Gate 1 tells the output unit to start shifting (pulse ROB initiates SOU).

First package of buffer BU1
Gate 1 lets the contents of the input unit (signal IEQ) enter the buffer during phase FBI.
Gate 2 lets ( $\alpha$ ) enter the buffer during phase FOO.
Gate 3 holds the bit until shifted.
Buffer-shift pulse generator BSPG
Gates 1 and 4 produce shifts synchronous with the input and output unitu.
Gates 2 and 3 produce shifts synchronous with the computer clock.

Synchronization. The Pedagac is so designed that signals $\mathrm{SPB}^{\prime}, \mathrm{RUB}^{\prime}$, and STB' can be of indefinite length. Hence the push-button synchronizers may be merely type $A$ packages in which the outputs of the actual buttons are gated with clock pulses. In order that no error result from pushing two buttons simultaneously, we have $\mathrm{SPB}^{\prime}$ inhibit RUB $^{\prime}$ and STB', and we have RUB ${ }^{\prime}$ inhibit STB'. In addition we have STB inhibit RUB', in case the start button were pushed immediately before the run button.

Synchronizing the input and output units of the Pedagac is equally simple. The input unit, for example, will put out a signal indicating when it is ready to deliver the next bit of a word. That signal initiates SIU in a type $A$ package; SIU is then killed by the inversion of that signal, delayed by one unit time interval [cf. gate 1 of package ISFG (Fig. 18-17)]. Signal SOU is similarly generated by the output equipment. The end-of-shift signals for the buffer, EWI' and EWO', are also synchronized in this manner, but with two units of delay (why?). This method assumes that the signals of the input and output unit have been processed to eliminate intermittencies, such as might result from relay chatter.


Frg. 18-18. Logical diagram of the push-button signal generators, in-out phase generator, and buffer.

## EXERCISES

(a) How does gate 2 of package F1SG keep $F 1$ on during $\mathrm{I}_{0-22}^{1}$ ?
(b) What is the purpose of having the stop-button signal SPB inhibit the initiation of phase 1 ?
(c) In gates 1 to 4 of package IF2G why are $T_{0}$ and the unit delay on $F 1$ both necessary?
(d) In package IF2G at what unit time interval will IF2 go off, and why?
(e) In gate 2 of package F2SG, why are the unit delays necessary?
(f) Both IF2 and IF3 perform the same function, namely, selecting the drum sector. Are they both necessary? (Hint: How would $F 2$ and $F 3$ be initiated if IF2 and IF3 were not available? Remember that only five gates are allowed to each package.)
(g) Why should the run button initiate phase IF1 in package I*F1G? Why must both ISF and RUB act on gate 5 of package I*F1G?
(h) Why is an auxiliary I*F1G package necessary?
(i) Show that I'F1 can come on only once after phase FBO.
(j) Why is $F 1$ initiated in package F1SG from two sources?
(k) What are all the functions of the signal ISF generated by package ISFG (that is, where is this signal used, and why is it necessary)?
(l) Why are both button conditions for stopping ISF necessary (see gate 3 of package ISFG)?
( $m$ ) How does the minor-cycle counter behave when ISF is on?
( $n$ ) Show that gate 1 of ISFG turns ISF on only when UTS comes on for the first time. Why is it necessary to resort to an unconventional technique in this case?
(o) Why is it necessary to have the computer idling in phase ISF before the start button is pushed for the first time?
( $p$ ) Suppose that the start button is pushed when the computer is not in phase ISF;

(q) What must be done on the control panel before the start button is pushed if it is desired to read in one word into 0000 during the course of debugging a program?
(r) Why is $T_{0}$ necessary in gate 1 of package IFOG?
(s) Why can FOO be inhibited simply by a $T_{0}$ ? (See gate 2, package FOOG.)
( $t$ ) Why can FBI be initiated after either phase 1 or phase ISF? (See gates 1 and 2 of package FBIG.)
(u) In gate 1 of package IFIG why did we not use a delayed FBI with $T_{0}$ ?
(v) How does the computer know that a word is to be read into the drum from the buffer during FOI, but from the drum into the buffer during FOO?
( $w$ ) Since both phases IFO and IFI perform the same function, namely, selecting a drum sector, why are they both necessary? (Hint: If both IFO and IFI were not available, how would FOO and FOI be initiated? Remember also the start button.)
( $x$ ) Describe all ways for entering idling phase ISF.
(y) Describe all ways for going out of idling phase ISF.
(z) When the stop button is pushed, why is it advantageous for the computer first to complete one minor cycle of phase IF1 and thep to change directly to the idling phase, bypassing phase F1? (Hint: Remember the operation of the run button and that the computer must pass through at least one minor cycle of phase IF1 during every instruction-execution cycle.)
(aa) Trace on the diagrams the actions of the start, run, and stop buttons.
(bb) Why must STB (start-button signal) be turned off as FBI comes on? (Hint: Suppose that STB was left on; what would happen? See packages ISFG and FBIG.)
(cc) Why must gate 1 of STBG have a $\bar{T}_{0}$ input? (Hint: See the instruction shift register, and note that an error would result if $\mathrm{STB}^{\prime}$ were pushed at $T_{0}$. Why?)
(dd) Are the $\bar{T}_{0}$ inputs to gate 1 of packages SPBG, RUBG, EWOG, and EWIG necessary? Why?
(ee) Why must the ISF input to package SPBG be delayed?
(ff) What is the purpose of the EWI and EWO inhibitions on gates 1 and 4 of package BSPG?
(gg) Are the $T_{0-18}^{1}$ inputs of gates 2 and 3 of package BSPG strictly necessary? Why?
( $h h$ ) Why must EWI and EWO wait, respectively, for IF1 and IFI to come on before they are turned off?
(ii) What is the purpose of package RIBG, and of package ROBG?
( $j \mathrm{j}$ ) In package BU 1 of the buffer why is it not necessary that the shift pulse be included as an input into gates 1 and 2, as it is into gate 1 of BU2?

## 18-9. Additional Topics

$a$. Redesign the Pedagac, using delay-line registers (including the current-address register and the instruction register).
b. Modify the design of the Pedagac to include other instructions such as the replace arithmetic operations and to admit relative addressing (see Chap. 4).
c. Design the Pedagac as a floating-point computer.
d. Redesign the Pedagac with a parallel arithmetic unit and parallel rapid multiplication and division.
e. Design the special-purpose business and logistics computer described in Sec. 8-5.
$f$. Incorporate the comparator unit, control computer unit (see Sec. 15-7, Additional Topics $c$ and $d$ ), business unit, and general-purpose Pedagac into a unified system as described in Sec. 8-6.

# ELECTRONIC DESIGN OF DIGITAL CIRCUITS 

CHAPTER 19

## PROBLEMS AND LIMITATIONS

 IN ELECTRONIC REALIZATION
## 19-1. Introduction

In Parts 3 and 4 we considered digital circuits to be abstract "black boxes" with certain logical properties; we abstractly represented digital information by means of the symbols 0 and 1 . Assuming the availability of such digital circuitry, we showed how a digital computer could be logically designed by appropriately connecting such circuits. In this part of the book we shall consider the problems involved inside our black boxes, problems of the electronic design of the digital circuits themselves.

Electronic signals are the physical realization of information processed in a digital electronic computer. In this part of the book we shall be concerned primarily with the electronic processing of these signals. The present chapter is concerned with the effect of the actual electronic circuits themselves on our building-block organizational concept. No longer can we neglect signal delay through amplifiers, or package-coupling problems, or absolute package reliability. The results of this present chapter are tacitly assumed in discussing the general considerations of circuits using semiconductors (diode and transistor) elements, in Chap. 20, and of circuits using magnetic elements, in Chap. 21. Memory methods and input-output techniques present many special problems, some of which will be considered in Chap. 22. Finally in Chap. 23 we shall return to the design of the Pedagac; and, specifying the electronic design of a particular type of package, we shall consider the nontrivial wiring diagrams, giving the actual pin connections between packages.

It should be emphasized, however, that almost every topic covered in this part of the book is a full-fledged and rapidly growing field in its own right. We can expect to do no more than present some of the basic principles involved. As with the previous parts of the book, the method of exposition of principles is by specific examples selected for that purpose. The extensive bibliographies given in the Additional Topics attest to the fact that only introductory material can be covered in such a short treatise as this.

In the present chapter various systems for the electronic realization of 0,1 are first described. The next general problem in the physical realization of digital circuits is the effect of finite delay during amplification, which demands an introduction of the concept of clock phases. Finally, the actual use of circuits brings up the problem of reliability, which although not directly influencing general circuit considerations falls naturally into this chapter.

## 19-2. Types of Digital Gating Systems

Electronic Functions of Packages. In general the package must perform four functions: (1) gating, (2) amplification and reshaping, (3) retiming (i.e., resynchronization), and (4) storage. The gating must be accomplished for the logical processing of the signals. This logical processing requires the signals to pass from package to package, through various circuit components such as resistors, transistors, diodes, capacitors, and inductors, which cause the signals to become somewhat attenuated and distorted (see Exercise a). In order that the signals may not become so distorted as to be undetectable by a following package, they must be amplified and reshaped. For proper operation of the logical processing all signals entering the same gate must be synchronized, even though they may have passed through different sets of components (involving different numbers of gates) on the way to this gate. Finally, delaying or storing the signal is often an important part of the logical processing.

We would not leave the reader with the idea that all these four features must be inciuded in every package, for frequently these functions are distributed over sets of snofializod nonkgres. As an illuctration, it sometimes happens that signals pass through a special amplification and reshaping package after having passed through several packages that perform only the gating and synchronizing functions; there are of course many possible variations. On the other hand some provision must always be made for the accomplishment of each of the four functions.

We shall consider in detail three methods for performing these functions: the dynamic, or regeneration, method; the static, or flip-flop, method; and the phase, or parametric, method. The general principles involved will be presented by means of examples, but the practical implementation of these methods in computer technology is by no means limited to these illustrations.

Dynamic, or Regeneration, Method. In this method the unit signal representation is in the form of a (synchronized) square voltage pulse, the zero in the form of no pulse. Amplification of the pulse is accomplished by standard circuitry, but the pulses are reshaped and retimed by means of logical gating. As an illustration, consider Fig. 19-1a, where the pulse representations of 0 and 1 are shown. A typical package is shown in Fig. 19-1b; specific circuits for the gates and amplification will be considered in detail in the next chapters. Because of the clock pulse at every input and gate the transmission of a pulse from one package to the
next occurs only as the clock pulse is on. The clock pulse itself, always correctly shaped and timed in a special clock oscillator, is sent directly to each input and gate. The leading edge of the clock pulse can therefore be used to reshape the leading edge of an attenuated input unit pulse, as illustrated in Fig. 19-1c. The input signal must enter the and gate


Fig. 19-1. Dynamic, or regenerative, method.
ahead of the clock pulse, so that the resulting waveform at point $A$ of the circuit will be as shown. The trailing edge of the input pulse still remains to be shaped. To do this, the amplified pulse is recirculated through a special two-input and gate with a clock pulse, but without a delay (other than that of the amplifier itself). The recirculation through this and gate will hold the output at the unit level until the clock pulse goes off. Then the trailing edge of the clock pulse will shape the trailing edge of the signal pulse. The output signal with and without such regeneration reshaping is shown in Fig. 19-1c (the offset of the
output signal to the right in the figure indicates the effect of delay inherent in the amplifier). Note that the circuit of Fig. 19-1b is of the type used in the package of the Pedagac; in our logical drawings we have always omitted the clock pulses and the recirculation and gate (cf. Fig. 19-1d).

This scheme has resulted in a package that gates and amplifies the signals, and reshapes and retimes them by using clock pulses to determine the leading and trailing edges of the signals. For storage, however, we must connect to the package a special delay line, as shown in


Fig. 19-2. Static, or flip-flop, method.
Fig. 19-1d. Frequently special packages are made containing only such delay lines; these are then wired in as required by the logical processing diagrams. A variation of this technique is an or-and-or gating arrangement, rather than just the and-or arrangement. The inputs to the circuit would be to the first level of or gates; the clock pulses and leading-edge shaping would occur in the next level of and gates, with the recirculation accomplished as already described.

Static, or Flip-Flop, Method. In this system the electronic signals pass through a gating network into a flip-flop. The unit or zero is recorded as the state of the flip-flop. The flip-flops usually have two stable voltage levels, one representing a unit, the other a zero. The voltage level held in the flip-flop is gated out by a clock pulse to become the information pulse signal for the gates of the next package. The 0 and 1 signal representations are voltage pulses in the gates but are constant voltage levels in the flip-flops. Figure 19-2a represents the gating and flip-flop combination, with the and gate that combines flip-flop output and clock pulse. Amplification is virtually accomplished in the flip-flop; retiming and reshaping are accomplished by the clock pulse in the output and gate (see Fig. 19-2b). The flip-flop is of course capable of storage as well.

A standard gating arrangement and flip-flop combination can be incorporated into a single package. However, it is frequently more convenient to have separate flip-flop and gating packages. In either case there must be a limit on the number of gating levels or packages through which a signal can be sent before a flip-flop is used. Sometimes the gating packages themselves contain provision for amplification, or separate amplification packages are included, to increase the number of gating packages possible between flip-flop packages. However, the flipflops would still accomplish the retiming, storage, and reshaping functions. We consider specific gating and flip-flop circuits in the next chapters.

Phase, or Parametric, Method. This system is entirely different from the two mentioned above. We include it here to indicate the diversity of conceivable methods; the principles involved also have important application to digital microwave circuitry (see Sec. 21-5). The 0, 1 information is represented in this case by the phase of a signal sine wave with respect to a standard "clocking" sine wave of double the frequency. (Compare the above methods, which represent information by the amplitude of a signal.) The technique is based on the phenomenon of parametric amplification, which we now describe.

We introduce the concept of a parametric amplifier by means of the rough mechanical analogy shown in Fig. 19-3a. As the bob of the pendulum swings past the lowest point of its path, with its greatest velocity, the cord is pulled, reducing the effective length $l$ of the pendulum by $\Delta l$. Since angular momentum is conserved, the linear velocity of the weight increases by the ratio $l /(l-\Delta l)$ and the swing is amplified. At the top of the ascending are the cord is released, allowing the arm to return to its original length $l$, and the procedure is repeated on the return arc. Thus the frequency of the exciting pull on the cord is twice the frequency $f$ of swing of the pendulum (see Fig. 19-3b). The energy absorbed by the pendulum as its swing is amplified is the difference between the work required to pull the cord against the combination of the weight of the bob and its centrifugal force $F$ at the low point of its swing and the work returned as the bob drops at the top of its swing without centrifugal reaction. The instantaneous input power is $P=F d l / d t$, and the work absorbed per cycle is $\int_{0}^{1 / f} P d t$. Thus for a small sinusoidal change of length of frequency $2 f=2(\omega / 2 \pi)$, we have $l=l_{0}-\Delta l \sin 2(\omega t+\alpha)$, with $\alpha$ giving the phase relation. Assuming a small swing of the pendulum (of angular frequency $\omega=2 \pi f$ ), and noting that the centrifugal force $F$ will be proportional to the square of the velocity of the swing, we have approximately $F=K \sin ^{2} \omega t=1 / 2 K(1-\cos 2 \omega t)$. Thus the work per cycle is

$$
\begin{aligned}
\Delta W=\int_{\omega t=0}^{\omega t=2 \pi} P d t & =\int_{0}^{2 \pi / \omega} 1 / 2 K(1-\cos 2 \omega t)[-2 \omega \Delta l \cos 2(\omega t+\alpha)] d t \\
& =\pi l \Delta l \cos 2 \alpha
\end{aligned}
$$

which has its maximum positive value when $\alpha=0$ or $\pi$, which is when the pull has its maximum velocity at the low point of the pendulum swing (i.e., at times $t_{1}, t_{3}$, . . of Fig. 19-3b). Note that, if the pendulum was initially at rest, no horizontal motion would be produced by pulling the cord: there must be an initial swing to the pendulum in order that amplification take place. The initial phase $\alpha$ of this motion should be 0 or $\pi$ for maximum amplification; clearly the amplified motion will have the same phase as the initial motion.

We can now understand the parametric amplifier, illustrated in Fig. $19-3 c$, in terms of the mechanical analog. The coils on cores $A$ and $B$ are wound in opposite directions, an exciting current-source wire threads the two cores, and a bias keeps the cores near the knee, or bend, of the hysteresis $\Phi-I$ curve (see Fig. 19-3d). The exciting wire is driven with a current source $I_{d}$ of frequency $2 f$, where $f$ is the resonant frequency of the main $L C$ circuit. As we have seen in the mechanical analog, there must be some small oscillation at the start. At time $t_{1}$ the small maincircuit current $I_{c}$ will increase the flux $\Phi$ in one core, say $B$, and decrease the flux in the other, $A$ (see Fig. 19-3d). Thus for the same $\Delta I_{d}$ the increase $\Delta \Phi_{A}$ will be greater than $\Delta \Phi_{B}$, the latter being practically zero. The induced voltage in $A$, namely, $V_{A}=d \Phi_{A} / d t$, is in the direction to increase $I_{c}$. This is just like the pull up on the bob at the bottom of the swing. At $t_{2}, I_{c}=0$; hence both cores are at the same point on the hysteresis loop and the induced voltages, being opposed, cancel-i.e., like letting out the bob at the top of its swing. At $t_{3}$ the cores interchange positions on the hysteresis curve since the current $I_{c}$ is reversed; since $\Delta \Phi_{A}$ wiil be negligible, $V_{B}=d \Phi_{B} / d t$, in the reverse direction, will heln increase the emrent. $I_{i}$. The gain in power (for ecild of iv tünio each) is

$$
P=N I_{d} \frac{d \Phi}{d t}=N I_{d} \frac{d \Phi}{d I_{d}} \frac{d I_{d}}{d t}
$$

where $\Phi=\Phi_{A}+\Phi_{B}$. Hence, since the bias on $I_{d}$ is large with respect to its total variation, we have for the work input the approximation

$$
\Delta W=\int_{\omega t=0}^{\omega t=2 \pi} P d t=N I_{d} \int_{0}^{2 \pi / \omega} \frac{d \Phi}{d I_{d}} \frac{d I_{d}}{d t} d t
$$

We have just seen that, with a sinusoidal current $I_{c}$ of frequency $f$ in the $L C$ circuit, the slope $d \Phi / d I_{d}=d \Phi_{A} / d I_{d}+d \Phi_{B} / d I_{d}$ varies with a frequency

$$
2 f=2 \frac{\omega}{2 \pi}
$$

Thus, to a first approximation $d \Phi / d I_{d}=K(1-\sigma \cos 2 \omega t)$, with $K$ and

(a) The pendulum

웅

(c) A parametric amplifier

(b) Exciting frequency and amplified frequency

(d) Operation of cores during parametric amplification

Fig. 19-3. The parametric amplifier.
$\sigma$ appropriate constants. For the current $I_{d}$ we have
whence

$$
\begin{aligned}
I_{d} & =I_{b}+\Delta I_{d} \sin 2(\omega t+\alpha) \\
\frac{d I_{d}}{d t} & =2 \omega \Delta I_{d} \cos 2(\omega t+\alpha)
\end{aligned}
$$

Thus the integral for $\Delta W$ is of the same form as for the pendulum above.


Exciter pulses for synchronization and rotiming
(c)


Gating and reshaping
(d)


Storage by recirculation
(e)

Frg. 19-4. Phase, or parametric, method.
Summarizing, the parametric amplifier will use energy of a frequency $2 f$ to amplify an initial small oscillation of frequency $f$, and the amplified result will have the same 0 or $\pi$ phase as the initial small oscillation (see Fig. 19-4a). This latter observation is most important, for a 0 or 1 is represented by an oscillation in the 0 or $\pi$ phase, respectively. The zero or unit information is transmitted into the amplifier by means of weak coupling, as illustrated in Fig. 19-4b, to initiate a small oscillation of appropriate phase; this is in turn amplified. The output is a coupling device to another amplifier. The exciting set of pulses of frequency $2 f$ synchronizes the timing and is analogous to the clock pulse described above. Different sets of exciting pulses are used for the previous, pres-
ent, and next successive packages (see Fig. 19-4c). Each set of pulses overlaps slightly as shown, and in this way the signal is transmitted from one package to another. Figure 19-4d represents a schematic for a parametric-amplifier package, where the $M$ part is the input coupler, and the circle is the amplifier supplied with leads for the exciting pulses. Storage can evidently be obtained simply by direct recirculation, as shown schematically in Fig. 19-4e.

Gating can be accomplished as follows: Suppose that there are three coupling windings. The coupling will be in the same phase as the majority of the three windings, since if two of the windings are in different phases ( $\pi$ radians apart) they will cancel and the phase of the third winding will prevail. Hence, to make an and gate, let the winding $K$ (see Fig. 19-4b and $d$ ) be in phase 0 ; then the phase of the exciter will be $\pi$ only if both $A$ and $B$ are in phase $\pi$ (that is, both units). To make an or gate, we let winding $K$ have phase $\pi$. Then the exciter will be in phase $\pi$ if the phase of $A$ or $B$ (or both) is $\pi$. Negation can be obtained by reversing the polarity of the coupling transformer input. This circuit, called a Parametron, is symbolically illustrated in Fig. 19-4d, where $M$ means majority.

## EXERCISES

(a) If a square waveform is introduced into a pure (1) resistor, (2) diode, (3) capacitor, (4) inductor, and (5) transistor, how will the attenuation affect the shape of the output in each case, assuming a series resistive load? Show mathematically how to account for each change of shape.
(b) Consider a flip-flop package with two inputs $R$ and $S$ such that the output $Q^{\prime}$ is given in terms of its state $Q$ by $Q^{\prime}=\bar{R} Q+S$. Design a serial adder, using the static, or flip-flop, method. (Hint: The carry and result should be the outputs of flip-flops.)
(c) Logically design a serial adder, using only four Parametrons each of which has three inputs as in Fig. 19-4. The circuit should form both the carry and the result. (Hint: Use the Parametrons directly as majority gates, and not as and or or gates.)

## 19-3. Clock Phases and Synchronization

Transfer, Repetition, and Overlap Times. In dealing with actual components, certain electronic-circuit responses become important. The first of these relates to the transfer time $\left(t_{T}\right)$, the time required for the leading edge of a pulse to pass through a package. Since the leading edge of a pulse may not be vertical, we should more precisely define the transfer time as that interval of time from the moment when the leading edge of the incoming pulse is high enough to be detected, to that moment when the resulting output pulse of the package rises to this same level (see Exercise a). On the other hand, the repetition time $t_{R}$ is the time interval that must elapse between two successive input pulses, i.e., the time required for a circuit to settle down so as to be able to distinguish the next successive input pulses. Even though the output information signal resulting from the logical processing of input signals by a gating
network may be detected, it does not follow that the network is ready to acquire another input. In general it is the repetition time that limits the speed with which digital information can be processed by a circuit, although not infrequently the proponents of a particular circuit may quote the usually shorter transfer time instead. Finally the overlap time $t_{L}$ must be considered; this is the time interval during which the input signal must be sustained in order to be detected.

Clock Phases and the Unit Time Interval. In Part 4 we deliberately avoided the problems that arise because of the finite response times of the package circuitry. However, as becomes clear from the considerations of Sec. 19-2, we can no longer postpone such a discussion. For this purpose let us first review our concept of the unit time interval $t_{U}$ as the indivisible unit of time in so far as the logical design of the computer is concerned (see, for example, Sec. 15-4). The unit time interval is the shortest possible time interval that can exist between the leading edges of two successive pulses entering the same gating circuit. Clearly then

$$
t_{U} \geq t_{R}
$$

For purposes of logical design all times were taken as integral multiples of the unit time interval, and also for simplicity we chose $t_{U}$ as the time required for a bit to go from the memory through a gating network to a register (see Sec. 15-1). Thus, for our logical considerations, the leading edges of the clock pulses were one unit time interval apart. However, from the electronic-design point of view this situation is not realistic. A pulse certainly passes through more than one package in a unit time intervai; there is a finite delay through each package; and therefore for each successive package a distinct clock pulse must be available to synchronize input pulses. Thus, if the pulses had to pass through four packages in a unit time interval, there would be four successively delayed clock pulses,


Fig. 19-5. Timing diagram for a package, where $t_{W}$ is the pulse width. denoted by $c p 1, c p 2, c p 3$, and $c p 4$. These are called clock-phase pulses, and with just the four pulses we would speak of a four-phase clock. A package can then be denoted by the clock phase with which it is synchronized, as a cp1 package, a $c p 2$ package, etc. Evidently it is more efficient to have the same clock phases for all parts of the computer. Hence the number of phases at minimum must be equal to the maximum number of packages that any single pulse in the computer will have to traverse in a pulse period. We shall analyze these timing considerations in more detail.

Clock-phase Sequencing. In Fig. 19-5 we have diagramed the various times associated with a package. The shaded area represents the input
overlap time $t_{L}$ between packages; the input and output pulses are offset by the transfer time $t_{T}$; the pulse width is represented by $t_{\mathrm{W}}$. Figure 19-6 illustrates these times for a four-clock-phase system; the diagram of Fig. 19-5 is there repeated for each package. Each unit time interval then contains the four clock-phase pulses $c p 1, c p 2, c p 3$, and $c p 4$. Observe that $t_{U} \geq 4\left(t_{W}+t_{T}-t_{L}\right)$, or for $n$ clock phases $t_{U} \geq n\left(t_{W}+t_{T}-t_{L}\right)$.


Fig. 19-6. Timing diagram for a four-clock-phase system.
The times $t_{W}, t_{T}$, and $t_{L}$ are not necessarily independent, since they are determined by the characteristics of the circuit. Suppose that $t_{W}=t_{L}$; then $t_{U} \geq n t_{T}$, or $n \leq t_{U} / t_{T}$. Information can be processed most rapidly when $t_{U}$ is a minimum, i.e., when $t_{U}=t_{R}$. In this case

$$
n \leq \frac{t_{R}}{t_{T}}
$$

which gives the electronic limitation on the maximum number of packages or gating levels that can be used in a unit time interval for most rapid operation. Observe, however, that it is not always possible to have $t_{W}=t_{L}$, as is the case, for example, in the dynamic package, where the leading edge of the clock pulse must be coincident with the maximum rise of the incoming pulse. Then all we can say is that the limitation on $n$ is given by

$$
n \leq \frac{t_{R}}{t_{W}+t_{T}-t_{L}}
$$

As mentioned above, all parts of the computer will be synchronized by the same clock phases. However, sometimes some particular gating network requires a pulse to go through fewer than the maximum number of packages in a unit time interval. There are two methods for handling such a situation. The first is simply to delay the output pulse during the other clock phases. The second is to arrange the timing of the circuitry
in such a way that some clock phases may be skipped. In a four-clockphase system, if the timing were arranged as in Fig. 19-7 the output of a $c p 1$ package could become the input of a $c p 4$ package, as illustrated by the shading. Thus either one or two clock phases could be skipped, in the situation of the figure. (See Exercise c.)


Fig. 19-7. Skipping clock phases.

## EXERCISES

(a) Discuss the transfer time, repetition time, and overlap time for the following pure components: (1) resistor; (2) capacitor; (3) inductor; (4) transistor. Assume a square-wave input.
(b) Using Fig. 19-1, describe $t_{T}, t_{R}$, and $t_{L}$ for a dynamic package.
(c) Suppose that a circuit were designed so that $t_{T}=3 / 4 t_{L}, t_{R}=4 t_{L}$, and $t_{U}-t_{W} \geq t_{L}$. Find a value for $t_{W}$ that will minimize $t_{U}$ and still allow for skipping up to two clock phases.
(d) For Parametrons the clock pulse has the analogy of a group of sine waves of frequency $2 f$. Suppose that 20 of these waves are required (i.e., "pulse" width) and that the overlap time must be 5 of these waves. Draw a diagram analogous to Fig. 19-6 for a three-clock-phase system of this type, indicating the waves as in Fig. 19-4a.

## 19-4. Methods for Increasing Circuit Reliability

General Considerations. Circuit reliability is of primary importance for digital-computer and -control systems, for clearly even a single inoperative gate can cause entirely erroneous results. Two possible methods of solutions to this problem are, first, increasing the reliability of the electronic-circuit design itself and, second, increasing the circuit reliability through redundant information-processing components.

A digital circuit has the general characteristic that it either operates successfully or does not; there is no gradation in its operation, such as
would be characteristic of radio circuits. The object of digital-electroniccircuit design is to obtain a circuit that will operate successfully under a wide variation of component parameter conditions. For instance, consider the problem of choosing resistance values $R$ for a transistor circuit that will utilize transistors of widely varying $\beta$ [ratio of collector (output) current to base (control) current] and a not too well regulated voltage source $V$. (A full discussion of transistors will be found in the next chapter.) Suppose that only the clear area on the $V-\beta$ plane of Fig. 19-8 represented those values of $V$ and $\beta$ for which resistance values could be chosen to make the circuit work and that for a given point ( $V, \beta$ ) the value of $R$ could vary within the volume illustrated. Then that resistance


Fig. 19-8. Operating range of characteristics.
value $R_{0}$ should be chosen which will maximize the area of intersection of this volume and the plane of constant resistance. Of course in general many more parameters are involved, and much more complicated situations occur than that illustrated. Also such calculations may be sensitive to the precise definition of when the circuit is or is not working.
Redundant information can be introduced for increasing circuit reliability in a variety of ways. The simplest is perhaps the parity-bit check, often used in reading a word into the computer. Here either a zero or a unit, the parity bit, is used as an extra bit of the word to make the total number of units of the word always odd or always even as desired. For example if the word were 0110 and we desired an even number of bits, the parity bit would be 0 and the final word 00110 ; if the word were 0111 , the parity bit would be 1 and the final word 10111 . When the word is read, the number of bits is checked; in this way a single error that may have occurred during storage or calculations can be detected. Of course more elaborate systems can be used incorporating self-correcting codification schemes into increased reliability techniques (see Sec. 7-7). These methods, however, lend redundancy to the digital system rather than to the component digital circuits themselves.

We shall here consider two approaches. for the introduction of redundancy directly into the gating circuits themselves; these are called the probabilistic-logic approach and the majority-logic approach.

Probabilistic Logic. $\dagger$ A digital circuit has a nonzero but usually small probability $p$ of failure at any time. By means of electronic-circuit design $p$ is made as small as possible. The


Fig. 19-9. If each and gate of the configuration has a failure probability $p$, then $f_{1}=A_{1} \cdot A_{2}$ (and $f_{2}=A_{1} \cdot A_{2}$ ) has a failure probability $p^{3} / 4$. question arises: Can a logical combination of such circuits have a probability of failure $q \ll p$ ? The answer is affirmative. For consider a collection of and gates each with probability of failure $p$, such that if $A_{1}$ and $A_{2}$ are inputs the output with failure will be $A_{1}$ (instead of $A_{1} \cdot A_{2}$ ). Then, as we shall presently show, either output of the configuration of Fig. 19-9 will be the logical product of the inputs, $A_{1} \cdot A_{2}$, with a failure probability of $p^{3} / 4$ ( $p^{3} / 4 \ll p$ for small $p$ ). In fact, if we used $n$ levels of gating, the total circuit would be equivalent to an and gate with failure probability $p^{n} / 4$.

First let us observe how to write the designation number of a function circuit with a failure probability. Consider, for example, the function $h_{1}$ of Fig. 19-9, where $h_{1}=A_{1} \cdot A_{2}$ when operating but $h_{1}=A_{1}$ with failure probability $p$. Note that $\ddot{\#}\left(\dot{A}_{1} \cdot \dot{A}_{2}\right)=0 \hat{0} 0 \hat{1} \dot{1}$ and $\ddot{\#} \dot{A}_{1}=0101$ differ only in position 1 ; in fact position 1 will have a unit with probability $p$ and a zero otherwise. Hence we write

| Position | 0 |  | 1 | 2 |
| :--- | :---: | :---: | :---: | :---: |
| Probability | 1 | $p$ | $p$ | 1 |
| $\# h_{1}$ | 0 | 0 | 1 | 0 |

where $\bar{p}=1-p$. Similarly, if $h_{2}=A_{2}$ at failure, with probability $p$, and $h_{2}=A_{1} \cdot A_{2}$ otherwise, then we would write

| Probability | 1 | 1 | $p$ | $p$ | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\# h_{2}$ | 0 | 0 | 0 | 1 | 1 |

Our probabilistic logic involves a probabilistic matrix ( $P_{j i}$ ), which corresponds to an ( $R_{j i}$ ) matrix of the kind described in Chap. 13. The probabilistic matrix has probabilities as its elements, and a nonzero element $p_{j i}$ of ( $P_{j i}$ ) means that the $j i$ th element of the corresponding ( $R_{j i}$ )
$\dagger$ This method is based on the author's adaptation for reliable circuit theory of a concept proposed by W. S. McCulloch in connection with neuron net theory (see MIT Research Lab. Electronics. Quart. Progr. Rept. 49, Apr. 15, 1958).
matrix is a unit with probability $p_{j i}$. Recall that ( $R_{j i}$ ) is associated with an array of designation numbers and that a unit in the $j$ th row and $i$ th column of ( $R_{j i}$ ) means that the $i$ th position (column) of the array is composed of the binary number $j$. Hence a nonzero probability element in the $j$ th row and $i$ th column of ( $P_{j i}$ ), namely, $p_{j i}$, means that the probability that the array's ith position is composed of the binary number $j$ is $p_{j i}$. As an illustration, consider the array of designation numbers (where we have repeated the basis for convenience):

| $\begin{aligned} & \# A_{1}{ }^{i} \\ & \# A_{2} \\ & \hline \end{aligned}$ | 0 | 0 |  | $\begin{aligned} & 2 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ |  | 3 1 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\# h_{1}$ | 0 | 0 | 1 | 0 | 0 | 1 |
| $\# h_{2}$ | 0 | 0 | 0 | 0 | 1 | 1 |
| Probability | 1 | p | $p$ | $\bar{p}$ | $p$ | 1 |

From this
where $\bar{p}=1-p$ as above. Observe that since the elements in a column of the ( $R_{j i}$ ) matrix are associated with a mutually exclusive and exhaustive set of possibilities (i.e., possible columns of the designation-number array) then the arithmetic sum of the probabilities in a column of the corresponding ( $P_{j i}$ ) matrix must be unity.

Let us recall that the ( $R_{j i}$ ) matrix associated with two levels of gating is the logical matrix product of the ( $R_{j i}$ ) matrices of each level. This is also true of the corresponding ( $P_{j i}$ ) matrices, except that the ordinary (not the logical) matrix multiplication is performed. For example, suppose that failure of gate $g_{1}$ (see Fig. 19-9) will result in $g_{1}=h_{1}$ and failure of gate $g_{2}$ in $g_{2}=h_{2}$, each with failure probability $p$; then the same ( $P_{j i}$ ) matrix will be associated with the second gating level as for the first. Thus we form

$$
\left(\begin{array}{cccc}
1 & \bar{p} & \bar{p} & 0 \\
0 & p & 0 & 0 \\
0 & 0 & p & 0 \\
0 & 0 & 0 & 1
\end{array}\right) \times\left(\begin{array}{cccc}
1 & \bar{p} & \bar{p} & 0 \\
0 & p & 0 & 0 \\
0 & 0 & p & 0 \\
0 & 0 & 0 & 0
\end{array}\right)=\left(\begin{array}{cccc}
1 & \bar{p}+\bar{p} p & \bar{p}+\bar{p} p & 0 \\
0 & p^{2} & 0 & 0 \\
0 & 0 & p^{2} & 0 \\
0 & 0 & 0 & 1
\end{array}\right)
$$

To see that this result is the desired probabilistic matrix, observe that the value of each element represents the probability that the element is a unit in the corresponding ( $R_{j i}$ ) matrix. For the arithmetic sum of products involved in finding an element of the result matrix is simply the sum of the probabilities of the exhaustive and mutually exclusive ways in which the corresponding ( $R_{j i}$ ) element can be a unit. Each product of this sum has two terms, which represent the probabilities of independent events (of
being units) that must occur if the element is to be a unit in that way. From our resulting adapted matrix we can now form the result array [observing that $\left.\bar{p}+\bar{p} p=(1-p)+(1-p) p=1-p^{2}=\overline{p^{2}}\right]$ :

| Position $i$ | 0 | 1 |  | 2 |  | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Probability | 1 | $\overline{p^{2}}$ | $p^{2}$ | $\overline{p^{2}}$ | $p^{2}$ | 1 |
| $\# g_{1}$ | 0 | 0 | 1 | 0 | 0 | 1 |
| $\# g_{2}$ | 0 | 0 | 0 | 0 | 1 | 1 |

A word of caution at this point: We cannot in general take this result array as representing all possible designation numbers by choosing all combinations of columns in each position, as we did above when solving type 3 problems with the ( $R_{j i}$ ) matrix. For in general designation numbers can be formed from the probabilistic result array that cannot result from any simultaneous combination of gate failures. On the other hand all designation numbers that can result from gate failures can be formed from some column combinations appearing in the result array.

In our example suppose that we desire to find for the first two levels of gating the probability that an erroneous result for $g_{1}$ will be obtained. This probability is equal to 1 minus the probability that $g_{1}$ is not in error. For no failure $g_{1}=A_{1} \cdot A_{2}$; thus, from the probabilistic array, $\# g_{1}=0001$ with probability $1 \cdot \overline{p^{2}} \cdot\left(\overline{p^{2}}+p^{2}\right) \cdot 1=\overline{p^{2}}=1-p^{2}$, and the probability of failure is $1-\left(1-p^{2}\right)=p^{2}$.

Continuing with our example of Fig. 19-3, assunc dinai he failure oí gate $f_{1}$ will result in $f_{1}=g_{1}$ and failure of the $f_{2}$ gate in $f_{2}=g_{2}$. Then the same ( $P_{j i}$ ) matrix holds for the third level of gating, and we form

$$
\left(\begin{array}{llll}
1 & \bar{p} & \bar{p} & 0 \\
0 & p & 0 & 0 \\
0 & 0 & p & 0 \\
0 & 0 & 0 & 1
\end{array}\right) \times\left(\begin{array}{llll}
1 & \overline{p^{2}} & \overline{p^{2}} & 0 \\
0 & p^{2} & 0 & 0 \\
0 & 0 & p^{2} & 0 \\
0 & 0 & 0 & 1
\end{array}\right)=\left(\begin{array}{cccc}
1 & \overline{p^{2}}+\bar{p} p^{2} & \overline{p^{2}}+\bar{p} p^{2} & 0 \\
0 & p^{3} & 0 & 0 \\
0 & 0 & p^{3} & 0 \\
0 & 0 & 0 & 1
\end{array}\right)
$$

Observing that $\bar{p}^{2}+\bar{p} p^{2}=1-p^{3}=\overline{p^{3}}$, we have the array:

| Position $i$ | 0 | 1 |  | 2 |  | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Probability | 1 | $\overline{p^{3}}$ | $p^{3}$ | $\overline{p^{3}}$ | $p^{3}$ | 1 |
| $\# f_{1}$ | 0 | 0 | 1 | 0 | 0 | 1 |
| $\# f_{2}$ | 0 | 0 | 0 | 0 | 1 | 1 |

As is easily seen, for no failure $f_{1}=A_{1} \cdot A_{2}$; hence the probability that $\# f_{1}=0001$ is $1 \cdot \overline{p^{3}} \cdot\left(\overline{p^{3}}+p^{3}\right) \cdot 1=\overline{p^{3}}=1-p^{3}$, and the probability of failure is $1-\left(1-p^{3}\right)=p^{3}$.

One further remark is necessary. We have just determined the probability of functional failure of the output of the circuit of the figure. Observe that, even if there is functional failure of the circuit, for three of the four possible values of $A_{1}, A_{2}$ the bit output will be correct, namely,
when $A_{1}, A_{2}$ take on values

$$
\begin{array}{llll}
A_{1} & 0 & 0 & 1 \\
A_{2} & 0 & 1 & 1
\end{array}
$$

Let us suppose that they occur randomly, i.e., that the probability of a given combination of $A_{1}$ and $A_{2}$ is $1 / 4$. Then the probability of a bit failure is $p^{3} / 4$. In Fig. 19-10 we have graphed the probability of bit failure (dashed lines) and functional failure (solid lines) for our example, as functions of $p$.


Fig. 19-10. $p$ is the probability of failure of a gate; $q$ is the probability of failure of the configuration in Fig. 19-9.


Fig. 19-11. Configuration for increasing the reliability of or gates.

It is easy to see that our probabilistic-logic technique is perfectly general and will apply to any sets of functions appropriately connected in levels (see, for example, Fig. 14-5). However, in order to cover all possible output functions with their corresponding probabilities, the nature of the malfunction and its probability must be explicitly stated. A little experimentation will show that only for certain special arrangements of some functions and malfunctions will the output be significantly more reliable than the component circuits. Our example illustrated one of these special cases. Consider now two further important examples, one concerned with increasing reliability of or gates and the other concerned with alternate levels of or-not and and-not circuits. The or-gate configuration appears in Fig. 19-11, in which for inputs, say $W_{1}, W_{2}$, the failure results in an output of $W_{1}$ (instead of $W_{1}+W_{2}$ ). Each level has the same ( $P_{j i}$ ), namely,

$$
\left(\begin{array}{llll}
1 & 0 & 0 & 0 \\
0 & p & 0 & 0 \\
0 & 0 & p & 0 \\
0 & \bar{p} & \bar{p} & 1
\end{array}\right)
$$

For $n$ levels the functional-failure probability is $p^{n}$ as in the case of the and-gate configuration. The alternate or-not, and-not circuit levels of Fig. 19-12, where for inputs $W_{1}, W_{2}$ the failure results in an output of $\bar{W}_{1}$ (instead of $\overline{W_{1}+W_{2}}$ in the former or $\overline{W_{1} \cdot W_{2}}$ in the latter), present respective probability matrices


Fig. 19-12. Configuration for increasing the reliability of or-inverter gates.

$$
\left(\begin{array}{llll}
0 & \bar{p} & \bar{p} & 1 \\
0 & 0 & p & 0 \\
0 & p & 0 & 0 \\
1 & 0 & 0 & 0
\end{array}\right) \quad \text { and } \quad\left(\begin{array}{cccc}
0 & 0 & 0 & 1 \\
0 & 0 & p & 0 \\
0 & p & 0 & 0 \\
1 & \bar{p} & \bar{p} & 0
\end{array}\right)
$$

If there are an odd number of levels $n$, then the functional-failure probability for the or-not circuit is $p^{n}$.

Majority Logic. The probabilistic-logic approach has the disadvantage that the precise forms of possible functional failures must be known. The majority-logic approach does not have this disadvantage; however, the increased reliability that can be gained is probably not so great. An additional circuit element must be used, called a majority circuit, and as we shall see, to gain any reliability at all the failure probability of the majority circuit must be less than that of the gating circuits themselves.
The majority-iogic technique depends on the formation of three repiicas of the gating functions, each being fed into the majority circuit (see Fig. 19-13a, where $M$ represents the majority element). At any time the output bit of the majority circuit will be that of the majority of the inputs. Thus, if $p_{m}$ represents the probability that an operating majority element will put out an erroneous result and $p$ the failure probability of a gating circuit (where in Fig. 19-13a $F_{1}, F_{2}$, and $F_{3}$ are gating circuits), then

$$
\begin{equation*}
p_{m}=3 p^{2}(1-p)+p^{3}=3 p^{2}-2 p^{3} \tag{19-1}
\end{equation*}
$$

since for failure either two of the three inputs or all three inputs must have failed. Of course it is possible to have majority circuits work on a majority of three out of five inputs, four out of seven, etc. (see Exercise $g$ ). In any case the majority element itself may fail, with failure probability $m$. Thus the total probability of failure of the output of the majority element becomes

$$
\begin{equation*}
p^{\prime}=p_{m}(1-m)+m=m\left(1-p_{m}\right)+p_{m} \tag{19-2}
\end{equation*}
$$

We certainly desire that $p^{\prime}<p$ if the majority-logic scheme is to contribute at all to increased reliability. Solving for $m$ in $p^{\prime}<p$, find

$$
\begin{equation*}
m<\frac{p-p_{m}}{1-p_{m}}=\frac{p-3 p^{2}+2 p^{3}}{1-3 p^{2}+2 p^{3}} \tag{19-3}
\end{equation*}
$$

( $<p$, since $p$ is less than unity). Note that, as $p \rightarrow 1 / 2$ or $p \rightarrow 0, m \rightarrow 0$; thus $m$ has a maximum for $0<p<1 / 2$. To find this maximum, let

$$
m=\frac{p-3 p^{2}+2 p^{3}}{1-3 p^{2}+2 p^{3}}
$$

and set $d m / d p=0$, finding

$$
\begin{equation*}
4 p^{3}-9 p^{2}+6 p-1=0 \tag{19-4}
\end{equation*}
$$

Factoring, we get $(4 p-1)(p-1)(p-1)=0$, whence $p=1 / 4$ for maximum $m$. Substituting $p=1 / 4$ into Eq. (19-3), $m<1 / 9$ at best.

(a)

Fig. 19-13. (a) Use of majority circuits; (b) same circuitry without majority elements.
Since $p^{\prime}$ is limited by the probability of the majority circuit, let us use three such circuits, as shown in Fig. 19-13a. The probability $p_{f}^{\prime}$ that either or both inputs to any $F_{3}$ of the figure are erroneous becomes

$$
p_{f}^{\prime}=2 p^{\prime}\left(1-p^{\prime}\right)+p^{2}=2 p^{\prime}-p^{\prime 2}
$$

The probability of an erroneous output for $F_{3}$, considering both failure of $F_{3}$ and erroneous inputs, is

$$
p^{\prime \prime}=p_{f}^{\prime}(1-p)+p
$$

If we did not use the majority circuits (see Fig. 19-13b), this probability would be

$$
s=1-(1-p)^{3}=3 p-3 p^{2}+p^{3}
$$

Observe that, if we let $m$ equal the expression in Eq. (19-3), then $p^{\prime \prime}=s$; that is, there would be no point in using the majority circuits at all unless $m$ is less than that value.

Now let us consider the next level of majority circuits shown in Fig. 19-13a. Analogous to Eqs. (19-1) and (19-2), we have
and

$$
\begin{gathered}
p_{m}^{\prime \prime}=3 p^{\prime \prime 2}-2 p^{\prime \prime 3} \\
p^{\prime \prime \prime}=p_{m}^{\prime \prime}(1-m)+m
\end{gathered}
$$

giving us, analogous to Eq. (19-3),

$$
m<\frac{p^{\prime \prime}-p_{m}^{\prime \prime}}{1-p_{m}^{\prime \prime}}
$$

From Eq. (19-4), by substituting $p^{\prime \prime}$ for $p$, we can find that value of $p^{\prime \prime}$ for which $m$ is a maximum, namely, $p^{\prime \prime}=1 / 4$. But the largest value $m$ can take is $\left(p^{\prime \prime}-p_{m}^{\prime \prime}\right) /\left(1-p_{m}^{\prime \prime}\right)$, which gives

$$
p^{\prime \prime}=s=3 p-3 p^{2}+p^{3}
$$

Hence the maximum value of $m$ must correspond to a $p$ that satisfies

$$
3 p-3 p^{2}+p^{3}-1 / 4=0
$$

Solving this for $p, p=1-\sqrt[3]{3 / 4}=0.092$. Substituting this back into Eq. (19-3), we find that

$$
m<0.070
$$

for any advantage to be obtained from two levels of majority circuits. In fact $m$. would have to be even smaller if we chose $p$ other than 0.092 for our example. Thus we find that the effectiveness of majority cirouits is highly dependent on the reliability of the majority circuits themselves.

## EXERCISES

(a) Devise the logical design of a circuit that will accomplish a parity check.
(b) Devise the logical design of a circuit that will correct two errors in an errorcorrecting codification of the type described in Sec. 7-7.
(c) Using the methods of probabilistic logic, determine the failure probability of $n$ levels of and gating of the type shown in Fig. 19-9.
(d) Consider the probabilistic analysis of an and-gating configuration of the type shown in Fig. 19-9, but allow three inputs to each gate, and have three such and gates on each level.
(e) Consider the extension of the configuration of Fig. 19-12 to $n$ levels of $o r$-inverter and and-inverter gating. What function is generated at the output of the even-level gates? What are the odd- and even-level output failure probabilities?
(f) Form a configuration, similar to that of Fig. 19-12, starting the first level with and-not circuits and then alternating. Analyze this configuration for failure probabilities.
(g) In majority logic suppose that $2 n+1$ functions $F_{1}$ are connected to a majority circuit whose output will be that of the majority of the inputs. What would be the general expression for $p_{m}$ in terms of $p$ ? (Hint: Recall the binomial expansion.)
( $h$ Let $m=0$, and graph $p^{\prime}$ as a function of $p$ for $n=1,2$, and 3 , where $2 n+1$ is the number of inputs to the majority circuit.
(i) Logically design a majority circuit for three inputs, using and gates and or gates.
(j) Plot $p^{\prime \prime \prime}$ as a function of $p$ for various values of $m$.

## 19-5. Additional Topics

a. Parametron References. The following articles contain additional information concerning the Parametron:

Goto, E.: New Parametron Circuit Element Using Non-linear Reactance, KDD Hankyu Shiryo, no. 52, November, 1954. (In Japanese.)
--: On the Application of Parametrically Excited Non-linear Resonators, Denki Tsushin Gakkai-shi, vol. 38, pp. 770-775, October, 1955. (In Japanese.)
--: The Parametron, a Digital Computing Element Which Utilizes Parametric Oscillation, Proc. IRE, vol. 47, pp. 1304-1316, August, 1959. (A correction, by E. Goto, R. G. Allen, and J. E. Mezei, appeared ibid., p. 1840, November, 1959.)

Hushimi, D., and K. Kataoka: Memory for the Parametron, Employing Nondestructive Readout of Information Stored as Residual Polarization, Proc. Japan. Inst. Elec. and Communs. Engrs., vol. 40, pp. 448-453, April, 1957. (In Japanese.)
Introduction to Parametron, Kenshi Kogyo, vol. 4, no. 11, p. 4, 1955. (In Japanese.)
Muroga, S.: Elementary Principle of the Parametron and Its Application to Digital Computers, Datamation, vol. 4, pp. 31-34, September-October, 1958.
—— and K. Takashima: The Parametron Digital Computer MUSAS(H)INO-1, IRE Trans. on Electronic Computers, vol. EC-8, pp. 308-316, September, 1959.
Takada, S.: "Hipac-1 (Hitachi Parametron Automatic Computer)," Hitachi, Ltd., Tokyo, December, 1958.
Takahashi, H.: The Parametron, Taugakkai-shi, vol. 39, no. 6, p. 56, 1956. (In Japanese.)
Terada, H.: The Parametron an Amplifying Logic Element, Control Eng., April, 1959, pp. 110-115.
Wigington, R. L.: A New Concept in Computing, Proc. IRE, April, 1959, pp. 516-523.
Yamada, S., et al.: Magnetic Core Memory of the Parametron Digital Computer Musasino-1, Japan. IEE J., vol. 33, pp. 1149-1155, November, 1958. (In Japanese, English summary.)

## b. References on Reliability

Bellman, R., and S. Dreyfus: On the Computational Solution of Dynamic Programming Processes-XVI: Reliability of Multicomponent Devices, Rand Corp. Rept. RM-2245, Sept. 2, 1958.
Depian, L., and N. T. Grisamore: Reliability Using Redundancy Concepts, George Washington Univ. Tech. Rept., February, 1959.
Lowenschuss, O.: Restoring Organs in Redundant Automata, Inform. and Control, vol. 2, no. 2, pp. 113-136, June, 1959.
McCulloch, W. S.: Stable, Reliable, and Flexible Nets of Unreliable Formal Neurons, MIT Research Lab. Electronics, Quart. Progr. Rept., April, 1958, pp. 118-129.
--: Stability of Biological Systems, Brookhaven Symposia in Biol., vol. 10, pp. 207-215, 1958.
———and W. Pitts: A Logical Calculus of the Ideas Immanent in Nervous Activity, Bull. Math. Biophys., vol. 5, 1943.
Moore, S. F., and C. E. Shannon: Reliable Circuits Using Less Reliable Relays, J. Franklin Inst., vol. 262, pp. 191-208, 281-297, 1956.

Moskowitz, F., and J. McLean: Some Reliability Aspects of System Design, Astia Document AD 66802.

Pieruschka, E.: Mathematical Foundation of Reliability Theory, Astia Document AD 203824.
Proc. Statist. Tech. Missile Evaluation Symposium, Aug. 5-8, 1958.
Von Foerster, H.: Basic Concepts of Homeostasis, Brookhaven Symposia in Biol., vol. 10, pp. 216-242, 1958.
Von Neumann, J.: Probabilistic Logics, in C. E. Shannon and J. McCarthy (eds.), "Automata Studies," pp. 43-98, Princeton University Press, Princeton, N.J., 1956.

Wing, Omar: Reliability Study of Communication Systems, Astia Document AD 204139.

## SEMICONDUCTOR ELEMENTS IN DIGITAL-CIRCUIT DESIGN

## 20-1. Introduction

Modern computers are almost all being constructed with transistors and other solid-state components, because of the generally greater reliability, longer life, smaller size, and lower power requirements of these components, compared with vacuum tubes. In this text we therefore consider only circuits using solid-state components, since in any case the tube circuits used in the older computers are almost directly analogous to their transistor counterparts. First, in Secs. $20-2$ and $20-3$ the physics of diodes and transistors is briefly discussed, so that the reader may gain an intuitive grasp of their properties and functional mechanisms. Next, in Sec. 20-4 is presented a simplified transistor equivalent circuit, which is most suitable for digital-electronic-circuit design. Since the subject of transistor equivalent circuits constitutes a large field in itself, many loose ends are left for the inquisitive reader to follow up elsewhere; but the main transistor properties useful for our purposes are stressed. Sections 20-5 and 20-6 discuss various examples of the application of diodes and transistors to digital circuits. Since computer-circuit engineering is advancing rapidly, our purpose in presenting these examples primarily is to illustrate the principles of the methods employed, and not the specific circuits themselves. Finally in Sec. 20-7 we present a brief introduction to the potentially highly important tunnel diode.

## 20-2. Solid-state Semiconductor Devices

Semiconductors. The solid-state devices under consideration all depend for their operation on the properties of semiconductor materials, which have an electrical conductivity less than the high conductivity of a metal but greater than the low conductivity of an insulator. Germanium (Ge) and silicon (Si) are the most commonly used semiconductors. As solids they form crystals in which the atoms are arranged in a lattice, each atom being surrounded by four other atoms. Each germanium atom has four valence electrons, and in the lattice structure each of these valence electrons is shared with one of the neighboring atoms through a covalent bond. The pairs of dots between adjacent atoms in the lattice pictured in Fig. 20-1 $a$ indicate the shared electrons of the covalent bond. The core of each germanium atom (i.e., the
nucleus and the filled shells of electrons) has a net +4 charge (in units of electron charge), which is balanced by the four valence electron charges so that the lattice is electrically neutral. The valence bonds are relatively weak and can be broken by the thermal energy of the lattice vibrations. A broken bond will free an electron so that it may carry current, leaving in its place what is called a hole (see Fig. 20-1b).

(a)

(b)

(d)

Fig. 20-1. Diagrammatic representation of a germanium lattice section. The pairs of dots represent shared electrons. (a) No free electrons, no holes; (b) thermal energy frees an electron leaving a hole; (c) pentavalent impurity presents a free electron; (d) trivalent impurity leaves a hole.

The energy required to break a bond and free an electron (i.e., to make a hole) is about 0.75 ev for Ge and 1.12 ev for Si . The neighborhood of the free electron will of course have a net negative charge, and similarly the neighborhood of the hole will have a net positive charge.

The conductivity of the material arises from two sources: the first is the free electrons; the second is concerned with the holes. When a hole appears, it is relatively easy for a neighboring covalent electron to break its bond and fill the hole, leaving a hole in its previous position. Thus it appears as though the hole had moved, as though there were movement of a positive charge. For this reason we speak of the conductivity due to the virtual movement of holes whenever an electron fills one hole, leaving another. Electron-hole pairs are continually being formed by thermal
agitation, while other electron-hole pairs disappear by recombination. The conductivity is proportional to the number of electron-hole pairs available at any time: for pure germanium at room temperature there is about one electron-hole pair for each $5 \times 10^{10}$ germanium atoms.

The electronic properties of interest to us, however, arise when minute amounts of impurities are introduced into the crystal lattice. First consider a five-valence-electron impurity such as antimony (Sb). As shown in Fig. $20-1 c$, the Sb atom will find a place in the Ge lattice and share four of its valence electrons with its Ge neighbors in covalent bonds. However, the fifth valence electron will not be bound and therefore will behave as a free electron, contributing to the conductivity of the material. (More accurately this fifth electron is lightly bound but can be freed by an energy of about 0.01 ev.) Such an impurity is called a donor, or $n$-type impurity, because it contributes (donates) electrons, or negative ( $n$ ) charges. These electrons appear in addition to those being formed normally in the germanium by thermal energy.

On the other hand a three-valence-electron impurity, such as indium (In), can be introduced into the lattice. As shown in Fig. 20-1d, the three valence electrons of the In atom will form covalent bonds with its Ge neighbors; but the fourth bond will be incomplete, leaving a hole which can accept an electron. Such impurities are called acceptors, or $p$-type impurities ( $p$ for positive). These holes appear in addition to those normally appearing in the germanium.

In summary, in a pure semiconductor (called an intrinsic semiconductor) the numbers of free electrons and holes are equal and are determined by statistical equilibrium in pair formation and recombination. In a semiconductor with pentavalent or trivalent impurities (called a doped semiconductor) the conductivity is increased by electric-charge carriers that are either predominantly electrons ( $n$-type) or predominantly holes ( $p$-type).

Semiconductor Junctions and Diodes. The motion of the holes and electrons through a semiconductor is due not to mutual repulsion or attraction but rather to the process of diffusion, which is a "randomwalk" phenomenon analogous to the motion of gas molecules. In general, if there is a high concentration of holes in one part of a semiconductor and a low concentration in another part, the holes will diffuse from the high-concentration area into the low-concentration area. The application of an electric field will cause the diffusing holes to drift generally in the direction of the field. The same of course holds for the free electrons (drifting against the field).

Suppose that we form a junction between a $p$-type and an $n$-type semiconductor [see Fig. 20-2a(1)]. Initially there will be relatively greater concentrations of holes in the $p$-type and of electrons in the $n$-type semiconductor. Hence the holes of the $p$ type will diffuse across the junction into the $n$ type, and the free electrons of the $n$ type will diffuse into the $p$ type. The result will be a recombination of holes and electrons near the junction to form negative ions of, for example, In in the $p$-type
semiconductor and positive ions of Sb in the $n$-type semiconductor. A net charge density will be formed, as shown in Fig. 20-2b(1). This charge density will of course be associated with an electric potential, as shown in Fig. 20-2c(1). The effect of this potential is evidently to inhibit the diffusion of holes into the $n$-type and of electrons into the $p$-type material. Thus a state of equilibrium will be established.

This equilibrium is, however, dynamic-i.e., there are still random holes and free electrons moving back and forth across the boundary. The movement of holes from the $p$-type to the $n$-type material, or of free electrons from the $n$-type to the $p$-type material, is called majoritycarrier current ( $I_{m a j}$ ), since the movement is of the majority charge carriers (due to the doping) in the materials in which the movements originate. Conversely the movement of holes from the $n$ type to the $p$ type, and of electrons from the $p$ type to the $n$ type, is called minority-carrier current $\left(I_{\min }\right)$. This latter current is due to hole-free electron pairs being formed in each material when Ge bonds are broken by thermal energy; then holes produced in the $n$ type will "fall down the potential barrier" into the $p$-type material, while the electrons produced in the $p$ type will be drawn into the $n$ type by theelectr on potential. In equilibrium, then, with due regard to the directions of these currents, $I=I_{m a j}-I_{m i n}=0$, as illustrated in Fig. 20-2d(1).

Consider now the effect of applying across the $p-n$ junction a potential which opposes the flow of $I_{m a j}$ (said to be in the reverse direction), as shown in Fig. 20-2(2). Holes in the $p$ type, and electrons in the $n$ type, will drift away from the junction, the charge density will extend farther from the junction on both sides, and the potential barrier to majority-carrier current will be increased, whence the majority-carrier current itself will be decreased. The minority-carrier current, on the other hand, is dependent only on the rate of formation of hole-electron pairs and hence will stay approximately the same as for the condition of no applied voltage. The net current across the junction in the reverse direction, i.e., from $n$-type to $p$-type material, will therefore be very small.

But consider the effect of applying a potential across the junction in the direction of $I_{m a j}$ (that is, in the forward direction), as shown in Fig. 20-2(3). In this case the charge density is confined closer to the $p-n$ boundary, the potential barrier is reduced, and more majority carriers are able to diffuse across the boundary. The minority-carrier current still remains about the same, being relatively independent of the applied voltage.

It can be shown by means of statistical mechanics that
and hence

$$
\begin{align*}
I_{m a j} & =I_{m i n} e^{V / \kappa}  \tag{20-1}\\
I & =I_{m a j}-I_{\min }=I_{\min }\left(e^{V / \kappa}-1\right) \tag{20-2}
\end{align*}
$$

where $I=$ net current, amp (in direction of majority current)
$V=$ applied voltage
$\kappa=T / C$

| 앙 |  | (1) No voltage applied | (2) Reverse voltage applied | (3) Forward voltage applied |
| :---: | :---: | :---: | :---: | :---: |
|  | (a) $p \cdot n$ junction |  |  |  |
|  | (b) Charge density |  |  |  |
|  | (c) Electric potential |  |  |  |
|  | (d) Recombination and thermal currents | $\begin{aligned} & I_{\text {maj }}^{\longrightarrow} \longrightarrow \\ & \square \longrightarrow I_{\text {min }}^{\longrightarrow} \end{aligned}$ | $\begin{aligned} & I_{\text {maj }} \rightarrow \\ & \square \\ & \stackrel{\leftrightarrow}{\leftarrow} \\ & \leftrightarrow I_{\text {min }} \end{aligned}$ |  |

Fig. 20-2. The $p-n$ junction (1) with no applied voltage, (2) with reverse applied voltage, and (3) with forward applied voltage. (a) The distributions of holes and electrons; (b) the charge-density distributions near the junction resulting from negative ions ( - ) and positive ions ( + ); (c) the resulting electric potentials; and ( $d$ ) the directions of hole and electron movement (short arrows with circles and dots, respectively) and the relative magnitudes of the majority-carrier current $I_{\text {mai }}$ and the minority-carrier current $I_{\text {min }}$.
with $T$ the temperature of the semiconductor in degrees Kelvin and $C$ the ratio of the electronic charge to Boltzmann's constant $(11,600)$-see the solid line in Fig. 20-3. A semiconductor device with one such


Fig. 20-3. Voltage-current characteristic of an $n-p$ junction diode. $p-n$ junction across which a voltage can be applied, called a diode, has the characteristic of high conductivity in the forward direction and low conductivity (very high back resistance) in the reverse direction. However, if the reverse voltage is made very large, an entirely different phenomenon occurs, the Zener effect: at some critical reverse voltage the back resistance goes practically to zero, and the current is limited only by the voltage-source resistance (see the dashed line in Fig. 20-3). The Zener effect is caused by the breakdown of valence bonds to produce new current carriers; these carriers acquire energy from the field and cause further carriers through ionization by collision, and so forth, as so-called avalanche breakdown occurs.

## EXERCISES

(a) If $I_{\min }=10 \mu \mathrm{a}$, compute the voltage-current characteristic of a diode at $20^{\circ} \mathrm{C}$ and at $30^{\circ} \mathrm{C}$.
(b) What other elements besides $\mathrm{Ge}, \mathrm{Sb}$, and In can be used to make a semiconductor diode?

## 20-3. Transistors

Physical Description. The physical model of a transistor can most easily be understood as an extension of the diode model. In the diode, or single-junction case, the small minority-carrier current across the junction is approximately independent of the applied voltage because it depends primarily on the rate of production (by thermal agitation of the Ge covalent bands) of holes in the $n$-type and electrons in the $p$-type semiconductors. The only way to increase this reverse current is to supply the $n$-type material with holes or the $p$-type with electrons. Since a $p$-type semiconductor can be a supplier of holes, suppose that we form a second junction with a $p$-type material to the right of our original diode (see Fig. 20-4). With no applied voltage we still have not increased the current in the reverse direction, for the holes and electrons will come to equilibrium as shown in $1 a$ of Fig. 20-4, to give an equilibrium electric potential as shown in $1 b$. However, if we decrease the potential difference of the middle $n$-type with respect to the added right-hand $p$-type material, then as we have already seen above, holes will diffuse into the $n$-type material. These holes can now diffuse across the $n$-type substance and


Fig. 20-4. The $p-n-p$ junction (transistor) with (1) no applied voltage and (2) forward and reverse voltages applied across the respective junctions. (a) Distributions of holes and free electrons; (b) electric potentials; and (c) the resultant current directions.
into the left-hand $p$-type substance, causing an increase in the reverse current across the left junction, as desired. We can better our chances of getting a reverse current by increasing the potential difference across the junction in question (the left junction) so that the holes diffusing across the $n$-type substance will "fall down the potential hill." The resultant potential curve is illustrated in Fig. 20-4(2).

The two-junction device just described is called a $p-n-p$ transistor, the center $n$-type substance is called the base, the right-hand $p$-type supplier of holes the emitter, and the left-hand $p$-type substance the

| Collector | Base | Emitter |
| :---: | :---: | :---: |
| $p$ type | $n$ type | $p$ type |



Fig. 20-5. $p-n-p$ transistor symbolism, with conventional current and appliedvoltage directions. collector. The use of transistors in digital circuits depends primarily on their switching properties. The emitter-to-base voltage controls the conduction of current through the device, from the emitter through the base to the collector. If the applied emitter-to-base voltage $V_{e}$ is small, no diffusion of holes can occur across the emitter-base junction. Increasing $V_{e}$ in the forward direction allows holes to enter the base from the emitter, to diffuse across the base, to fall down the collector-base potential hill $V_{c}$, and thus to contribute to an increased collector current. Figure $20-5$ presenis ine conventional symbolism for a transistor and aiso gives the conventional current directions, in terms of which the actual collector and base currents, $I_{c}$ and $I_{b}$ as shown in Fig. 20-4c(2), are of course negative during conduction.

It is important that the base current $I_{b}$ be relatively small during conduction so that voltage or current amplification can be obtained. This goal is achieved in the physical design of the transistor. To minimize the contribution to $I_{b}$ of electrons crossing the base-emitter junction, the doping of the base is made much smaller than the doping of the emitter; thus the base-emitter current consists primarily of holes. Second, the contribution to $I_{b}$ of electrons recombining with the holes diffusing across the base is minimized by making the base very thin; this reduces the time required for the holes to diffuse across the base from emitter to collector, preventing too many recombinations. Since the conduction through the base-emitter junction is mainly by holes, a measure of the number of recombinations that do occur in the base is the proportion actually reaching the collector, of the holes that crossed the emitter-base junction. This is given by the ratio of the change in magnitude of the collector current $I_{c}$ to the change in magnitude of the emitter current $I_{e}$ for a fixed voltage across the collector-base junction. Calling this ratio $\alpha$, we have

$$
\begin{equation*}
\alpha=\left|\frac{\Delta I_{c}}{\Delta I_{e}}\right|_{V_{c}=c o n s t} \tag{20-3}
\end{equation*}
$$

The value of $\alpha$ is close to unity, typical values being around 0.98 .
Since from the diode equation (20-2) the contribution from the collec-tor-base junction is $I_{\min }\left(e^{x}-1\right)$ for $x=V_{c} / \kappa$ and the contribution from the holes of the emitter current is $\alpha I_{e}$, we have (observing our current conventions for transistors), replacing $I_{\min }$ by $I_{c o}$, the collector minority carrier current, approximately

$$
\begin{equation*}
I_{c}=I_{c o}\left(e^{x}-1\right)-\alpha I_{e} \quad \text { for } x=\frac{V_{c}}{\kappa} \tag{20-4}
\end{equation*}
$$

When the transistor is conducting, the collector-base junction is reversebiased; $e^{x}$ is very small compared with unity and can be neglected. Hence Eq. (20-4) reduces to the approximation $I_{c}=-I_{c o}-\alpha I_{e}$. From our current convention we have

$$
\begin{equation*}
I_{b}+I_{c}+I_{e}=0 \tag{20-5}
\end{equation*}
$$

whence $I_{c}=-I_{c o}+\alpha\left(I_{b}+I_{c}\right)$. Thus at constant $V_{c}$, for the ratio, called $\beta$, of the changes in magnitude of the collector and base currents, we have

$$
\begin{equation*}
\beta=\left|\frac{\Delta I_{c}}{\Delta I_{b}}\right|_{V_{c}}=\frac{\alpha}{1-\alpha} \tag{20-6}
\end{equation*}
$$

Characteristic Curves of Transistors. Figure 20-6a shows typical $V_{c}$ versus $I_{c}$ characteristic curves, for constant $I_{e}$, of a transistor in the grounded-base configuration. Observe that the $V_{c}$ and $I_{c}$ axes are negative according to our current and voltage conventions (Fig. 20-5). Three regions of transistor operation can be distinguished (see Fig. 20-6a): the cutoff region 1 , the active region 2 , and the saturation region 3 . In the cutoff region the base-emitter voltage difference is too large to allow for diffusion of holes into the base from the emitter, even though there is a reverse voltage applied to the collector-base junction. Thus $I_{e}=0$, and since the base-emitter voltage is reversed, $e^{x} \ll 1$; hence from Eq. (20-4), $I_{c}=-I_{c o}$. In the active region the transistor conducts as described above. Saturation occurs when the collector-base voltage difference is too small to keep the holes flowing through the junction. The collector $p$-type material then becomes saturated with holes, and the collector current drops to zero. In fact the collector may become for-ward-biased and supply holes back to the base: the base then receives holes from both the emitter and the collector, and the hole density in the base becomes large. We shall have more to say about this phenomenon when we discuss over-all time responsiveness of transistors.

Figure $20-6 b$ shows a set of $V_{c e}$ versus $I_{c}$ characteristic curves for constant $I_{b}$, for the same transistor connected in a grounded-emitter configuration. The active and saturated regions are clearly seen; the cutoff

Grounded-base confiçuration
$\alpha=0.98$

(a)

Grounded-emitter configuration



Fig. 20-6. (a) Grounded-base $I_{c}$ versus $V_{c}$ characteristic curves for constant values of $I_{e}$; (b) grounded-emitter $I_{c}$ versus $V_{c e}$ characteristic curves for constant values of $I_{b}$. Curves are approximately those for the Raytheon 2 N 414 transistor, which has $\alpha=0.98, \beta=60$ (at -12 volts), average $I_{c o}=-0.002 \mathrm{ma}$, and average $I_{e o}=-0.002 \mathrm{ma}$.
region is not, because the base current at cutoff is equal to or greater than $I_{c o}$. These curves are generally more useful than the $V_{c}-I_{c}$ curves because the current gain $\beta$ can be easily calculated from these. For example, if the collector is attached to a -10 -volt supply, through a resistor $R=2,000$ ohms, then from the active region in the curves we can observe that a change in $I_{b}$ from 0 to $-100 \mu$ a will cause changes in $V_{c e}$ of from -9.8 volts to -0.2 volt and in $I_{c}$ of from -0.005 ma to -4.82 ma (see the load line in Fig. 20-6b).

Response Times. There is a delay in transmitting the leading edge of a pulse through a transistor. This delay can be related to the density of holes in the base (i.e., of the principal minority current carriers with respect to the collector-base junction). Consider, for example, Fig. 20-7, which illustrates the density distribution of holes in the base. In the cutoff region both emitter and collector are reverse-biased with respect to the base, and hence whatever holes (minority carriers) due to thermal pair generation are present in the base will diffuse toward the emitter and collector, so that the hole-density distribution is as shown in the figure. When an input signal


Fig. 20-7. Density distribution of holes in the base of a transistor for the cutoff, active, and saturation regions. drives the emitter-base junction into the active (forward-biased) region, holes diffuse from the emitter into the base and the hole density builds up near this junction as shown in Fig. 20-7. The hole-density gradient stimulates the diffusion of holes to the collector-base junction; they are quickly gathered into the collector by the potential hill at that junction, to produce the collector signal response. The delay in the transmission of the leading edge of the signal, i.e., the rise time, is therefore the time required to build up the hole-density gradient in the base and initiate the final hole-diffusion rate. When the input signal is removed, collector current will continue to flow until the gradient is sufficiently reduced; the time required for this is the fall time, the lag in the trailing edge of the signal. If an input signal drives the transistor into the saturation region, the density of holes will rise at the collector-base junction as well. When the input signal is turned off, all these holes must be removed from the base by the collector before the output voltage signal can begin to fall. This delay, or storage, can be several times the fall time for the active region. Clearly for transistors used as switches, where speed is essential, care should be taken to keep the transistor from operating in its saturation region. However, in a large proportion of digital circuits the transistor is driven into saturation by the input pulse because of other considerations; these will be discussed in the next section.

As an illustration of the storage time $t_{s}$, consider the grounded-emitter configuration of Fig. 20-8a. With an input base-voltage pulse $V_{b 1}$ of width $t_{w}$ a base current $I_{b 1}=V_{b 1} / R_{b}$ will flow, provided that $R_{b}$ is large compared with the internal impedance of the transistor. The rise time $t_{r}$ of the collector current includes a very small initial delay (not indicated in the figure). During the storage time $t_{s}$ the impedance of the transistor is still small, and $I_{b 2}=V_{b 2} / R_{b}$. After the transistor has returned to its active region, $I_{b}$ falls to zero as the impedance of the transistor


Fig. 20-8. Grounded-emitter transistor as a switch, with the input signal driving the transistor well into saturation. Shown here are (a) the circuit configuration, (b) the applied base-voltage pulse, (c) the input base-current pulse, and (d) the resulting delayed collector-current (output) pulse. increases, during the normal fall time (see Fig. 20-8b, $c$, and $d$ ).

Elementary Analysis. An elementary analysis of a transistor, approximately valid in all three regions, can be instructive. The main difficulty of such an analysis is that constants such as $\alpha$ or $I_{c o}$ can vary appreciably in different transistors of the same type (although manufacturers are steadily improving reliability). The analysis is based on Eq. (20-4), which we repeat here, using $\alpha_{n}$ to signify the "normal" $\alpha$ :

$$
\begin{array}{r}
I_{c}=I_{c o}\left(e^{x}-1\right)-\alpha_{n} I_{e} \\
\left(\text { for } x=\frac{V_{c}}{\kappa}\right) \tag{20-7}
\end{array}
$$

This is simply the equation for the characteristic curves giving $I_{c}$ as a function of $V_{c}$ for constant values of $I_{e}$ (see Fig. 20-6a). Suppose that next we consider the transistor used in reverse, i.e., the collector used as the emitter and the emitter used as the collector. Then we can write an equation analogous to ( $20-7$ ):

$$
\begin{equation*}
I_{e}=I_{e o}\left(e^{y}-1\right)-\alpha_{I} I_{c} \quad y=\frac{V_{e}}{\kappa} \tag{20-8}
\end{equation*}
$$

where $\alpha_{I}$ is the $\alpha$ of our "reverse" transistor. In writing Eqs. (20-7) and (20-8) we must be careful of the sign conventions for $I_{c}, I_{e}, V_{e}$, etc., which were summarized in Fig. 20-5. By substituting Eq. (20-8) into (20-7) we can determine $I_{c}$ as a function of the parameters $I_{c o}, I_{e o}, \alpha_{n}$, and $\alpha_{I}$ and the voltages $V_{c}$ and $V_{e}$,

$$
\begin{equation*}
I_{c}=\frac{I_{c o}}{1-\alpha_{n} \alpha_{I}}\left(e^{x}-1\right)-\frac{\alpha_{n} I_{e o}}{1-\alpha_{n} \alpha_{I}}\left(e^{y}-1\right) \tag{20-9}
\end{equation*}
$$

Similarly by substituting Eq. (20-7) into (20-8) we find

$$
\begin{equation*}
I_{e}=\frac{I_{e o}}{1-\alpha_{n} \alpha_{I}}\left(e^{y}-1\right)-\frac{\alpha_{I} I_{c o}}{1-\alpha_{n} \alpha_{I}}\left(e^{x}-1\right) \tag{20-10}
\end{equation*}
$$

However, $\alpha_{n}, \alpha_{I}, I_{e o}$, and $I_{c o}$ are not independent; it can be shown (from the physics of the device) that they are related by the equation

$$
\begin{equation*}
\alpha_{n} I_{e o}=\alpha_{I} I_{c o} \tag{20-11}
\end{equation*}
$$

Equations (20-7) and (20-8) can be solved for the junction voltages $V_{c}$ and $V_{e}$,

$$
\begin{align*}
& V_{c}=\kappa \ln \left(1+\frac{I_{c}+\alpha_{n} I_{e}}{I_{c o}}\right)  \tag{20-12}\\
& V_{e}=\kappa \ln \left(1+\frac{I_{e}+\alpha_{I} I_{c}}{I_{e o}}\right) \tag{20-13}
\end{align*}
$$

The characteristic curves giving $I_{c}$ as a function of $V_{c e}$ for constant $I_{b}$ (see Fig. 20-6b) can be derived by observing that $V_{c e}=V_{c}-V_{e}$. Then,: letting $z=\left(V_{c}-V_{e}\right) / \kappa$, from Eqs. (20-1) and (20-2), using (20-5) and (20-11), we have

$$
\begin{equation*}
I_{c}=\frac{\alpha_{I}\left(1-e^{2}\right) I_{c o}-\alpha_{n}\left(\alpha_{I}+e^{z}\right) I_{b}}{\alpha_{n}\left(\alpha_{I}-e^{z}\right)-\alpha_{I}\left(1-\alpha_{n} e^{2}\right)} \tag{20-14}
\end{equation*}
$$

$n-p-n$ Transistor. A transistor can also be constructed by placing a $p$-type semiconductor between two layers of $n$-type substance, as shown in Fig. 20-9. The arrow on the emitter lead


Fig. 20-9. n-p-n transistor symbolism with current and voltage conventions. specifies the direction in which current will flow when the emitter-base junction is biased in the forward direction, for active-region operation. However, in both the $n-p-n$ and $p-n-p$ transistors the conventional currents $I_{c}, I_{e}$, and $I_{b}$ are directed into the transistor (see Exercises $h$ through $m$ ).

## EXERCISES

(a) How would you make an analogy between a transistor and a triode vacuum tube?
(b) Explain from our physical model of the transistor why $\alpha$ is close to but less than unity. (Hint: Where does the base current $I_{b}$ arise?)
(c) What is the physical explanation of the flatness of the $V_{c}$ versus $I_{c}$, constant $I_{e}$, curves?
(d) In Fig. 20-8 suppose that the input signal $V_{b_{1}}$ did not drive the transistor all the way to saturation; how would curves $c$ and $d$ appear for $I_{b}$ and $I_{c}$, respectively?
(e) For the $p-n-p$ transistor of Fig. 20-6 in the grounded-base configuration, if the
collector is connected through a 2,000 -ohm resistor to a -10 -volt supply, and if $I_{b}=-75 \mu \mathrm{a}$, find the values of $V_{c e}, V_{c}, V_{e}, I_{c}$, and $I_{e}$.
(f) Find an expression for $V_{e}$ at cutoff. (Hint: At cutoff $I_{e}=0, I_{c}=I_{c o}$.)
(g) Derive an expression for $I_{b}$ when the transistor is in the cutoff region.
( $h$ ) Draw a figure analogous to Fig. 20-4 for an $n-p-n$ transistor.
(i) For an $n-p-n$ transistor, how would typical $V_{c e}$ versus $I_{c}$, constant $I_{e}$, and $V_{c}$ versus $I_{c}$, constant $I_{b}$, characteristic curves appear? (Hint: Be careful of conventional current directions.)
(j) How would an $n-p-n$ transistor be used in the grounded-emitter configuration as a switch?
(k) What are the main current carriers in the base of an $n-p-n$ transistor operated in its active region?
(l) Derive an equation for the $V_{c}$ versus $I_{c}$, constant $I_{e}$, (grounded-base) characteristic curves of an $n-p-n$ transistor.
( $m$ ) Derive an equation for the $V_{c e}$ versus $I_{c}$, constant $I_{e}$, (grounded-emitter) characteristic curves of an $n-p-n$ transistor.

## 20-4. Transistor Equivalent Circuit $\dagger$

Equivalent Circuits. The preceding section has discussed the development of the junction transistor from the viewpoint of qualitative physical theory and the steady-state direct-current (d-c) voltage equations. In order to apply the transistor as an element in an electronic circuit, it is necessary to redescribe the physical device in a form more useful from the viewpoint of circuit-design techniques. This is accomplished by means of the transistor's equivalent circuit, describing the device in terms of familiar circuit elements which can be treated by the standard methods of notwork analysis. The emitter, hase, and collentor terminals of the transistor can be connected to the external circuitry in three possible configurations, the grounded-emitter, grounded-base, and grounded-collector modes. Because of its superior switching characteristics the grounded-emitter mode is most widely used in logical switchingcircuit design and will be dealt with exclusively in this section. And since the majority of digital transistor circuits employ a voltage-step input to the base (rather than a current-step input), we shall limit ourselves to this type of input.

In this section we shall show a transistor equivalent circuit, in several forms, emphasizing how the circuit is used. The discussions given concerning the origin of the circuits are largely descriptive and heuristic in nature and should not be interpreted as "proofs" in any sense. The development of the small- and large-signal circuits themselves is beyond the scope of the text.

Our main purpose will be to derive the transient rise-time, saturationstate, storage-time, and transient fall-time characteristics of the transistor in the grounded-emitter mode for a large-signal input voltage pulse applied through the base. This involves a preliminary study of the
$\dagger$ This section is based on a private communication on an original development of Sidney B. Geller, Paul A. Mantek, and Don R. Boyle of the National Bureau of Standards.
large-signal d-c behavior as well as the small-signal behavior of the transistor. It is well first to digress for a moment to review the IRE notational standards for variable $\mathrm{d}-\mathrm{c}$ and modulation parameters. The d-c parameters are indicated by capital letters, the transient, or modulation-level, parameters by lower-case letters (as illustrated in Fig. 20-10 for voltages). The subscripts indicate the reference points: A capital subscript means that a reference point is at true zero, that the total displacement is involved; a lower-case subscript indicates the d-c reference, involving only


Fig. 20-10. Notational review. the local modulation displacement. (Constant parameters may be denoted by any convenient symbols, provided that no ambiguity arises.)
Large-signal D-C Equivalent Circuit. From the equations of the previous section (with $I_{B}$ substituted for $I_{b}$ ) it can be shown that

$$
\begin{equation*}
I_{B}=\frac{I_{e o} e^{V} / k}{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1)}-\frac{I_{e o}}{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1)^{2}}-I_{c o} \tag{20-15}
\end{equation*}
$$

However, since $I_{c o} \ll I_{B}$ in the active and saturated regions, and also since

$$
\frac{I_{e e} V_{e} / \kappa}{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1)} \gg \frac{I_{e o}}{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1)^{2}}
$$

we find approximately

$$
\begin{equation*}
I_{B} \cong \frac{I_{e 0} V_{0 / k}}{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1)} \tag{20-16}
\end{equation*}
$$

Also $\quad I_{c}=-\beta I_{B}+I_{c o} \cong-\beta I_{B} \quad$ and $\quad I_{e} \cong(\beta+1) I_{B}$
Solving for $V_{e} / I_{B}$ in Eq. (20-16), with $\kappa \cong 1 / 39$ at room temperature, we find

$$
\begin{equation*}
\frac{V_{e}}{I_{B}}=R_{B E} \cong \frac{1}{39 I_{B}} \ln \frac{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1) I_{B}}{I_{e o}} \tag{20-18}
\end{equation*}
$$

The variable resistance $R_{B E}$ can be interpreted as a diffusion-process resistance in the base. However, the effective base-to-emitter voltage is somewhat less than the external voltage; the reduction is the loss across a small equivalent internal resistance, denoted by $r_{b b}$, which must be separated from the diffusion resistance. We shall replace the symbol $V_{e}$ by $V_{B E}$, to represent the effective internal base-to-emitter voltages. With $V_{B E}$ replacing $V_{e}$, Eqs. (20-17) and (20-18) enable us to draw
the main features of the circuit (Fig. 20-11); here $R_{X}$ is the external resistance and $V_{X}$ the externally applied voltage step. The value of $r_{b b}$, from 50 to 1,000 ohms, is usually obtained by disconnecting the emitter and then measuring the collector-to-base resistance, at high frequency


Fig. 20-11. Direct-current large-signal equivalent circuit.
so that the capacitance from base to collector effectively short-circuits the current generators.

From the figure, with no output current

$$
I_{B}\left(R_{X}+r_{b b}\right)-V_{X}=V_{B E}
$$

Since by Eq. (20-18) $V_{B E}$ (that is, $V_{e}$ ) is a function of $I_{B}$, this equation can be solved by finding the intersection of the graphs of

$$
y=I_{B}\left(R_{X}+r_{b b}\right)-V_{X} \quad \text { and } \quad y=V_{\underline{D} E}
$$

when they are plotted as functions of $I_{B}$ (see Sec. 6-3). Figure 20-12


Fig. 20-12. The $V_{B E}-I_{B}$ curve, obtained from Eq. (20-18) or by direct measurement. gives this latter curve of $V_{B E}$ as a function of $I_{B}$. The $V_{B E^{-}} I_{B}$ curve is a key feature of this development and will be utilized extensively in the following discussions. It is easily obtained, either from Eq. (20-18) or by direct d-c measurement of a particular transistor.

Dynamic Behavior and the Smallsignal Equivalent Circuit. The transition from the d-c to the dynamic behavior of the transistor can be made as follows: In the d-c state $I_{B}$ is the current that flows through the diffusion resistance, contributing to $V_{B E}$ as shown in Fig. 20-11. In the dynamic case, however, a capacitance appears to parallel the diffusion resistance. The axes of Fig. 20-12 should be relabeled with $i_{B E}$ and $v_{B E}$, in accordance with the IRE notation. The curve, however, remains the same; in Fig. 20-13 it has been redrawn more accurately for a typical

2N414 transistor. A capacitance appears which is a combination of the diffusion-process capacitance and the space-charge capacitance at the base-collector junction; it is denoted by $C_{d j}$. For the dynamic state


Fig. 20-13. The $v_{B E}-i_{B E}$ curve of a typical 2 N 414 transistor.
we can rewrite Eqs. (20-16) and (20-17) appropriately:

$$
\begin{equation*}
i_{B E} \cong \frac{I_{\infty e^{v_{B E} / k}}}{\left(1-\alpha_{I} \alpha_{n}\right)(\beta+1)} \tag{20-19}
\end{equation*}
$$

and

$$
\begin{equation*}
I_{c} \cong \beta i_{B E} \quad I_{e} \cong(\beta+1) i_{B E} \tag{20-20}
\end{equation*}
$$

The small-signal case occurs when in a steady d-c state, with applied voltage $V_{X}$, a small increase in voltage is applied, say $\Delta V_{X}=v_{X}$, producing small increases in $i_{B E}, I_{c}$, and $v_{B E}$, of $\Delta i_{B E}=i_{b e}, \Delta I_{c}=i_{c}=\beta i_{b e}$, and $\Delta v_{B E}=v_{b e}$, respectively. However, for a small signal the diffusion resistance can be taken as a constant with the value $v_{b e} / i_{b e}=\Delta v_{B E} / \Delta i_{B E}$ (see Fig. 20-13). On taking the derivative of Eq. (20-19) we find this resistance to be

$$
\begin{equation*}
r_{b e}=\frac{v_{b e}}{i_{b e}}=\frac{1}{(1 / \kappa) i_{B E}} \tag{20-21}
\end{equation*}
$$

Thus we can draw the small-signal (variational) equivalent circuit as shown in Fig. 20-14. A circuit analysis easily yields, for small signals,

$$
i_{b e}(t)=\frac{v_{x}}{R_{X}+r_{b b}+r_{b e}}\left\{1-\exp \left[-t / \frac{r_{b e} C_{a j}\left(R_{X}+r_{b b}\right)}{R_{X}+r_{b b}+r_{b e}}\right]\right\}
$$

for a small step $v_{x}$. (For the return step, see Exercise b.) From the physical analysis that describes the alternating-current (a-c) behavior of a transistor it can be shown that $C_{d f}=(1 / \kappa) i_{b_{e}} T_{B}^{*}$, where $T_{B}^{*}$ is a constant for a given collector load resistance $R_{L}$ and collector supply


Fig. 20-14. Small-signal equivalent circuit.
voltage $V_{c c}$. Thus from Eq. (20-21) we have

$$
\begin{equation*}
r_{b e} C_{d f}=T_{B}^{*} \tag{20-23}
\end{equation*}
$$

which can be substituted into Eq. (20-22). Therefore $T_{B}^{*}$ is an invariant time constant, independent of $r_{b e}$ and $C_{d f}$, which vary with $r_{B E}$. To obtain $T_{B}^{*}$, note that if $R_{X}$ is very large, i.e., if the base is driven by a current source $i_{x}$, then $v_{x}=i_{x} R_{x}$ and Eq. (20-22) becomes approximately

$$
i_{b_{e}}=i_{x}\left(1-e^{-t / T s^{*}}\right)
$$

and $T_{B}^{*}$ becomes the time required for $i_{b e}$ to rise to $1-e^{-1}=63.2$ per cent of its final value $i_{x}$. (There is an analytic method for obtaining $T_{B}^{*}$ for any value of $R_{L}$ from a single rise-time measurement, due to Geller, Mantek, and Boyle of the National Bureau of Standards.)
Large-signal Equivalent Circuit: Rise Phase. The large-signal equivalent circuit is shown in Fig. 20-15. The main difference between it


Fig. 20-15. Large-signal equivalent circuit.
and the small-signal circuit is that $r_{b c}$ is replaced by the diffusion resistance $r_{B E}$ and $I_{c o}$ no longer cancels out. Because of the nonlinearity of $r_{B E}$ and $C_{d f}$, the exact equation for $i_{B E}(t)$ is difficult, if not impossible, to obtain. A simple graphical method, however, is available, based on the nodal differential equation for the currents into the junction of $C_{d f}$ and $r_{b b}$ :

$$
\begin{equation*}
\frac{V_{x}-v_{B E}}{R_{X}+r_{b b}}=i_{B E}+I_{c o}+C_{d f} \frac{d v_{B E}}{d t} \tag{20-24}
\end{equation*}
$$

From Eq. (20-23), $C_{d f}=T_{B}^{*} / r_{b e}$; from Fig. 20-13 we see that

$$
\frac{1}{r_{b e}}=\frac{d i_{B E}}{d v_{B E}}
$$

(i.e., the slope), and hence $C_{d f}=T_{B}^{*}\left(d i_{B E} / d v_{B E}\right)$. Substituting in Eq. (20-24) we have, since $\left(d i_{B E} / d v_{B E}\right)\left(d v_{B E} / d t\right)=d i_{B E} / d t$,

$$
\frac{V_{x}-v_{B E}}{R_{X}+r_{b b}}=i_{B E}+I_{c o}+T_{B}^{*} \frac{d i_{B E}}{d t}
$$

Solving for $d i_{B E} / d t$,

$$
\begin{equation*}
\frac{d i_{B E}}{d t}=\frac{1}{T_{B}^{*}}\left[\left(\frac{V_{x}-v_{B E}}{R_{X}+r_{b b}}-I_{c o}\right)-i_{B E}\right] \tag{20-25}
\end{equation*}
$$

Hence at any point the slope of the $i_{B E}(t)$ curve is represented by the hypotenuse of a triangle constructed at that point having the constant $T_{B}^{*}$ as base and the bracketed expression as altitude.

Figure $20-16 a$ shows the construction, by linear approximation (cf. Sec. $6-10$ ), of the $i_{B E}(t)$ curve for an input voltage pulse of constant voltage $V_{x}$ and of relatively long duration starting at $t=0$. To the left is drawn the $v_{B E-} i_{B E}$ curve, with ordinates to the same scale as on the $i_{B E}(t)$ curve. Intersecting this curve is drawn the "load" line representing the equation

$$
\begin{equation*}
i=\frac{V_{X}-v_{B E}}{R_{X}+r_{b b}}-I_{c o} \tag{20-26}
\end{equation*}
$$

Observe that the distance between the line and the curve, along a line of constant $v_{B E}$, is the bracketed expression of Eq. (20-25) (displaced by the proper $i_{B E}$ ). Starting from zero, the $i_{B E}(t)$ curve is approximated by line segments at constant intervals of time. From a given point of the curve a horizontal line is drawn intersecting the $v_{B E}-i_{B E}$ curve to find the $v_{B E}$ corresponding to the current at this point. From this intersection a vertical line is drawn intersecting the "load" line, measuring off $\left(V_{X}-v_{B E}\right) /\left(R_{X}+r_{b b}\right)-I_{c o}-i_{B E}$. From this latter intersection a horizontal line is drawn back to a point $T_{B}^{*}$ beyond the abscissa of the original point on the $i_{B E}(t)$ curve. The curve is then extended, along the line (the hypotenuse) joining these latter two points, to the next incremental value of $t$.

The process is continued until $i_{B E}$ reaches saturation, and the curve levels off as shown in Fig. 20-16. The intervals of time chosen need not be uniform, but for greater accuracy may be made smaller in the region where the curvature of the graph is greatest.

Saturation and Storage. Saturation is initiated when

$$
\begin{equation*}
I_{c}=\frac{V_{c c}}{R_{L}} \tag{20-27}
\end{equation*}
$$

When saturation occurs, then we have $i_{B E}=V_{c c} / \beta R_{L}=I_{B S}$ and

(a) Rise phase with saturation; the slope is recomputed every $\Delta t$

(b) Fall phase after saturation and storage

FIG. 20-16. Graphical method for determining $i_{B E}(t)$.

Sec. 20-4] semiconductor elements in digital-circuit design 665
$v_{B E}=V_{c c} r_{B E} / \beta R_{L}=V_{B S}$. Thus in our graphical iteration we must stop when the saturation value of $i_{B E}$ is obtained, and this value then continues until the end of the storage time. To account for this phenomenon in our equivalent circuit, we introduce a diode in series with a battery of strength $V_{B S}=V_{c c} r_{B E} / \beta R_{L}$ for $r_{B E}$ and $\beta$ at saturation (see Fig. 20-17a). During saturation the circuit behaves as in Fig. 20-17b,

(b)

Fig. 20-17. Large-signal equivalent circuit including provision for saturation. (a) Equivalent circuit adapted for saturation; (b) behavior of equivalent circuit during saturation.
where a small-interval collector resistance $R_{s}$ of about 4 ohms now appears. We have drawn $R_{s}$ in Fig. 20-17a also, but because of $I_{c}$ it has no effect before saturation is reached.

As the trailing edge of the $V_{X}$ pulse cuts off, storage begins, saturation lasting until the storage is ended. If the base current during saturation, but before storage begins, is denoted by $I_{B 1}$; if the reverse base current during saturation but after storage has begun (i.e., after $V_{X}=0$ ) is denoted by $I_{B 2}$; and if $I_{B S}=V_{c c} / \beta R_{L}$, then it can be shown that the storage duration is given by

$$
\begin{equation*}
t_{S}=K_{S} \ln \frac{I_{B 1}-I_{B 2}}{I_{B S}-I_{B 2}} \tag{20-28}
\end{equation*}
$$

where $K_{S}$ is constant for relatively deep saturation. Here $K_{S}$ is the excess base charge stored per unit excess base current. Equation (20-28) holds only for the case when $I_{B 2}$ is a constant reverse current; for the case when $I_{B 2}$ is not constant, e.g., if a capacitor is placed across $R_{X}$, other techniques, beyond our present scope, must be used to obtain the storage time.

Large-signal Equivalent Circuit: Fall Phase. When storage has ceased, the fall phase begins. Or if $V_{X}$ returned to zero before saturation was reached, the fall phase would then be initiated immediately. For the fall phase the equivalent circuit of Fig. 20-15 is again valid. Equation


Fig. 20-18. Response of 2N414, with input pulse $V_{x}=0.52$ volt (voltage drive to the brink of saturation). (a) Simulated; (b) experimental.
(20-25) holds, with $V_{X}=0$. Figure $20-16 b$ repeats the graphical analysis of Fig. 20-16a, with the "load" line given by Eq. (20-26), with $V_{X}=0$ :

$$
i=-\frac{v_{B E}}{R_{X}+r_{b b}}-I_{c o}
$$

Neglecting $I_{c o}$ (as is usually done), the line passes through the origin.
Summary. The analysis of Fig. 20-16 may be used for large-signal inputs other than the voltage pulse. Here the two "load" lines would be replaced by a family of lines, found by evaluating Eq. (20-26) for $V_{X}$ at corresponding time increments.

Given the $i_{B E}(t)$ curves, we can deduce the $V_{c}(t)$ curve, since

$$
V_{c}(t)=i_{c} R_{L}=R_{L} \beta i_{B E}(t)
$$

Figure 20-18 compares an oscilloscope tracing with the computed rise

Sec. 20-5] semiconductor elements in digital-circuit design 667
and fall curves of $V_{c}(t)$ for a voltage pulse at the base of a 2 N414 transistor. The increments used for the computed curve were taken fairly small, to illustrate the adequacy of the construction.

## EXERCISES

(a) Derive Eq. (20-15) from the equations of the previous section.
(b) Derive Eq. (20-22) from the equivalent circuit of Fig. 20-14, and show that the return-step current is given by

$$
\frac{v_{b e}}{R_{X}+r_{b b}+r_{b e}} \exp \frac{-t}{r_{b e} C_{d f}\left(R_{X}+r_{b b}\right) /\left(R_{X}+r_{b b}+r_{b e}\right)}
$$

Consider a 2 N 414 transistor for which $\beta=55, r_{b b}=100 \mathrm{ohms}$, and $K_{S}=2 \mu \mathrm{sec}$. For the purposes of the following exercises take

$$
T_{B}^{*} \cong 1.5 \times 10^{-6}+R_{L}\left(14 \times 19^{-12}\right) 56
$$

At room temperature $1 / \kappa=39.6$.
(c) If $R_{X}=20,000 \mathrm{ohms}, R_{L}=1,000 \mathrm{ohms}$, and $V_{c c}=-12$ volts, and if a voltage pulse $V_{X}$ of -12 volts and $5 \mu \mathrm{sec}$ duration is applied, draw a graph describing the transient behavior of the voltage at the collector terminal during the rise phase, saturation (including storage time), and the fall phase. Use the curve of Fig. 20-13.
(d) For the situation of Exercise $c$ find the time required for the collector current to rise to 90 per cent of its final value. What are the emitter current, base current, and base voltage at this time?
(e) Repeat Exercise $c$, but let $R_{L}=500$ ohms. Compare the results and give a qualitative explanation.
(f) Repeat Exercise $c$ for $R_{L}=300$ ohms and $V_{X}$ a voltage pulse of -4 volts and $1 \mu \mathrm{sec}$ duration. Compare the results and give a qualitative explanation.

## 20-5. Diode-gated Circuits

Diode Gating. Figure 20-19 indicates the conventions and symbols used for a diode. Suppose that a unit of a computer word is represented by some signalvoltage level $V_{+}$and a zero by a lower signalvoltage level $V_{-}$(this is sometimes referred to as positive logic). Then the diode current arrangement in Fig. 20-20 will yield an or gate. For the output voltage will be the zero signal level $V_{-}$only if no diode is conducting; i.e., if any one of the inputs is a unit voltage $V_{+}$, the current through resistance $R$ will raise the output potential to the unit signal level $V_{+}$. For two diodes the condition-function table would be

$$
\begin{array}{rr}
A & 0101 \\
B & 0011 \\
\hline \text { Output } & 0111
\end{array}=A+B
$$

The dashed diode connections in Fig. 20-20


Fig. 20-19. Conventional diode symbolism for semiconduction diode. Polarity of applied voltage $V$ for conduction, and directions of low-resistance current $I$ and high-resistance current $I_{0}$ are shown.

Suppose on the other hand that we let $V_{+}$be the zero voltage level and $V_{\text {- }}$ be the unit level (negative logic). Then our condition-function table would be

$$
\begin{array}{l|l}
A & 0101 \\
B & 0011 \\
\hline \text { ut } & 0001
\end{array}=A \cdot B
$$

Thus we see that the interpretation of the signal-voltage levels is important for the logical analysis of the gate. In Fig. 20-21 we have turned the diodes

around and attached the output through the resistor to a $V_{+}$voltage supply. It is seen that, for the same interpretation of 1 and 0 , reversing the diodes changes an or gate into an and gate and an and gate into an or gate.

In our discussion so far we have neglected the effect of the diode forward resistance $r_{f}$. When this is taken into account, it is seen that the voltage swing from $V_{-}$to $V_{+}$on the input side of the diodes will be greater than that on the output side and will depend on the number of diodes conducting at any time. For the circuit of Fig. 20-20, with an input voltage swing from $V_{-}$to $V_{+}^{\prime}$ and with $n$ diodes conducting, the output voltage $V_{+}$will be given by

$$
V_{+}=V_{-}+\frac{R}{R+r_{f} / n}\left(V_{+}^{\prime}-V_{-}\right)=\frac{r_{f} V+n R V_{+}^{\prime}}{r_{f}+n R}
$$

which increases toward $V_{+}^{\prime}$ as $n$ increases. When a constant value for $V_{+}$ is required, the output voltage can be "clamped" through a diode so that it will never exceed a predetermined $V_{+}$. This clamping voltage should clearly be not more than $\left(r_{f} V_{-}+R V_{+}^{\prime}\right) /\left(r_{f}+R\right)$, the value of $V_{+}$above for $n=1$. Similarly for the circuit of Fig. 20-21, with an input voltage swing from $V_{-}^{\prime}$ to $V_{+}$, the output could be clamped to a predetermined $V_{-}$. However, one should note that the supply voltages connected to the resistors $R$ must be the same as the maximum or minimum input voltages $V_{+}^{\prime}$ or $V_{-}^{\prime}$ (why?). The outputs from several of the circuits of

Fig. 20-21 can be the inputs to a circuit of Fig. 20-20 (or vice versa); here both $V_{+}$and $V_{-}$could be clamped. Figure $20-22$ shows such a combination with the input to the amplifier clamped between $V_{+}$and $V_{-}$, where $V_{+} \leq V_{+}^{\prime}$ and $V_{-} \geq V_{-}^{\prime \prime}>V_{-}^{\prime}$. The supply resistors ( $R$ in Figs. 20-20 and 20-21) should be large enough to keep the supply current small but should not be large compared with the back resistance $r_{b}$ of the diodes.


Fig. 20-22. A diode-gate and-or circuit.
Transistors as Amplifiers. An ordinary diode is a passive circuit element with no means for reinforcing signal strengths, so that after a few levels of such diode gates as described above the output signals become too much attenuated to be usable. Therefore in all diode-gated circuitry some form of active element is included to reamplify, and sometimes reshape, the signals. The earliest computers used vacuum tubes as amplifiers, but the postwar developments in solid-state devices have brought tubes to obsolescence in computer uses. We consider in this section transistors used purely as amplifiers of diode-gate output, as we shall consider magnetic elements purely as amplifiers in Sec. 21-3.

Figure $20-23 a$ shows the simplest of gated-amplifier circuits, a single gate followed by the amplifier. For the 0,1 levels as shown, the diode configuration acts as an or gate; the transistor amplifies the gate output, but in reverse polarity. Note that a clock pulse cannot be used here, in the ordinary way, since the output would be a zero whenever the clock was on. Hence this circuit is usually employed in conjunction with flip-flop synchronization and retiming. (Compare Exercise $b$ of Sec. 20-6. Because of the lack of clocking, and because of considerations required by the logic used with these packages, they are generally called or inverters rather than or-not gates.) In the design of such a package the
collector load resistor $R_{L}$ should be as small as possible, since the base currents for succeeding stages are drawn through $R_{L}$ (when this transistor is cut off), and the drop across it must not be too great. Similarly $R$ must be as large as possible, to limit the currents through the preceding load resistors, but not so great that it cuts down the base current when the previous stages are fully loaded (i.e., have the maximum drop across


Fig. 20-23. Or-inverter packages.


Fig. 20-24. (a) Two input gating levels; (b) input and output gating levels.
their load resistors). The small base-to-emitter resistor $r$ helps reduce saturation and consequent storage time. Figure $20-23 b$ shows the optimum values for the circuit parameters, for a type 2 N 414 transistor, as computed from the equivalent circuit given in Sec. 20-4. (Observe that $R_{X}$ for the equivalent circuit is computed from the parallel combination of $R$ and $r$ and that the $V_{X}$ used must be reduced to its Thévenin equivalent.) The $100-\mu \mu \mathrm{f}$ capacitor shunting $R$ helps remove the excess holes in the base when the input goes positive.

More than one level of diode gating can be used with transistors.

Figure 20-24a illustrates a level of and gates followed by an or gate. Of course each and gate can have more inputs than the two illustrated, but once a package is designed the number of inputs to each and gate is fixed. Another arrangement of levels of diode gating is illustrated in Fig. 20-24b. Here, instead of having both levels of gating precede the transistor, one level precedes and one level follows the transistor. In both circuits the parallel combination of and-gate resistors in the following stages acts as a collector resistor. The circuits of Fig. 20-24a and $b$ differ only in the packaging: the dashed line in (a) shows where the


Fig. 20-25. Dynamic circuit with regeneration.
separation was made in (b), and the dashed line in (b) shows where the separation was made in (a). Of course each of the output diodes of $b$ is connected to a different succeeding package, and each input is connected to several preceding packages. An advantage of the circuit of (b) over that of $(a)$ is that the packaging has now limited the number of outputs rather than the number of inputs; for packages whose output capacity is quite limited by electronic-design considerations, this arrangement is more natural.

Retiming and reshaping, as well as amplification, can be incorporated into a transistor diode-gating package by means of regeneration as described above. Figure 20-25 illustrates such a package, designed as a simple extension of the circuits of Fig. 20-24a and $b$. Note that a second transistor must be used to invert the output before recirculation; thus we have available both the direct and complemented outputs. A collector resistor must be added for the first transistor, to allow for the case of no loading on the complemented output. Pulse transformers could also be used to provide the inversion for the regeneration; here again both direct and complemented outputs result.

## EXERCISES

(a) For the diode voltage-current characteristic drawn in Exercise $a$ of Sec. 20-2, calculate $V_{-}^{\prime \prime}, V_{-}$, and $V_{+}$of Fig. $20-22$ for $V_{+}^{\prime}=6$ volts and $V_{-}^{\prime}=-6$ volts and $R=10,000$ ohms.
(b) For the circuit of Fig. 20-23a compute $I_{c}, V_{c}, I_{e}, i_{B E}$, and $V_{B}$ for $V_{-}=-12$ volts, $R_{L}=620$ ohms, $R=3,900$ ohms, $R=620$ ohms, and $V_{X}=-12$ volts, when the output is connected to 1,5 , and 10 other packages.
(c) Find the rise and fall times for an input voltage swing from 0 to -12 volts for the circuit of Fig. 20-23a, for the values given in Exercise b, when the output is connected to 1,5 , and 10 other packages. (Use the transistor values given under the Exercises in Sec. 20-4.)
(d) In order to increase the number of packages that can be driven from the circuit of Fig. 20-24a, how would you adjust the value of the and-gate resistor? The transistor base resistors? What are the limitations to such an adjustment?
(e) In order to increase the number of packages that can be driven from the circuit of Fig. 20-23a, how would you adjust the resistors $R_{L}, R$, and $r$ ? What are the limitations to such an adjustment?
(f) For the circuit of Fig. 20-25 predict the output voltage rise and fall as a function of time for each transistor, when the and-gate resistance is $5,000 \mathrm{ohms}$, the input resistance to the base of each transistor is 2,000 ohms, the base-emitter shunt resistance is 500 ohms , and the collector resistance of the first transistor is $5,000 \mathrm{ohms}$, for a voltage input swing of 0 to -10 volts, of duration $1 \mu \mathrm{sec}$, and for five additional packages being driven from each output; for one additional package being driven from each output. (Use only four segments in the graphical approximation, and the values of $\beta, T_{B}$, etc., as given under the Exercises in Sec. 20-4, as well as the curve of Fig. 20-13.)

## 20-6. Transistor Gating and Flip-Flops

Resistance-coupled Transistor Circuits. Figure 20-26a illustrates an or-inverter circuit gated with resistors only. The circuit is designed so that, if any one of the inputs $A, B$, or $C$ receives a negative voltage signal, the current through the input resistance is sufficient to turn the transistor on; hence, with the negative signal representing a unit, the output is $\overline{A+B+C}$. The advantages of such a resistance-gated circuit are low cost, simplicity, and high reliability, since semiconductor components are minimized by the elimination of diodes. The disadvantage of the circuit is that if two or more inputs are on at the same time the operating speed is lowered. This occurs because the transistor is driven more deeply into saturation as more inputs are actuated; the effect of more inputs is to place more input resistors in parallel between $V_{-}$and the base, lowering the effective resistance of the input and increasing the base-emitter current. In order to maximize the number of transistors that any stage can drive, the collector resistor should be made as small as possible: For when the transistor is not conducting, connecting more outputs to the collector (i.e., more drives) requires a larger current through the collector resistor; the collector voltage may rise to such a value that the succeeding transistors can no longer be turned on. Note that only one level of gating can be accomplished per transistor stage.

In Sec. 18-1 the advantages of combinations of or and and inverters were described from a logical point of view. In Fig. 20-26b is illustrated a mutually compatible or-inverter-and-inverter circuit pair. The and inverter uses an $n-p-n$ transistor instead of the $p-n-p$ of the or inverter. Since the or inverter operates between 0 and -12 volts, the emitter of the $n-p-n$ transistor (and inverter) is connected to -12 volts and the collector load resistor is grounded, so that this circuit too may operate over this range. However, matching problems still occur, for the $p-n-p$ transistor operates near and below ground, while the $n-p-n$ transistor operates near and above -12 volts. On the other hand, the or


Fig. 20-26. (a) Resistor-coupled or-inverter package; (b) dual $p-n-p$ and $n-p-n$ circuits.
inverter must be able to drive either an and inverter or another or inverter, as also must the and inverter. One solution to this problem is to have the bias resistor or collector load resistor adjustable according to the succeeding circuit requirements.

Direct-coupled Transistor Circuits. Figure 20-27 illustrates directcoupled transistor logic. The advantage of this type of circuit is that it minimizes the number of different component types and the necessary power supply voltages and presents low power dissipation. In (a) is shown the and inverter, whose output (inverted) will appear only when $A$ and $B$ and $C$ are units; in (b) is shown an or inverter, whose output (inverted) will appear if either $A$ or $B$ or $C$ is a unit. Even though the voltage swing from 0 to 1 is small, the transistors are driven into saturation because of the direct coupling, limiting the switching speed. The transistors being driven must be evenly matched as to the base voltage necessary for saturation. Suppose in Fig. 20-27c that transistor $T_{1}$ is saturated at -0.3 volt, while $T_{2}$ requires -0.4 volt for saturation. As the driving transistor is cut off and the voltage falls to -0.3 volt, $T_{1}$ will conduct; its base current might be enough to keep the voltage from falling to -0.4 volt, and $T_{2}$ would never be driven to saturation.

(a)

(b)

(c)

Fig. 20-27. Direct-coupled transistor circuits. (a) and inverter; (b) or inverter; (c) direct-coupled driving.

Current-switching Transistor Logic. As we have seen in Sec. 20-3, transistors driven into saturation can have long storage-time delays. For higher switching speeds, therefore, it is desirable to use only small voltage swings for 0 and 1 representation and to avoid using the transistors in the saturation region. The current-switching transistor method now to be described is designed for this purpose. The basic concept of


Fig. 20-28. Transistor current switching.
current switching can be discerned from consideration of the circuit of Fig. 20-28. Here the emitters of both transistors are connected to a constant-current source. The base of transistor $T_{2}$ is grounded, while the base of transistor $T_{1}$ receives the input to the circuit, a voltage swing just large enough to cause the transistors either to conduct or to be cut off. Suppose that $T_{1}$ is conducting. Then the current will go through the top resistor to $-V$ through $T_{1}$, raising the output voltage at the top to $-V+\left(I_{c o}+\alpha I\right) R$. The emitter-base voltage on $T_{2}$ is too small for conduction; hence $T_{2}$ is in cutoff so that only $I_{c o}$ flows through the bottom
resistor and the lower output voltage remains $-V+I_{c o} R$. Now suppose that $T_{1}$ is cut off by the input signal. The current source will raise the voltage applied to the emitters until $T_{2}$ starts to conduct. The current will now flow through $T_{2}$, raising the bottom output voltage to $-V+\left(I_{c o}+\alpha I\right) R$; the top output voltage level drops to $-V+I_{c o} R$. In this way a small input voltage swing switches the current through one or the other of the transistors, thereby altering the two complementary output voltages.


Fig. 20-29. Current-switching circuits for alternate matching.
In order that the voltage swing of the output be symmetric about $-V$, the configurations of Fig. 20-29 are used. Consider, for example, Fig. 20-29a: when $T_{1}$ is conducting (i.e., the input is at -0.6 volt), approximately 3 ma of the 6 -ma source will go to the top current "sink"; the other 3 ma will pass through the 200 -ohm resistors to the bottom current "sink," raising the top output voltage to approximately -5.4 volts, and lowering the bottom output voltage to about -6.6 volts. When the input is raised to +0.6 volt, $T_{1}$ is cut off and $T_{2}$ conducts, reversing the potentials at the outputs. The voltage levels given here are approximate because an exact calculation must take into account the effective internal resistances of the transistors; and, in addition, a current source is usually comprised of a large resistor in series with a voltage source, so that the current cannot be held precisely constant.

The outputs of the circuit of Fig. 20-29a swing between -5.4 and -6.6 volts, whereas its input changes from +0.6 to -0.6 volt. We must have another current-switching circuit, shown in Fig. 20-29b, whose input swing is -5.4 to -6.6 volts and whose output change is from +0.6 to -0.6 volt. Note that $n-p-n$ transistors are used in circuit $b$ and that the base of the bottom transistor is held at -6 volts instead of at ground level. Circuits of these two types are connected alternately.


Fig. 20-30. Current-switching gating. (a) or gate; (b) and gate.
Current-switching logical operations are performed as shown in Fig. $20-30$. In circuit $a$, if any of the transistors $A$ or $B$ or $C$ is turned on, the current is switched, giving the complementary outputs $A+B+C$ and $\overline{A+B+C}$. In circuit $b$ all three transistors $A$ and $B$ and $C$ must be turned on to switch the current, giving the complementary outputs $A \cdot B \cdot C$ and $\overline{A \cdot B \cdot C}$.
Transistor Flip-Flop Circuits. The circuit of Fig. 20-31 is typical of transistor flip-flop circuitry. In one of the two stable states of the flipflop, transistor $T_{2}$ is conducting, its collector voltage rising almost to 0 volts (ground). This collector voltage is applied through the resistor to the base of transistor $T_{1}$, cutting it off. Since $T_{1}$ is not conducting,
its collector voltage will be about -12 volts; this voltage is applied to the base of transistor $T_{2}$, to keep it conducting (in saturation). The other stable state has $T_{1}$ conducting and $T_{2}$ not. Again the base-tocollector connections between $T_{1}$ and $T_{2}$ keep $T_{1}$ on (in saturation) and $T_{2}$ off (in cutoff). The outputs of the flip-flop, which are the two collector voltages, now reverse. Switching the flip-flop is accomplished by means of the capacitor and diode connected to the base of each transistor. The normal state of each input is at -12 volts; the diode prevents a reverse current from the base of the cutoff transistor. Suppose that $T_{2}$


Fig. 20-31. Flip-flop package.
is conducting and $T_{1}$ is cut off. When a positive signal is applied to the reset input, $T_{2}$ is cut off and its collector voltage falls to -12 volts. putting $T_{1}$ in saturation and reversing the state of the flip-flop. A positive pulse in the set input will now change the state back again. The switching of the flip-flop in this fashion is called $R-S$ switching (from "Set-Reset"). This mode of operation corresponds to that described in Sec. 12-11, Additional Topic b. The small capacitor paralleling the resistor between the base of each transistor and the collector of the other acts simply to decrease the switching time by helping to clear out holes in the respective bases.

A single trigger pulse can be made to switch the flip-flop. Consider Fig. 20-32, which is the same circuit as that of the previous figure, except that the inputs have been connected together. Suppose that $T_{2}$ is conducting and $T_{1}$ is in saturation. The quiescent input voltage is -12 volts. The collector of $T_{2}$ will be at around 0 volts, while the collector $T_{1}$ will be at -12 volts; the base of $T_{2}$ will be at a small negative potential, while that of $T_{1}$ will be slightly positive. Observe that the voltage across the $T_{2}$ input capacitor will be 12 volts, while the voltage across that of the $T_{1}$ input will be about 0 volts, since the resistors $R$
are connected from each input capacitor to the corresponding collector. As a positive pulse (with 0 volts peak) appears at the input, the voltages across the capacitors remain momentarily unchanged. The voltage on the base of $T_{1}$ is unchanged since it was more positive than the input pulse peak; the base of $T_{2}$, however, is driven positive by the charge on its capacitor, far into the transistor's cutoff region. As the capacitors charge and discharge, $T_{2}$ is held at cutoff long enough for its collector voltage to bring $T_{1}$ on and the circuit settles into its other stable state. (The trailing edge of the pulse has no effect because of the diodes.)


Fig. 20-32. Triggering the flip-flop with a single pulse.
Another positive pulse will of course again change the state, this time cutting off $T_{1}$, and so forth. This mode of operation corresponds to the $T$ flip-flop described in Sec. 12-11, Additional Topic $b$.

Figure 20-33 shows several of these flip-flop circuits connected to form a shift register. Suppose that a unit in the flip-flop is represented by the right-hand transistor conducting, the left-hand transistor not, and a zero by the other flip-flop state. When the triggering shift pulse appears, we desire to transfer the state of the first flip-flop stage to the second flip-flop stage. This is accomplished by connecting the resistor part of our diode-capacitor inputs to the collector of each first-stage transistor as above, so that the state of the first stage can be "recorded" in the capacitors; but the diodes are now connected to the bases of the transistors of the second stage, so that the triggering excitation will have its effect there. However, we want the second stage to attain the same state that the first stage was in, and therefore we must connect the capacitor that senses the $T_{2}$ collector of the first stage to the base of the $T_{1}$ transistor of the second stage and the capacitor that senses the $T_{1}$ collector
of the first stage to the base of the $T_{2}$ transistor of the second stage (why?), and so on, down the line of successive flip-flops in the register. Note that the first stage has two capacitors attached to its transistors' collectors. The other pair of capacitors load the shift register in the manner described for the circuit of Fig. 20-31.


Fig. 20-33. Flip-flop shift register.

## EXERCISES

(a) Discuss the circuit of Fig. 20-26, considering rise and fall times, number of inputs, saturation, and number of drives, etc. (Hint: Base the discussion on the transistor equivalent circuit.)
(b) Describe a method for graphically analyzing the rise and fall collector voltagetime curves for the circuit of Fig. 20-27c.
(c) How can the flip-flops of Fig. 20-31 be connected (through the $G$ - $H$ terminals) to make a serial binary counter?
(d) How can the flip-flops of Fig. $20-32$ be connected to make a parallel binary counter?
(e) Discuss the use of clock pulses in a computer using the or inverter of Fig. 20-23, with and without the use of flip-flops. (Hint: In the latter case treat succeeding or inverters as or gates followed by and gates.) Does this discussion apply to the or-inverter circuit of Fig. 20-26?

## 20-7. The Tunnel Diode

Operating Principles of Tunnel Diodes. $\dagger$ The so-called tunnel diode is a new solid-state device, with a negative-resistance region in its char-
$\dagger$ The tunnel diode was discovered by Dr. Leo Esaki; see L. Esaki, New Phenomenon in Narrow Ge p-n Junctions, Phys. Rev., vol. 109, pp. 603-604, Jan. 15, 1958.
acteristic curve, which can be used in microwave digital circuits for amplification and gating (see Fig. 20-34a). Utilizing this device, repetition rates (i.e., $1 /$ unit time interval) of 1,000 to 3,000 megacycles, or more, may be realizable. Thus its potential advantage is very great speed in a comparatively reliable solid-state device. At present there are disadvantages, associated with problems of reproducibility and uniformity of characteristics as well as with the many circuit-design problems introduced by the high speed, which must be overcome.

The tunnel diode consists of a junction between extremely heavily doped (doped to "degeneracy") $n$-type and $p$-type semiconductors. It depends for its operation on the quantum-mechanical phenomenon known as tunneling, from which the diode derives its name. $\dagger$ Tunneling is an effect in which an electron can "tunnel" through a potential barrier, even though it does not have sufficient energy to "surmount" the barrier, provided the barrier is "thin" enough. The explanation of the tunnel diode's characteristics must therefore be given in terms of available energy states. The tunneling of electrons from the $n$-type side to the $p$-type side of the diode will occur provided that the junction potential barrier is thin, that electrons are available in the $n$-type side to do the tunneling, and that states are available in the $p$-type side into which the electrons can go. Figure $20-34 b$ represents an energy-band diagram of the $p$ and $n$ sides of a tunnel diode, showing forbidden, empty, and filled energy states and their relation to the Fermi level in the diode. To simplify the illustration, the picture is shown for low-temperature conditions, under which the energy level between filled and empty states, as indicated by the Fermi level, is well defined; but this is not essential to our discussion. Any electron that tunnels through the barrier must fill an empty energy state at the same energy level from which the electron originally came. That is, in the diagram of Fig. 20-34b, electrons from the $n$ side must tunnel into empty energy states "horizontally opposite" on the $p$ side. Thus for zero bias no tunneling can occur, for there are no $p$-side empty energy states available at the same energy level as the $n$-side electron state. A small forward bias, however, brings the $n$-side electron states to a point horizontally opposite empty $p$-side states on the diagram, and tunneling occurs, accounting for the initial tunneling peak in the $V-I$ characteristic. Further increase in the forward bias puts the $n$-side electron states opposite $p$-side forbidden energy states; tunneling ceases, accounting for the valley in the V-I characteristic. As the forward voltage becomes sufficiently large, the minority current dominates, as in the usual diode case, producing the rightmost diode action portion of the $V-I$ characteristic.

Use of Tunnel Diodes in Digital Circuits. As an example of the use of the tunnel diode consider the circuit of Fig. 20-35a, due to E. Goto. The circuit is analogous to the Parametron considered above (Sec. 19-2)

[^11]


681

Fig. 20-34. Tunnel-diode characteristic and explanation of tunneling by available energy-band levels.
in that the clock pulse is utilized to build up a weak input signal; it differs from the Parametron in that its clock pulse and signal inputs and outputs are direct-current pulses and not wave pulses. The circuit uses two tunnel diodes in series and two clock pulses of opposite polarities;


Fig. 20-35. Diagram and operation of a digital circuit utilizing tunnel diodes.
the input to the circuit is a small current signal, which behaves as a small current source either into or out of node $q$ depending on the sum of the currents through the large input resistors (see Fig. 20-35a). To see how this current signal is built up into a large voltage level by the diodes, consider the successive stages of the operation of the circuit illustrated in Fig. 20-35b. Here the vertical axis represents the current through
either diode; the horizontal axis represents the voltage $V$ of node $q$ with respect to ground. Thus when the clock pulses are zero (i.e., no pulse), $V$ must be negative to forward-bias diode $D_{1}$, positive to forward-bias diode $D_{2}$, as shown in the top diagram of Fig. 20-35b. As the positive clock pulse attached to $D_{1}$ comes on, its effect is to move the $D_{1}$ characteristic curve further to the right; as the negative clock pulse comes on, its effect is to move the $D_{2}$ curve further to the left, as shown successively in the lower diagrams. An input current $I$ to node $q$ will be divided between $D_{1}$ and $D_{2}$, moving the voltage of node $q$ slightly positive until current $I$, as shown by the heavy vertical line in the top diagram, is achieved between the two curves. As the clock pulses come on, the movement of the curves forces the voltage of node $q$ to move further positive, always keeping the difference between the currents through $D_{1}$ and $D_{2}$ equal to $I$, as shown by the successive positions of the heavy vertical line. Thus the signal is amplified, during a single clock-pulse period, and the voltage $V_{1}$ is approximately reached by node $q$, as shown in the bottom diagram. We say "approximately," for current will now be supplied to the output and after the clock pulse of the previous gate is turned off, current may also be drawn backward through the input. A similar argument shows that a voltage of approximately $V_{0}$ is reached if the original input signal was a negative current.

Observe that the two tunnel diodes of this circuit must be matched for approximately equal tunnel-peak heights of the characteristic. Consider the effect of a current mismatch of $\Delta h$, as shown in Fig. 20-35c. If the input current signal $\Delta I$ is less than $\Delta h$, then as the clock pulses are applied the direction of movement of the voltage $V$ of node $q$ cannot be predicted, for as the characteristic curves move across each other, an unstable point appears at which the voltage could either increase or decrease as indicated by the arrows on the figure. On the other hand, if $\Delta I>\Delta h$, the voltage of node $q$ must remain on the same side of zero, as desired. Note, in the lowest diagram of Fig. 20-34b, that the limit on the total number of inputs plus outputs of the circuit is the difference in height between the tunnel peak and the valley, divided by $\Delta I$; that is, $n_{i}+n_{o} \leq(h-y) / \Delta I$, for $n_{i}$ inputs, $n_{o}$ outputs, tunnel-peak height $h$, valley height $y$, and input current signals of magnitude $\Delta I$.

Since the generated signal can propagate both forward and backward, we have a situation again analogous to the Parametron, as described in Sec. 19-2 (see Fig. 19-4). The same solution to that problem can be applied here: three clock phases are


Fig. 20-36. Parametron analogy, showing signal build-up with clock pulse and a three-clock-phase system. utilized, as shown in Fig. 20-36. The method of gating is also analogous to that of the Parametron in that
it is essentially of the majority-gate type. Thus, as indicated in Fig. $20-35 a$, if input $X$ has no current, then an input on either $A$ or $B$ will result in a positive voltage output, producing an or gate if $V_{+}$is a unit. If the input $X$ has negative current (i.e., out of node $q$ ), then both $A$ and $B$ must be unit inputs in order that $V_{+}$result, for an and gate. Observe that there is no negation. In the Parametron of Sec. 19-2 we simply reversed the two leads, since transformers coupled the circuits illustrated there. Here, however, two independent gates must be maintained for each gating operation, one for the direct, one for the inverse, output.

## EXERCISES

(a) On transparent paper, draw the characteristic curves of Fig. 20-34a for $D_{1}$ and $D_{2}$; by sliding the curves across each other, as in Fig. 20-35b, observe carefully what happens as the two tunnel peaks cross.
(b) Design a serial adder using the circuit given in Fig. 20-35a. More than three inputs may be utilized. What is the minimum number of circuits required?
(c) Design a shift register utilizing the tunnel-diode circuit of Fig. 20-35a. How is the "delay" accomplished?
(d) Design a digital circuit using only a single tunnel diode. (Hint: Current-bias the tunnel diode just below the tunnel peak; then an additional current pulse will drive the voltage to the diode action slope. What is the limitation on the number of inputs and outputs of this circuit? Why is a three-phase clock necessary? How can gating be accomplished?)

## 20-8. Additional Topics

## a. Selected Bibliography on Semiconductor Physics

Bridgers, H. E., J. H. Scaff, and J. N. Shive: "Transistor Technology," Bell Laboratories Series, 3 vols., D. Van Nostrand Company, Inc., Princeton, N.J., 1959.
Dunlap, C. W., Jr.: "An Introduction to Semiconductors," John Wiley \& Sons, Inc., New York, 1957.
Hannay, N. B.: "Semiconductors," Reinhold Publication Corporation, New York, 1959.

Katz, H. W.: "Solid State Magnetic and Dielectric Devices," John Wiley \& Sons, Inc., New York, 1959.
McAfee, K. B., E. J. Ryder, W. Shockley, and M. Sparks: Observations of Zener Currents in Germanium P-N Junctions, Phys. Rev., vol. 83, pp. 650-651, August, 1951.

McKay, K. G.: Avalanche Breakdown in Silicon, Phys. Rev., vol. 94, pp. 877-884, May, 1954.
Middlebrook, R. D.: "Junction Transistor Theory," John Wiley \& Sons, Inc., New York, 1957.
Miller, S. L.: Avalanche Breakdown in Germanium, Phys. Rev., vol. 99, pp. 1234-1241, August, 1955.
Scobey, J. E., W. A. White, and B. Salzberg: Fast Switching with Junction Diodes (Operating at Reverse Breakdown), Proc. IRE, vol. 44, pp. 1880-1881, December, 1956.

Shive, John N.: "Properties, Physics, and Design of Semiconductor Devices," Bell Laboratories Series, D. Van Nostrand Company, Inc., Princeton, N.J., 1959.

Shockley, W.: The Theory of P-N Junction in Semiconductors and P-N Junction Transistors, Bell System Tech. J., vol. 28, pp. 435-489, July, 1949.
———: "Electrons and Holes in Semiconductors," D. Van Nostrand Company, Inc., Princeton, N.J., 1950.
——, M. Sparks, and G. K. Teal: P-N Junction Transistor, Phys. Rev., vol. 83, pp. 151-162, July, 1951.
Warschauer, D. M.: "Semiconductors and Transistors," McGraw-Hill Book Company, Inc., New York, 1959.

## b. Selected Bibliography on Transistors and Equivalent Circuits

Coblenz, A., and H. L. Owens: "Transistors," McGraw-Hill Book Company, Inc., New York, 1955.
Deuitch, D. E.: Junction Transistor Switching Characteristics, Transistors, RCA Labs., March, 1956, pp. 609-639.
DeWitt, D., and A. L. Rossoff: "Transistor Electronics," McGraw-Hill Book Company, Inc., New York, 1957.
Easely, J. W.: The Effect of Collector Capacity on the Transient Response of Junction Transistors, IRE Trans. on Electron Devices, vol. ED-4, pp. 6-14, January, 1957.
Ebers, J. J., and J. L. Moll: Large-signal Behavior of Junction Transistors, Proc. IRE, vol. 42, pp. 1761-1772, December, 1954.
Enenstein, N. H.: A Transient Equivalent Circuit for Junction Transistors, IRE Trans. on Electron Devices, vol. PGED-4, pp. 37-54, December, 1953.
Farley, B. G.: Dynamics of Transistor Negative Resistance Circuits, Proc. IRE, vol. 40, pp. 1497-1508, November, 1952.
Giacoletti, L. J.: Study of P-N-P Alloy Junction Transistors from D-C through Medium Frequencies, RCA Rev., vol. 15, pp. 506-562, December, 1954.
Hunter, L. P.: "Handbook of Semiconductor Electronics," McGraw-Hill Book Company, Inc., New York, 1956.
Lo, A. W., R. O. Endres, J. Zawels, F. D. Waldhauer, and Chung-Chih Cheng: "Transistor Electronics," Prentice-Hall, Inc., Englewood Cliffs, N.J., 1955.
Marcovitz, M. W., and E. Seif: Analytical Design of Resistor-coupled Transistor Logical Circuits, IRE Trans. on Electronic Computers, vol. EC-7, pp. 109-119, June, 1958.
Moll, J. L.: Large Signal Transient Response of Junction Transistors, Proc. IRE, vol. 42, pp. 1773-1784, December, 1954.
Peterson, L. C.: Equivalent Circuits of Linear Active 4 Terminal Networks, Bell System Tech. J., vol. 27, pp. 593-622, October, 1948.
Pritchard, R. L.: Electric Network Representation of Transistors-A Survey, IRE Trans. on Circuit Theory, vol. CT-3, pp. 5-21, March, 1956.
Shea, R. F. (ed.): "Principles of Transistor Circuits," John Wiley \& Sons, Inc., New York, 1953.
Zawels, J.: Physical Theory of New Circuit Representation for Junction Transistors, $R C A$ Rev., vol. 16, pp. 360-378, September, 1955.
c. Selected Bibliography on Diodes and Transistors in Digital Circuits

Anderson, A. E.: Transistors in Switching Circuits, Proc. IRE, vol. 40, no. 11, pp. 1541-1558, November, 1952.
Beter, R. H., W. E. Bradley, R. B. Brown, and M. Rubinoff: Directly Coupled Transistor Circuits, Electronics, vol. 28, no. 6, pp. 132-136, June, 1955.
$—, —$, and - Surface-barrier Transistor Switching Circuits, IRE Conv. Record, pt. 4, pp. 139-145, 1955.

Booth, G. W., and T. P. Bothwell: Logic Circuits after a Transistor Digital Computer, IRE Trans. on Electronic Computers, vol. EC-5, pp. 132-138, September, 1956.
Carroll, W. N., and R. A. Cooper: Ten Megapulse Transistorized Pulse Circuits for Computer Application, Digest of Technical Papers, Transistor and Solid-state Circuits Conference, Feb. 20-21, 1958.
Chaplin, G. B. B.: Transistor Regenerative Amplifier as a Computer Element, Proc. IEE, vol. 101-3, pp. 298-313, 1954.
Clark, E. G.: Direct Coupled Transistor Logic Complementing Flip-flop Circuits, Electronic Design, vol. 5, pt. 1, pp. 24-27, June 15, 1957; pt. 2, pp. 34-47, Aug. 1, 1957.

Deuitch, D. E.: Transistor Circuits for Digital Computers, Electronics, vol. 29, no. 5, pp. 160-161, May, 1956.
Easley, J. W.: Transistor Characteristics for Direct-coupled Transistor Logic Circuits, IRE Trans. on Electronic Computers, vol. EC-7, pp. 6-16, March, 1958.
Grisamore, N. T., L. S. Rotolo, and G. U. Uyehara: Logical Design Using the Stroke Function, IRE Trans. on Electronic Computers, vol. EC-7, pp. 181-184, June, 1958.

Harris, J. R.: Direct-coupled Transistor Logic Circuitry, IRE Trans. on Electronic Computers, vol. EC-7, pp. 2-6, March, 1958.
Henle, R. A.: High-speed Transistor Computer Circuit Design, IRE-AIEE Transistor and Solid-state Circuits Conference, February, 1957, Philadelphia.
——_ and J. W. Walsh: The Application of Transistors to Computers, Proc. IRE, vol. 46, pp. 1240-1254, June, 1958.
McMahon, R. E.: Designing Transistor Flip-flops, Electronic Design, vol. 3, no. 10, pp. 24-26, October, 1955.
Millman, J., and H. Taub: "Pulse and Digital Circuits," McGraw-Hill Book Company, Inc., New York, 1956.
 Conf., February, 1957, pp. 167-171.
Page, C. H.: Digital Switching Circuits, Electronics, vol. 21, no. 11, pp. 110-118, September, 1948.
Prom, G. J., and R. L. Crosby: Junction Transistor Switching Circuits for High-speed Digital Computer Applications, IRE Trans. on Electronic Computers, vol. EC-5, pp. 192-196, December, 1956.
Rowe, W. D.: Transistor NOR Circuit Design, Electronic Design, vol. 6, no. 3, pp. 26-29, Feb. 5, 1958.
——and R. G. Royer: Transistor NOR Circuit Design, Trans. AIEE, Communs. and Electronics, no. 31, pp. 263-267, July, 1957.
Slutz, R. J., A. W. Holt, R. P. Witt, and D. C. Friedman: Diode Capacitor Memory, NBS Circ. 551, Computer Development at the NBS, January, 1955, pp. 102107.

Smith, C. V. L.: "Electronic Digital Computers," McGraw-Hill Book Company, Inc., New York, 1959.
Wanlass, C. L.: Transistor Circuitry for Digital Computers, IRE Trans. on Electronic Computers, vol. EC-4, pp. 11-16, March, 1955.
Wier, J. W.: Some Direct-coupled Circuits Utilizing N-P-N and P-N-P Transistors in Combination, Univ. Ill., Digital Computer Lab., Rept. 65, Aug. 31, 1955.
Yourke, H. S., and E. J. Slobodzinski: Millimicrosecond Transistor Current Switching Techniques, Proc. Western Joint Computer Conf., February, 1957, pp. 68-72.
-: Millimicrosecond Transistor Current Switching Circuits, IRE-AIEE Transistor and Solid-state Circuits Conference, February, 1957, Philadelphia.

## d. Articles on Other Semiconductor Devices

Aldrich, R. W., and N. Holonyak, Jr.: Multiterminal P-N-P-N Switches, Proc. IRE, vol. 46, p. 1236, June, 1958.
Chang, K. K. N.: Low-noise Tunnel Diode Amplifier, Proc. IRE, vol. 47, pp. 1268-1269, July, 1959.
Early, J. M.: P-N-I-P and N-P-I-N Junction Transistor Triode, Bell System Tech. J., vol. 33, p. 519, May, 1954.
Grinich, V. H., and I. Haas: Application of PN $\pi$ N Triode Switches, Digest of Technical Papers, pp. 52-53, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Hamilton, D. J., J. F. Gibbons, and W. Shockley: Physical Principles of Avalanche Transistor Pulse Circuits, Digest of Technical Papers, p. 92, IRE-AIEE Solidstate Circuits Conference, 1959, University of Pennsylvania.
Kingston, R. H.: Solid-state Maser Amplifiers and Their Applications: A Survey, Digest of Technical Papers, p. 74, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Mackintosh, I. M.: The Electrical Characteristics of Silicon P-N-P-N Triodes, Proc. IRE, vol. 46, p. 1229, June, 1958.
Moll, J. L., et al.: P-N-P-N Transistor Switches, Proc. IRE, vol. 44, no. 9, p. 1174, September, 1956.
Rupprecht, E. G., H. J. Patterson, and P. Miller: Hyperfast Diffused-silicon Diode and Transistor for Logic Circuits, Digest of Technical Papers, p. 72, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Schwartz, S. J., and J. S. Sallo: Electrodeposited Transistor and Bit Wire Components, Digest of Technical Papers, p. 94, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Shockley, W.: Unique Properties of the Four-layer Diode, Electronic Inds. T'ele-Tech, August, 1957.
——and J. F. Gibbons: Introduction to the Four-layer Diode, Semiconductor Products, January-February, 1958.
Wallmark, J. T., and S. M. Marcus: Integrated Devices Using Direct-coupled Unipolar Transistor Logic, Digest of Technical Papers, p. 58, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
e. Selected Bibliography on the Tunnel Diode

Chang, K. K. N.: Low-noise Tunnel-diode Amplifier, Proc. IRE, vol. 47, pp. 12681269, July, 1959.
Chow, W. F.: Tunnel-diode Digital Circuitry, Digest of Technical Papers, 1960 International Solid-state Circuits Conf., February, 1960, pp. 32-33.
Dacey, G. C.: Properties of Esaki (Tunnel) Diodes: A Survey, Digest of Technical Papers, 1960 International Solid-state Circuits Conf., February, 1960, pp. 6-7.
Esaki, L.: New Phenomenon in Narrow Ge p-n Junctions, Phys. Rev., vol. 109, pp. 603-604, Jan. 15, 1958.
Lesk, I. A., and N. Holonyak, Jr.: Germanium and Silicon Tunnel Diodes-Design, Operation and Application, IRE Wescon Conv. Rec., vol. 3, pt. 3, pp. 9-31, 1959.
Lewin, M. H.: Negative Resistance Elements as Digital Computer Components, Proc. Eastern Joint Computer Conf., pp. 15-27, Boston, Dec. 1-3, 1959.
, A. G. Samusenko, and A. W. Lo: The Tunnel Diode as a Logic Element, Digest of Technical Papers, 1960 International Solid-state Circuits Conf., February, 1960, pp. 10-11.

Miller, J. C., K. Li, and A. W. Lo: The Tunnel Diode as a Storage Element, Digest of Technical Papers, 1960 International Solid-state Circuits Conf., February, 1960, pp. 52-53.
Neff, G. W., S. A. Butler, and D. L. Critchlow: Esaki (Tunnel)-Diode Logic Circuits, Digest of Technical Papers, 1960 International Solid-state Circuits Conf., February, 1960, pp. 16-17.
Price, P. J., and J. M. Radcliffe: Esaki Tunneling, IBM J. Research Develop., vol. 3, pp. 364-371, October, 1959.
Sklar, B.: The Tunnel Diode-Its Action and Properties, Electronics, vol. 32, no. 45, pp. 54-57, Nov. 6, 1959.
Sommers, H. S., Jr.: Tunnel Diodes as High-frequency Devices, Proc. IRE, vol. 47, pp. 1201-1206, July, 1959.
, K. K. N. Chang, H. Nelson, R. Steinhoff, and P. Schnitzler: Tunnel Diodes for Low Noise Amplification, IRE Wescon Conv. Rec., vol. 3, pt. 3, pp. 3-8, 1959.
Tiemann, J. J.: Tunnel Diodes and Their Use as Multifunctional Circuit Elements, Digest of Technical Papers, 1960 International Solid-state Circuits Conf., February, 1960, pp. 8-9.

## MAGNETIC ELEMENTS IN DIGITAL-CIRCUIT DESIGN

## 21-1. Introduction

Magnctic Circuits. Magnetic elements can have high reliability, mechanical strength, small size, light weight, small power consumption, and relatively low cost. As such they are an important kind of component for digital circuits. After a brief review in this section of some of the laws of physics governing magnetic phenomena, we consider in the next section properties of those magnetic materials most frequently used in digital circuits. Application of magnetic components to amplification in diode-gated circuits is considered in Sec. 21-3. In Sec. 21-4 application of the magnetic components to the gating functions is described, including the multiaperture cores that give promise of digital circuits devoid even of diodes and transistors. Finally in Sec. 21-5 we consider modern developments still in experimental stages, the Cryotron operating on magnetic principles, and microwave gating operating on electromagnetic principles. The topics of this chapter by no means cover all the types of magnetic components or circuits that have been reported in the literature. Our purpose primarily is to introduce the reader to as large a variety of concepts as possible without embarking on too extensive a discourse. Each of the concepts studied has many possible variations; and it is hoped that the basic principles of the use of magnetic components in digital circuitry, illustrated by the examples chosen for this chapter, will enable the student to understand other techniques appearing in the literature that must be omitted here.

Review of Ampère's Law. A magnetic vector field is associated with every current, every moving charge. According to Ampère's law, the infinitesimal contribution dH to the magnetic field at a point $P$ made by the infinitesimal length $\mathrm{dl}_{I}$ of wire carrying current $I$ is given by the vector product

$$
\begin{equation*}
\mathrm{dH}=\frac{I \mathrm{dl}_{I} \times \mathbf{r}}{4 \pi r^{3}} \tag{21-1}
\end{equation*}
$$

where r is the position vector from $\mathrm{dl}_{I}$ to point $P$ (see Fig. 21-1 $\alpha$ ). Then according to the right-hand rule (see Fig. 21-1b) the direction of dH is perpendicular to the plane of $\mathrm{dl}_{I}$ and r . Consider, for example,
the field at the center of a circular loop, carrying a current $I$ (see Fig. 21-1c) :

$$
\mathrm{H}=\int_{0}^{l} \frac{I \mathrm{dl}_{I} \times \mathbf{r}}{4 \pi r^{3}}=I \int_{0}^{2 \pi} \frac{r d \alpha}{4 \pi r^{2}} \mathbf{k}=\frac{I}{2 r} \mathbf{k}
$$

where $\mathbf{k}$ is a unit vector, here directed toward the reader perpendicular to the plane of the figure. For $N$ turns, each carrying the current $I$,

$$
\begin{equation*}
\mathbf{H}=\frac{N I}{2 r} \mathbf{k} \tag{21-2}
\end{equation*}
$$

The current-related dimensions for H are thus ampere-turns per meter.


Fig. 21-1. (a) Ampère's law; (b) the right-hand rule for H ; (c) field in the center of a wire loop.


Fig. 21-2. (a) Path enclosing loop of wire; (b) path enclosing $N$ loops; (c) path inside toroid.

A concept closely related to the magnetic field is that of magnetomotive force, mmf (which is not a force at all but rather is associated with work or energy), defined as the line integral of the scalar product

$$
\begin{equation*}
\mathcal{F}_{A B}=\int_{A}^{B} \mathrm{H} \cdot \mathrm{dl}_{P} \tag{21-3}
\end{equation*}
$$

It can be shown that, if the line of integration is taken as a closed path around a current $I$, then

$$
\begin{equation*}
\mathfrak{F}=\wp \mathrm{H} \cdot \mathrm{dl}_{P}=I \tag{21-4}
\end{equation*}
$$

and is independent of the particular path chosen, so long as it encloses $I$ (see Fig. 21-2a). If for a coil of $N$ turns carrying a current $I$, the closed
path is taken through the center and then round the outside of the coil (see Fig. 21-2b), then from Eq. (21-4)

$$
\begin{equation*}
\mathfrak{F}=N I \tag{21-5}
\end{equation*}
$$

Thus $\mathfrak{F}$ can have the current-related dimensions of ampere-turns. Consider, for example, the path taken inside a toroidal coil (see Fig. 21-2c) of radius $R$ such that $H$ (the magnitude of H ) is constant along the path. Then from Eq. (21-3), $\mathfrak{F}=H l$; but, from (21-5), $\mathcal{F}=N I$; hence $H=N I / l$, where $l=2 \pi R$.

Review of Faraday's Law. A magnetic field can be represented by lines whose directions at all points are those of the magnetic field vectors


FIg. 21-3. (a) Flux change through coil; (b) toroid with secondary coil; (c) induced current direction.
at those points. By convention the number of these lines crossing a unit area taken normal to their direction is made equal to the magnitude of the field vector. Such lines are called lines of induction, or lines of $f l u x$. The total number of lines of induction passing through a surface is called the magnetic fux through the surface. Consider a coil of $N$ turns enclosing magnetic flux $\Phi$ (see Fig. 21-3a); if the flux is varied with time at a rate $d \Phi / d t$, then according to Faraday's law a voltage $V$ is induced across the windings, of magnitude

$$
\begin{equation*}
V=-N \frac{d \Phi}{d t} \tag{21-6}
\end{equation*}
$$

Note that, since $H$ is given in ampere-turns per meter, we could give $\Phi$ in ampere-turn-meters; but then $V$ would become something different from a volt. Because of this, $\Phi$ is more often given in dimensions of volt-seconds per turn, called the weber. Thus 1 volt is induced across one turn enclosing a flux change of $1 \mathrm{weber} / \mathrm{sec}$. Since H is essentially flux density (flux per normal unit area), we can now express it in terms of webers per square meter. When expressed in these units, it is called the magnetic induction, or flux density, and is denoted by B. Thus $\mathbf{B}=\mu_{0} \mathrm{H}$, where $\mu_{0}$ is a constant of proportionality between the different kinds of units (i.e., webers per square meter and ampere-turns per meter);
and in fact $\mu_{0}=4 \pi \times 10^{-7}=1.257 \times 10^{-6}$ weber/amp-turn-m (for a vacuum; see below).

Note that the flux density inside the toroid of Fig. 21-2c is $B=\mu_{0} N I / l$. If the radius of the loops is $r$, then the flux in the loop is $\Phi=B A$, or

$$
\Phi=\frac{\mu_{0} A N I}{l}=\frac{N I}{l / \mu_{0} A}
$$

where $A=\pi r^{2}$. If we place a second coil of $M$ turns inside the toroid (see Fig. 21-3b), then the voltage induced across this second coil, due to a rate of change of current equal to $d I / d t$ in the toroid coil, becomes $V=-M d \Phi / d t=-M N(d I / d t) /\left(l / u_{0} A\right)$.


Fig. 21-4. Coils with cores showing flux lines.
The direction of the induced voltage is given by Lenz's law, which states that the direction of an induced voltage is such as to oppose the cause producing it. Thus, as the flux inside a coil increases, the direction of the voltage induced must be süch that a resuiting current wiil produce a flux tending to decrease the imposed flux change; and as the imposed flux decreases, the resulting current will produce a flux tending to increase the imposed flux. For example, in our toroid when $d I / d t$ is positive the induced $d I^{\prime} / d t$ is negative, and vice versa (see Fig. 21-3c).

Ferromagnetism. When certain materials, such as iron, nickel, cobalt, and their alloys, are placed in a magnetic field $H$, the flux density inside the material becomes greater than the applied field. This phenomenon is due to subatomic currents associated with electron spin, nuclear spin, or planetary motion in atoms. When an external field is applied, the subatomic currents are lined up so that their fields are in the same direction and the vector sum of these fields produces the observed phenomenon. The amount of this additional flux density is (roughly) proportional to the applied field. Thus the total flux density inside the material becomes

$$
\begin{equation*}
\mathbf{B}=\mu_{0} \mathbf{H}+\chi \mathbf{H}=\left(\mu_{0}+\chi\right) \mathbf{H}=\mu \mathbf{H} \tag{21-7}
\end{equation*}
$$

where $\chi$ is called the magnetic susceptibility of the material and $\mu$ is called the permeability of the material. The constant $\mu_{0}$ introduced above is called the permeability of space. For example, if a wire of $N$ windings carries a current $I$ around a ferromagnetic core of susceptibility $\chi$ (see Fig. 21-4a), then $B=\mu_{0} N I / l+\chi N I / l=\mu N I / l$. For the flux
we have $\Phi=B A=N I /(l / \mu A)$. Even if the windings are located only on one part of the core, since the permeability of the core is so much greater than that of the surrounding space, most of the flux is still confined inside the core (see Fig. 21-4b). If a small air gap were made in the core, most of the flux lines would cross the gap and enter the material on the other side (see Fig. 21-4c) and the flux would be almost the same all around the ring.

Reluctance. Let us assume that the flux in Fig. 21-4c is confined within the ring, which has a constant cross-sectional area $A_{1}$, and within a constant area $A_{2}$ across the air gap. Choosing within the ring as a path of integration a line of constant magnetic field intensity $H_{1}$, Eq. (21-3) gives

$$
\mathfrak{F}_{1}=H_{1} l_{1}
$$

where $l_{1}$ is the length of the line within the metal. Integrating along the continuation of this line (having constant field intensity $H_{2}$ ) in the air gap, we find

$$
\mathfrak{F}_{2}=H_{2} l_{2}
$$

where $l_{2}$ is the length of the line within the gap. By Eq. (21-4)

$$
\mathfrak{F}=\mathfrak{F}_{1}+\mathfrak{F}_{2}=H_{1} l_{1}+H_{2} l_{2}
$$

Since the total flux $\Phi$ is constant across $A_{1}$ or $A_{2}$, we have

$$
\Phi=B_{1} A_{1}=B_{2} A_{2}
$$

or $B_{1}=\Phi / A_{1}$ and $B_{2}=\Phi / A_{2}$. Applying Eq. (21-7), we find $H_{1}=\Phi / \mu_{1} A_{1}$ and $H_{2}=\Phi / \mu_{2} A_{2}$, with $\mu_{1}$ and $\mu_{2}$ the permeabilities of the ring and air gap, respectively. Substituting these values in the above equation and solving for $\Phi$, we have

$$
\Phi=\frac{\mathfrak{F}}{l_{1} / \mu_{1} A_{1}+l_{2} / \mu_{2} A_{2}}=\frac{\mathfrak{F}}{\mathfrak{R}_{1}+\mathfrak{R}_{2}}
$$

where $\mathcal{R}_{i}=l_{i} / \mu_{i} A_{i}$ is called the reluctance of the path. As with resistances, the reluctances of series paths add, and the reciprocals of the reluctances of parallel paths add.

## 21-2. Magnetic Properties and Materials for Digital Circuits

Square-hysteresis-loop Materials. Consider a plot of B versus H for a magnetic core made of "square-loop" material (see Fig. 21-5). As the field $H$ is applied, the flux through the core reaches a maximum, beyond which additional H will not produce appreciably more B . In this state practically all the subatomic currents are lined up, and the core is said to be saturated (see point $a$ in Fig. 21-5). If the field is decreased to zero, the core will retain most of its flux, i.e., will behave as if it were a permanent magnet. The flux density $B$ at this point ( $b$ in Fig. 21-5) is called the retentivity, or remanence. As $H$ is decreased still more (i.e., as H is reversed in direction), the flux will suddenly start to drop rapidly (point
c). The magnitude of $\mathbf{H}$ for which $\mathrm{B}=0$ (point $d$ ) is called the coercive force, or coercivity. The direction of the flux density will now change, and the core will again become saturated, but oppositely to the previous saturation state (point $e$ ). Further decrease of H will not appreciably change $\mathbf{B}$ (point $f$ ). If $\mathbf{H}$ is now increased, the plot will follow the lower line of Fig. 21-5 (points $f, g, h, i, j, a$ ), passing through the retentivity, or remanence, for this state (point $g$ ) and the coercivity (point $i$ ) for positive H. Thus the core can have two remanent states, which in binary circuits represent a unit (e.g., point b) and a zero (e.g., point g). The processes of changing $H$ so that the core goes from one remanent state to the other is called fipping, or


Fig. 21-5. Square hysteresis loop. switching, the core. (If the coercive force is not exceeded, partial flipping of the core may occur-see the dashed lines of Fig. 21-5.) The reader should remember that not all magnetic materials exhibit such a square hysteresis loop.

The most commonly used cores are made of ferrite materials, molded ceramics composed of iron oxide and other metallic oxides. The powdered ceramic is pressed into toroidal molds and sintered at around $1300^{\circ} \mathrm{F}$ until proper crystallization has occurred. Such cores are manufacturcd in a variety of sizes, for memories some as small as 0.05 in . in diameter. Cores have also been made with ultrathin ( $1 / 8 \mathrm{mil}$ ) metallic tapes wound on ceramic or steel bobbins, the layers reducing eddy currents. The ferrites are nonconductors, and therefore their eddy currents are automatically kept small. Crystal structure and uniformity of composition are important factors in obtaining a square hysteresis loop.

It has been shown that there exist in ferromagnetic substances small regions called domains. Within each domain all the electronic spins are parallel to each other-i.e., the domain is saturated. Adjacent domains have different directions of spins, i.e., of intrinsic B. The region between two domains is called the domain wall. Here the spin directions gradually change as the wall is crossed from one domain to another. In unmagnetized material the domain may have a linear dimension of 0.1 mm ; the wall thickness is about $10^{-4} \mathrm{~mm}$. When a field is applied, the domains originally oriented in the direction of the field begin to grow larger at the expense of the other domains; this is accomplished by the movements of the domain walls. Another process, called domain rotation, may also occur, where all the spins of a domain simultaneously rotate to the direction of the applied field.

Flipping the Cores. The dot notation for core windings is a very important point for an understanding of core circuits. The factors
involved are (1) the zero or unit state of the core, (2) the primary (energized) coil and the secondary (induced) coil, and (3) the direction of the current in (i.e., polarity of the voltage across) each coil (see Fig. 21-6a and $b)$. The dot notation organizes these factors according to the following conventions:

1. Flipping to zero (Fig. 21-6a). The driving current $I$ or impressed voltage $V$ will tend to flip the core to the zero state when the current


Fig. 21-6. Dot convention for flipping cores.
enters the lead adjacent to the dot. When a core is flipped to the zero state, the induced current in the secondary coil will leave the coil at the lead adjacent to the dot as the induced voltage makes that lead more positive than the other.
2. Flipping to unit (Fig. 21-6c). The driving current $I$ or impressed voltage $V$ will tend to flip the core to the unit state when the current leaves the dot lead. When a core is flipped to the unit state, the induced current of the secondary coil will enter the coil at the dot lead, as the induced voltage makes the dot lead more negative than the other.

If the current is such as to drive a core into the state which it already occupies, evidently no flipping of the core will result, and hence no voltage will be induced in the secondary coil.

Consider a two-winding core (such as in Fig. 21-6a) which has a constant-current pulse source applied to its primary coil to switch it. Figure 21-7 illustrates the shapes of the resulting flux and corresponding induced-voltage curves, as functions of time, during the switching process. Of course the induced voltage appears in each of the coils, as a counter emf in the primary and as an induced emf in the secondary. Observe that there is an initial rise in the flux, $\Phi_{i}$, and a peak in the voltage associated with the initiation of the current from the source. As the domains


Fig. 21-7. Flipping the core with a constant-current source.
become aligned, the flux increases, with its rate of change being reflected in the magnitude of the induced voltage. When the saturation flux $\Phi_{s}$ is obtained, there is no further increase in the flux and the voltage drops to zero. When the current is turned off, the flux is slightly reduced to the remanent value $\Phi_{r}$, and a corresponding spike appears in the voltage. If the current source now reverses direction, the core flips back to its original state.

When a voltage source $V$ is applied to the driving coil (see Fig. 21-8), there is an initial current rise of $I_{0}$ through the coil, until point $c$ or $h$ of Fig. 21-5 is reached. Then the switching of the core begins, and the counter emf in the driving coil limits the current flow to $I_{s}$ (see Fig. $21-8 b$ ). During this time the coil appears as an approximately constant resistance $R_{c}$. Of course the voltage source must be connected with a resistor $R$ in series with the coil, so that after the core is flipped (and $R_{c}$ becomes zero) the current will rise only to a value $I=V / R$. Letting $V_{s}$ be the voltage across the coil during switching, we have
and

$$
\begin{align*}
V_{s} & =\left(I_{s}-I_{0}\right) R_{t} \\
V & =I R=\left(I_{s}-I_{0}\right) R_{c}+I_{s} R \tag{21-8}
\end{align*}
$$

From these equations we find
and

$$
\begin{align*}
& V_{s}=\frac{R R_{c}\left(I-I_{0}\right)}{R+R_{c}} \\
& I_{s}=\frac{V+I_{0} R_{c}}{R+R_{c}} \tag{21-9}
\end{align*}
$$

The core switching resistance $R_{c}$ appears only during the time the core is switching, i.e., when $d \Phi / d t \gg 0$. Note that $R_{c}$ is approximately constant in the constant-voltage case (i.e., the $I_{s}$ part of the $I$ curve of Fig.


Fig. 21-8. Flipping the core with a constant-voltage source.
21-8 is approximately flat), but the approximation is not so good for the constant-current case. (Why? See Fig. 21-7.)
The value of $R_{c}$ can be estimated by means of considerations concerning the switching time of the core, the time $\tau$ required to switch or flip a core. This is frequently defined as the time required to switch the core through 80 per cent of $\Phi_{s}$. It has been found experimentally that if a constant $\mathrm{mmf} \mathfrak{F}_{s}$ (that is, constant $N I_{s}$ ) is used to switch a core, then the switching time is inversely proportional to the $\mathrm{mmf} \mathfrak{F}_{s}$. Since the coercivity must be applied before the core switches, the plot of $1 / \tau$ versus $\mathscr{F}_{s}$ appears as in Fig. 21-9. The equation of this straight line is

$$
\begin{equation*}
\frac{1}{\tau}=\frac{\mathfrak{F}_{s}-\mathfrak{F}_{0}}{S}=\frac{N\left(I_{s}-I_{0}\right)}{S} \tag{21-10}
\end{equation*}
$$

where $S$ is the slope of the line. If $d \Phi / d t$ is considered constant during the switching (that is, $R_{c}$ is constant), then $d \Phi / d t=0.8 \Phi_{s} / \tau$, whence from Eq. (21-6) $V_{s}=0.8 N \Phi_{s} / \tau$. Then by Eqs. (21-8) and (21-10) we
find

$$
\begin{equation*}
R_{c}=\frac{0.8 N^{2} \Phi_{s}}{S} \tag{21-11}
\end{equation*}
$$

If $R_{c}$ cannot be considered constant, then we can find an average $R_{c}$


Fig. 21-9. Experimental plot of the reciprocal of the switching time $\tau$ versus the mmf $\mathscr{F}_{s}\left(\mathscr{F}_{0}=N I_{0}\right.$ is the coercive mmf). defined such that $\bar{R}_{c}=\bar{V}_{s} /\left(I_{s}-I_{0}\right)$. However, the average voltage during switching, by Eq. (21-6), is

$$
\bar{V}_{s}=\frac{1}{\tau} \int_{0}^{\tau} V d t=\frac{0.8 N \Phi_{s}}{\tau}
$$

Then, from Eq. (21-10) we have once more

$$
\begin{equation*}
\bar{R}_{c}=\frac{0.8 N^{2} \Phi_{s}}{S} \tag{21-12}
\end{equation*}
$$

Getting back to the switching time, let us find the effect of the impressed voltage $V$ in the case of constant-voltage drive, and of the driving current $I$ in the case of constant-current drive. From Eqs. (21-10) and (21-9) we find

$$
\frac{1}{\tau}=\frac{N}{S} \frac{I-I_{0}}{R+R_{c}} R \quad \text { and } \quad \frac{1}{\tau}=\frac{N}{S} \frac{V-R I_{c}}{R+R_{c}}
$$

The constant-current case requires $R \gg R_{c}$, whence

$$
\boldsymbol{\tau}=\frac{S}{N\left(I-I_{0}\right)}
$$

whereas for the constant-voltage case $R_{c} \gg R$, whence

$$
\tau=\frac{S}{N} \frac{R_{c}}{N\left(V-R I_{0}\right)}=\frac{0.8 N \Phi_{s}}{V-R I_{0}}
$$

## EXERCISES

(a) Prove Eqs. (21-9) from Eqs. (21-8).
(b) If, for a core, $S=0.66 \times 10^{-4}$ (amp-turn)(sec) $/ \mathrm{m}, N=50$ turns, $I_{0}=3 \mathrm{ma}$, and $\Phi_{s}=4 \times 10^{-8}$ weber, find $R_{c}$ in ohms.
(c) Find the switching time $\tau$ for the core of Exercise $b$ when a current source $I=10 \mathrm{ma}$ is applied; when a voltage source of 10 volts through a resistance of '2,000 ohms is applied.

## 21-3. Diode-gated Magnetic-amplifier Circuits

Problems of Digital Magnetic Circuits. A discussion of an elementary core shift register will display the three important problems that arise
in connection with magnetic circuits, namely, (1) separation of the input and output phases of each core stage, (2) signal amplification, and (3) signal isolation of a core from its adjacent stages. In the operation of a core the initial state is a zero; the core is flipped for a unit input and remains unchanged for a zero input. To sense the bit stored in a core, an attempt is made to flip it to the zero state: if an output signal is induced in a sensing coil, a unit was stored; no signal indicates that a zero was stored. Figure 21-10 illustrates the elementary register to be described, which has two cores per register bit. Each core of our shift register has three windings: an input coil that will flip the core if a unit signal arrives from the previous stage; a clock coil that is driven by a


Fig. 21-10. Elementary core shift register, two cores per bit.
constant-current source to try to flip the core to zero; and an output coil that senses if the core was actually flipped by the clock. Note that the $A$ and $B$ clocks operate in alternate cycles. The simultaneous current pulses from the $A$ clocks will produce output signals from stages 0 and 2, as these stages are "cleared" to the zero state. These output signals become the respective input signals to stages 1 and 3 . When clocks $B$ are activated, stages 0 and 2 are cleared and are in their input phases, while stages 1 and 3 are in their output phases. Because the cores are alternately cleared as the information is shifted from stage to stage, the register requires two cores per bit.

Assume that the $B$ clocks are energized and that the stage 1 core is thereby flipped from the unit state to the zero state. Let the switching flux change be $\Phi_{1}$; then a voltage $V(t)=N d \Phi_{1} / d t$ will be induced in the $N$ turns of the stage 1 output coil. This voltage will be impressed across the $M$ turns of the stage 2 input coil, flipping it to the unit state. But as core 2 flips, a voltage is induced across its clock and output coils. However, the $A$ clocks are off, and no current can flow in the clock coil; and the induced voltage in the output coil reverse-biases the diode so that no current will flow. Thus during the flipping of the stage 2 core by the stage 1 core, the rate of induced flux is $d \Phi_{2} / d t=V(t) / M$. To find the total induced flux, observe that

$$
\int_{0}^{\tau} V d t=N \Phi_{1}=M \Phi_{2}
$$

If $M<N$, then $\Phi_{2}>\Phi_{1}$. This amplification of the signal is necessary

(b)

Fig. 21-11. Series clock-pulse core logic. (a) or-inverter gate; (b) direct instead of inverted output.
to ensure that the stage 2 core will flip even if there is some resistive loss and even if the clock and output coils of stage 2 do have some effect.

We have seen how stage 3 is isolated from stage 2 by the diode when the latter stage is flipped by stage 1. The problem still remains as to the effect of stage 1 on stage 0 , for as the $B$ clock flips stage 1 , a voltage will be induced in the input coil of stage 1 and the resulting current will be in the forward direction of the diode. Since current will flow, clearly flux will be induced in the core of stage 0 , but the induced flux $\Phi_{0}$ will be only a fraction of $\Phi_{1}$, since $\Phi_{0}=(M / N) \Phi_{1}$. Actually $\Phi_{0}$ will be even smaller because of resistive loss and because of some small effect of the input and clock windings on the core of stage 0 , and only partial reversal of the flux will occur. But stage 0 is also receiving an input at this time; if the input is a unit, no problem exists, for the core will be flipped the rest of the way; if a zero input occurs, the partial flux reversal will remain. Now consider the effect of this partial reversal when clock $A$ is energized. Some small voltage will be induced in the output coil of stage 0 . There is danger of this being amplified by the ratio $N / M$; in practice this does not happen, for the coercive force must first be met, and also the diode will still have appreciable resistance at low forward biases. Thus a small voltage will not be amplified, whereas, as we have seen above, a large voltage will be amplified.

Series Clock-pulse Core Logic. In the shift register, signal amplification was obtained by having a smaller number of turns on the input coil than the output coil. Although this proves adequate for driving one core, other techniques must be employed to drive more than one. Suppose, for example, that the core of Fig. 21-11a is in the zero state. A positive voltage swing of the clock will tend merely to drive the core further into the zero state and there will be little change of flux in the core. Hence the output coil will appear as little or no resistance, and the clock will essentially be connected directly to the output. The output voltage will very nearly follow the positive clock voltage. On the other hand, if the core is in the unit state a positive voltage swing of the clock will flip the core back to the zero state. As we have seen in the previous section, the output coil will then appear as a resistance through which the clock is connected to the output. Now if $R_{c} \gg R_{1}$, most of the voltage drop from the clock voltage to $-V$ will appear across the output coil and the output voltage will not rise appreciably. In this way the core acts as a resistance that can be switched in or out, and the output is driven directly by the voltage-source clock (and not by the core). This type of amplifier is generally called a Ramey magnetic amplifier. Note that in this circuit, as in the shift register above (and the circuits below), the input phase of one stage is the output phase of the preceding stage, and thus there is necessarily a half-unit-time-interval delay between successive gates.

Let us now consider the entire circuit of Fig. 21-11a. Here gating is accomplished in the usual fashion by the input diodes. At the start of the input phase the core is always in its zero state. During the input
phase a positive pulse arriving from $A$ or $B$ or $C$ will flip the core into its unit state. Note that we must distinguish between zero and unit signal levels and zero and unit core states. We have chosen a positive signal pulse to represent a unit signal level: thus the core is flipped into its unit state by a unit pulse. During the input phase, however, the clock voltage will be negative, reverse-biasing the output-coil diode, so that no current flows in the output coil. During the output phase the output coil flips the core back to the zero state; the output voltage remains close to ground, and a zero output signal results. Thus the circuit acts as an or inverter. As the core is flipped, the input coil reverse-biases the input diodes and no current flows. The grounded diode near $-V$ on the input coil assures that the input diodes will be truly reverse-biased (why?).

The circuit can be used to produce an uninverted output by reversing the input coil and using a bias coil connected to a current source (see Fig. 21-11b). During the input phase the bias coil tends to flip the core to its unit state. If there is a unit input signal (i.e., positive signal), then the input coil will drive against the bias coil, tending to keep the core in its zero state. The result will be no net change in the flux of the core, and the core will remain in the zero state. During the output phase the output-coil resistance will be negligible and a positive (unit) signal pulse will result. However, for all-zero input signals (near ground voltage level), the bias coil will succeed in flipping the core to its unit state; then during the output phase the output coil will present its switching resistance, and a zero output signal will result.

Parallel Clock-pulse Core Logic. In the above circuit the voltage source is connected in series with the output coil. Magnetic amplification can also be obtained by connecting the voltage source in parallel with the input coil (see Fig. 21-12). In the input phase, if all the previous cores connected to an and gate are in the unit state, then they will present a (divided) switching resistance between the +40 - and +1 -volt supplies, so that a unit signal will pass through the or gate. But if at least one of the cores of each and gate is in the zero state, each and gate then presents a small resistance, the inputs to the gates will all fall to near 1 volt, and the output of the or gate will be a zero signal. Note that the previous cores of the active and gates are flipped back to the zero state by the current from the 40 -volt supply (in part-see below).

During the input phase the voltage-source clock output will be positive. If the output from the or gate is a unit (a positive voltage at point $S$ of the figure), a current will flow through the input coil of the core to ground, flipping the core to the unit state. If the output from the or gate is a zero, point $S$ is near ground potential, the positive clock voltage reverse-biases its diode so that no current flows through the core input coil, and hence the core remains in the zero state.

During the output phase the voltage-source clock output swings negative, pulling down the voltage at $S$ and with it the voltages at $P$ and $Q$. The and-gate diodes isolate these negative voltages from the previous
gates, which are now in their input phases. At the same time the clock voltage is applied to the input coil of this gate in a direction to flip the core to the zero state. If the core is left in that state, the flow of current will not be impeded by the core nor will the core state be altered. If the


Fig. 21-12. Parallel clock-pulse core logic.
core is left in the unit state, the clock voltage on the input coil, together with the current in the output coil from the 40 -volt supply if the output is connected to an active and gate, will flip the core back to the zero state, ready for the next input phase. The circuit of Fig. 21-12 is known as the Hogue magnetic amplifier.

## EXERCISES

(a) Why must a voltage source be used in the Ramey amplifier circuit (see Fig. 21-11)?
(b) Draw the states of the core of the Ramey amplifier after the input phase and after the output phase, for both zero and unit pulse inputs.
(c) Why is the small $+V$ needed in Fig. 21-11b? (Hint: Where will current flow in the and-gate-or-gate network during the output phase?)
(d) For the Ramey amplifier describe the state of the preceding core stage and the input coil of the present stage during the output phase of the present core circuit.
(e) For the Hogue amplifier (Fig. 21-12) describe the states of the preceding core stage and the input coil of the present stage during the output phase of the present core circuit.
(f) For the Hogue amplifier describe the effect on the next successive stage of flipping the core to a unit during the input phase.
(g) Discuss the source or sources of amplification (power) in the Ramey and Hogue circuits.
(h) Devise a system for negation using the Hogue circuit. (Hint: Use an extra core.)
(i) Suppose in the Ramey amplifier of Fig. 21-11a that $V=-10$ volts, $R=2,000$ ohms, the clock voltage source is a $\pm 10$-volt square wave at 200 kc , the core is as described in Exercise $b$ of Sec. 21-2 with 50 turns on the input, 100 turns on the output windings, and inductances, respectively, of 2 and $4 \mu \mathrm{~h}$. Calculate the maximum number of cores that can be driven. [Hint: Recall that $\int_{0}^{t} v d t=L i(t)$ when current flows through a coil and the core is not being flipped.]

## 21-4. Magnetic Gating

Gating with Cores. In the previous section we were concerned with the use of cores for magnetic amplification. We now consider the use of


Fig. 21-13. Mirror notation.
cores for the logical gating functions as well. But first we consider a new, shorter notation for core windings, the mirror notation. In this notation a core is represented by a vertical bar (see Fig. 21-13a); the unit and zero (counterclockwise and clockwise) flux directions of the core are imagined
as upward and downward flux directions in the bar, respectively. A coil on the core is represented simply by an intersecting horizontal line (see Fig. 21-13b). A dot at the side of the bar could be used to represent the dot lead of the coil, as shown in the second column of Fig. 21-13b; the mirror notation replaces the dot by a diagonal line, slanted so that it acts like a mirror, "reflecting" the input-current direction into the resultant flux direction. For induced currents, see Fig. 21-13c, which shows the directions of the induced currents for both types of diagonal line. Frequently each intersection is considered a single turn, in which case more than one intersection must be used for several turns (see Fig. 21-13d).


Fig. 21-14. Gating with cores.
Gating is accomplished in two phases, as was amplification. In the input phase the logical function is formed in the core, represented by the resulting zero or unit state of the core. During the output phase a reset winding is pulsed to reset the core to zero. A sense winding then determines whether the core flips or not, i.e., whether its state was a zero or unit; the current induced by flipping is a unit output. For example, consider the gating configurations of Fig. 21-14. In (a) is illustrated an or gate with inputs $A$ and $B$. Either input $A$ or input $B$ alone provides sufficient current to switch the core to the unit state during the input phase. If both $A$ and $B$ occur, there will of course be twice as much current as necessary to switch the core, but the flux change will still be only to saturation, that is, $\Phi_{s}$. During the output phase the reset pulse causes the sense wire to be energized if the core was left in a unit state, for an output $A+B$. In the circuit of (b) we introduce a new element, the bias wire whose current alone is sufficient to flip the core. During the input phase the bias works against inputs $A$ and $B$, so that if the core is to be flipped to the unit state, both $A$ and $B$ must be energized. In the output phase the output will represent $A \cdot B$. Since this bias tends to change the core to the zero state, it is called a 0 bias. A 1 bias can also be used to produce negation, as shown in Fig. 21-14c. By the appropriate use of one or more bias wires any elementary Boolean product can be obtained. For example, Fig. 21-15a is a circuit generating
$\bar{A} \cdot B \cdot C \cdot \bar{D}$. Note that for each negation there is a corresponding 1-bias and, for an $n$-term product, $n-1$ of the 0 biases must appear. However, each pairing of a 1 bias and a 0 bias cancels and hence can be eliminated, as shown in Fig. 21-15b. With less than $n-1$ (gross) 0 biases the core logic becomes a logic of majority gating. For example, in Fig. 21-15c an output will appear if more than four of the inputs $A, B, C, D, E$, or $F$ occur. Negations can be handled in the same manner as for the elementary products.
 Fig. 21-15. Generating elementary products.
We have not yet considered the problems of isolation and amplification for our core-logic gating method. Adaptations of the Ramey or Hogue magnetic-amplifier circuits can be used, with a gating stage followed by an amplifying stage, and so forth. Or if the output need drive no more than a single subsequent core, the method used in the shift register of Fig. 21-10 can be employed. Figure 21-16a shows that shift register in the mirror notation, and Fig. 21-16b illustrates shifting into an and gate.
Gating with Flux. Note that when gating with cores we still had to use diodes for the transmission of information between cores. Gating by flux switching eliminates the necessity for using other than magnetic elements in the circuit: isolation, as well as a certain amount of amplification, can be obtained. Gating by flux switching is accomplished by means of multiaperture devices (abbreviated MAD), which are disks of square-loop ferrite material in which variously shaped holes have been made. The basic principle of a MAD can be described in terms of the two-hole device (called a Transfuxor) of Fig. 21-17. There are two windings, one through each hole as shown. If sufficient current $I$ is passed through the larger hole, the direction of the flux (lines with arrowheads) will be the same all the way round. This is called the clear state.

In particular the flux in $\operatorname{leg} L_{1}$ and $\operatorname{leg} L_{2}$ will be saturated (Fig. 21-17a). A current in winding $N_{R}$ cannot change the flux locally round the small hole (see dashed lines), for this would imply an increase in flux in one of the already saturated legs $L_{1}$ or $L_{2}$. However, if the current in $N_{R}$ is large enough, the flux can be reversed in leg $L_{1}$, but such a reversal

(a) Shift register in mirror notation

(b) Shifting into an and gate

Fig. 21-16. Use of shift-register method with core gating.
must extend to the flux all the way round the large hole (see Fig. 21-17b), because the lines of flux must close on themselves.
With the flux lines in this set state, a smaller current in $N_{R}$ can now vary the amount of flux round the small hole (within the limits of saturation). For, in changing from the clear to the set state, the flux in the long path round the large hole has to be reversed; this requires a larger $\mathcal{F}=N_{R} I=H l$ than does just changing the flux in the shorter path round the small hole in the set state. To see how this occurs, consider the flux in leg $L_{1}$ of the MAD in the clear state (see point a of Fig. 21-18). As the current in $N_{R}$ is increased, the flux goes from $a$ to $b$ to $c$, at which point the flux reversal begins, to the saturated state $d$, and on further driving to $e$. At and beyond $d$ the MAD is in its set state.

Reversing the current in $N_{R}$, the flux of leg $L_{1}$ now follows the dashed line of Fig. 21-18, going to $f$, to $g$, from which point the flux in the smaller loop is switched, to $h$. The flux in leg $L_{1}$ can now be varied round the path $h,(i), j, f, g$ by varying the current in $N_{R}$. Note that, in the set state,


Fig. 21-17. Two-hole MAD (Transfluxor) showing clear and set states.
a small $\operatorname{mmf} \mathscr{F}_{s}$ will switch some flux in $L_{1}$, whereas in the clear state this will not occur (see point $b^{\prime}$ in Fig. 21-18), since then $\mathfrak{F}_{c}$ is needed.

The operation of a three-hole MAD can be described in terms of the principles developed for the two-hole MAD. In the clear state, induced


Fig. 21-18. Switching flux in $L_{1}$, clear and set states (solid line, clear state; dashed line, set state). by a strong current through the "clear" wire, a small current in $N_{R}$ or $N_{T}$ cannot cause any flux change (see Fig. 21-19a). A large current in $N_{R}$ will put the MAD in the set state (see Fig. 21-19b). Note that the reversal of flux takes place primarily in the shortest possible path round the large hole, through $L_{3}$ rather than $L_{4}$. This is to be expected: $\mathfrak{F}$ will roughly be inversely proportional to the distance from the wire, and as $\mathfrak{F}$ is increased, the coercive force for flux reversal is reached sooner round a shorter path than round a larger path. The exact geometry of the MAD thus becomes an important factor in its operation. In the set state a small current in $N_{T}$ or $N_{R}$ will be able to change the flux locally round its respective small hole.

Note that a change in the flux round the small $N_{T}$ hole will not affect the state of the MAD. This principle is used for isolation in MAD logic. Amplification is obtained as follows: Consider the coil $N_{T}$ of one MAD connected to the coil $N_{R}$ of another, as shown in Fig. 21-20. Let the set state represent the unit, and let the MAD receiving the unit initially
be in the clear state. A relatively small current pulse $I$ in the split winding shown in Fig. 21-20a will encounter a switching resistance in the

(a) Clear (zero) state

(b) Set (unit) state

Fig. 21-19. Diagrammatic illustration of the flux lines in the clear and set states of the three-hole MAD.
set MAD; but low values of $I$ will not affect the flux in the clear MAD, and no resistance will be developed. Hence the current will almost all pass through the clear MAD, finally rising to a level high enough to change the clear MAD into the set, or unit, state. This effect can be increased by making turns $N_{T}$ greater in number than turns $N_{R}$. If a zero is to be transmitted (Fig. 21-20b), then both MAD's are in the clear state initially. The current pulse will be equally divided through $N_{T}$ and $N_{R}$ but will not be great enough in either to change states. Amplification results from this current-switching phonomenon. A shift register can be made on this principle (see Fig. 21-21), again using two cores (stages $A$ and $B$ ) for each bit. There must now be four phases

(b)

Fig. 21-20. (a) Transferring a unit; (b) transferring a zero. (the pulse wires of the figure) to shift each bit. First the $B$ stages must be cleared, and then the $A$-to- $B$ transfer pulse sets the $B$ stages. Third, the $A$ stages are to be cleared, and last the $B$-to- $A$ transfer current pulse sets the $A$ stages.


FIG. 21-21. MAD shift register.
(a)
gate
(b)
(c)
and gate

Fig. 21-22. Diagrammatic illustration of flux linkages in gating with flux.
Logical gating can be achieved in a single MAD element. Figure $21-22 a$ represents an or gate. The zero state of an output aperture occurs when the flux is in the same direction in both legs about the aperture, i.e., when the flux does not link locally round the aperture. The unit state of an output aperture occurs when the flux does link locally round the aperture. If no unit (i.e., current pulse) is received in either $A$ or $B$, the or MAD remains in the clear state; i.e., the output is a zero. But if an input is received at $A$, for example, the shortest path
that will allow a flux change in the outside leg of aperture $A$ is round the large hole as shown. This flux linkage leaves the output hole locally linked, and hence a unit output occurs. By symmetry it is seen that a unit output will result from $A+B$. Negation is a little more compli-cated-see Fig. 21-22b. Here the clear wire sets the output aperture to a locally closed state, i.e., a unit (note carefully the path of the clear wire). An input zero of course leaves this state unchanged, and the output is a unit. A unit input pulse, however, reverses the flux round the shortest possible path, the periphery of the core as shown. (Note that a hold wire keeps the flux in the cross leg in the direction shown, in both the clear and set states.) Thus the resulting flux round the output aperture does not link it, to form a zero output. An and gate (Fig. 21-22c) operates as follows: Consider a single unit input at $B$. A flux reversal in the outside leg of aperture $B$ can occur by linking the nearest half of the center hole as shown. But the output aperture is still linked round the other half of the center hole and hence still remains a zero. It is clear that, if an input occurs at $A$ and $B$ at the same time, the output aperture will be linked locally.

## EXERCISES

(a) Using the mirror notation, design a core circuit that will have an output if more than four of $\bar{A}, B, C, \bar{D}, E$, and $\bar{F}$ are inputs. Minimize the number of necessary wires.
(b) Making use of the majority feature of core gating, design a serial adder using only four cores (cf. Exercise c of Sec. 19-2).
(c) Draw a flux-linkage diagram for the case of $A$ and $B$ both being inputs to the MAD or gate.
(d) Draw a flux-linkage diagram for the case of $A$ and $B$ both being inputs to the MAD and gate, showing the unit output.
(e) Design a serial adder using MAD logical elements.
(f) How can single-aperture cores be used, in a way analogous to the use of multiaperture devices, to form and, or, and not gates without the use of diodes or any other elements? (Hin't: Use combinations of single-hole cores with different hole diameters wired appropriately together.)

## 21-5. Modern Computer Techniques

The Cryotron. $\dagger$ Cryogenics is the study of extremely low-temperature phenomena. Cryotron is the name given to a switching device whose operation is based on superconductivity, which occurs at extremely low temperatures. When certain elements are cooled to near absolute zero temperature, their electrical resistivity drops practically to zero. This transition into the superconductive state occurs at a sharply defined temperature, which is characteristic of the element but can be altered by an applied magnetic field. In general, the greater the magnetic field, the lower becomes the transition temperature. This magnetic phenomenon is the basis for the Cryotron. Figure 21-23 shows the transition
$\dagger$ The Cryotron as a computer element was invented in 1955 by Dudley A. Buck.
temperature as a function of the applied magnetic field for tin (Sn) and lead ( Pb ), two metals capable of superconductivity. (Such low temperatures can be maintained in liquid helium.)

Figure 21-24 pictures the simplest of Cryotrons, consisting of crossed "wires" of tin and lead, operated at a temperature of about 2 to $3^{\circ} \mathrm{K}$. When no current is flowing in the lead wire, both wires are superconducting. When current flows in the lead wire, the magnetic field created by


Frg. 21-23. Superconductor transition temperature as a function of applied magnetic field for Sn and Pb .


Fig. 21-24. A Cryotron.
this current flow forces the tin wire out of the superconducting state (see the dashed line in Fig. 21-23). The tin "wire" is made about ten times wider than the lead wire, to reduce its current density so that its magnetic field will not bring the lead wire out of the superconductive state. The lead wire, which is thus always in a superconducting state, is the controlling element; the tin wire, whose superconducting state is dependent on the current flow in the lead wire, is the controlled element. Because of the negligible resistance encountered, it is convenient to have a current source and to use the Cryotron as a current switching device. Figure $21-25 a$ shows a Cryotron and gate; Fig. 21-25b shows an or-gate. In each circuit the current is switched to one or the other of the two outputs.

In connection with Cryotrons it has been suggested that an electron-
microscope beam be used to aid the construction of the circuit patterns from thin films. The use of film wires as illustrated may have the advantage of decreasing the required switching time to the millimicrosecond range. According to this suggested technique a thin film of Sn (or Pb ) is placed as the object of the electron microscope and the electron beam moved to trace the desired path of a wire. It happens that, wherever the beam hits, a hard substance, namely, $\mathrm{SiO}_{2}$, is formed from the tetraethoxysilane present in the beam chamber because of the


Fig. 21-25. Cryotron and and or gates.
oil-diffusion vacuum system. A small quantity of chlorine gas introduced into the chamber will etch the film, removing all metal not covered by $\mathrm{SiO}_{2}$. Hence the trace of the electron beam is left as a flat wire. Finally, if desired, the $\mathrm{SiO}_{2}$ can be removed by introducing a small amount of hydrogen fluoride gas into the chamber. It is expected that by this procedure "wires" of a diameter approximating $0.1 \mu\left(10^{-5} \mathrm{~cm}\right)$ can be formed, several layers of such wires being formed over each other to complete the Cryotron gates. If this technique can be fully developed, then we can have over 100 million gates within 1 square centimeter. Such a process could significantly change the logical design concepts and introduce an entirely new capability into digital-computer engineering. However, such techniques are still in their early experimental stages.

A Cryotron computer would operate inside a Dewar flask, or the like, filled with liquid helium, into which must lead the wires connecting the computer with the outside world. In the case of component failure
there would be no way to repair the computer. This, coupled with the fact that a practically unlimited number of gates can be incorporated into the computer, indicates the possibly great effectiveness of the probabilistic-logic approach to increasing the reliability of gating circuit outputs (see Sec. 19-4).

Microwave Computer Components. Microwaves can be conveniently transmitted and gated by means of so-called strip-line components (see Fig. 21-26a). A strip line consists of a copper ground plane, covered


Fig. 21-26. Microwave components. (a) The strip line; (b) coaxial connection; (c) line termination with carbon wedge; (d) diode in the strip line.
by a layer of dielectric material, on top of which are placed strips of copper. Microwaves will be guided along the strip line, confined approximately between the ground plane and the top copper strip itself. It may be desirable to place another layer of dielectric on top of this and finally another copper ground plane; however, we do not illustrate this in our diagrams for the sake of clarity. Energy from a klystron or magnetron can be inserted into the strip line by means of a coaxial connection (see Fig. 21-26b). A line can be terminated by a wedge of carbon placed at its end to convert the electromagnetic energy into heat (see Fig. 21-26c). Diodes can also be placed in the line (see Fig. 21-26d).

Attempts are being made to utilize strip-line microwave techniques to obtain gating components with unit time intervals in the millimicrosecond range. One technique is to use a carrier wave of approximately 2,000 megacycles, modulated at about 500 megacycles, for unit-zero information transmission. Using these figures for illustrative purposes, a unit (or zero) signal would be represented by a burst of four 2,000 -megacycle oscillations; actually, however, groups of 10 to 15 oscillations are presently being employed. There are two ways of representing unit
and zero bits with these 2,000-megacycle pulse bursts, called the phasescript and pulse-script methods. The concept of phase script is just that described previously (Sec. 19-2) for a Parametron; the pulse script is analogous to the usual dynamic operation (see Fig. 21-27). Since it is easy to convert from pulse to phase script, and vice versa, either method can be utilized in different parts of the same computer, as convenience or electronic considerations may require.


Fig. 21-27. Unit and zero representations in phase and pulse scripts.


Fig. 21-28. Microwave parametric amplifier.
Consider the phase script first. A parametric amplifier (see Fig. 21-28) can be used, with a 4,000 -megacycle primary source of energy entering the strip line at $P$. Any 2,000-megacycle input signal, coupled into the amplifier at $C$, will be amplified with its same phase in the 2,000 -megacycle half-wave resonator $R$. A diode $D$ in this resonator serves as a variable reactor; a 4,000-megacycle half-wave resonant strip $H$ allows the 4,000-megacycle drive to enter $R$ but prevents the 2,000-megacycle energy from escaping. A loosely coupled output arm $F$ guides the amplified 2,000 -megacycle signal to the rest of the circuit.

An and gate can be constructed by means of a so-called hybrid ring (see Fig. 21-29a). The ring is a circular section of strip line $11 / 2$ wave-
lengths in effective circumference. A constant train of microwaves entering the ring through arm $K$ as shown in the figure can split and go round the ring in both directions. When the two halves meet at $C$, they will be in phase; but when they meet at either $\operatorname{arm} A$ or $\operatorname{arm} B$,


Fig. 21-29. (a) Hybrid ring; (b) time-phase relationships at arm C.
they will be $1 / 2$ wavelength out of phase and will therefore cancel, feeding no energy into $A$ or $B$. Neither will this energy be reflected back into arm $K$, because it will be $1 / 2$ wavelength out of phase with the incoming wave at $K$. Similarly the energy entering the ring at $A$ will cancel at arms $K$ and $B$ and will not be reflected back at $A$ but will be in phase at $C$; energy entering at $B$ will cancel at $K$ and $A$, will not be reflected back at $B$, but will be in phase at $C$. If the constant wave is in the unit
phase at $K$, then both $A$ and $B$ inputs will have to be in the unit phase for the resulting wave in arm $C$ to be in the unit phase. For the constant wave entering at $K$ will reinforce a zero-phase wave entering $A$ or $B$ or both (see Fig. 21-29b). Thus $C=A \cdot B$, and we have an and gate. An or gate can be obtained by having the constant input in the zero phase when it enters at $K$, instead of the unit phase. Negation is of course obtained by sending the wave through an extra $1 / 2$ wavelength of strip line.


Fig. 21-30. Pulse-script and gate.
The pulse-script gating techniques use the hybrid ring also. For example, consider the ring used as an and-gate (see Fig. 21-30). Note again that the clockwise and counterclockwise waves due to an input at $A$ cancel at $B$, and conversely waves entering at $B$ cancel at $A$. If there is only one input, e.g., a train of pulses entering at $A$ but not $B$, then half the power is absorbed at $D$ and the other half enters $C$. On the other hand, if a train of wave pulses enters $A$ and $B$ at the same time (and in the same phase), then they will cancel at $D$ (i.e., no power will be lost in $D$ ) and will reinforce at $C$. Therefore four times the power will appear at $C$ when there is an input at both $A$ and $B$ than will appear at $C$ when there is only one input. The operation of the not gate of Fig. 21-31 is as follows: If no pulse enters $A$, then the constant power entering at $K$ will be divided between $D$ and the output $\bar{A}$, presenting a pulse of waves at $\operatorname{arm} \bar{A}$. If a group of waves enter at $A$, then there is canceling at $\bar{A}$ due to the constant input $K$ and there is no output; all the power is absorbed at $D$.

Observe, however, that the parametric amplifier cannot be used in the pulse script, for even if there is no pulse (zero) input to the 2,000-megacycle resonator, 2,000-megacycle energy will still be accumulated (in an essentially random phase). Hence the pulse script must be converted into phase script; the phase script is amplified and then converted back to pulse script. For conversion from pulse to phase script consider the hybrid ring of Fig. 21-32, where the $\bar{A}$ input is delayed by a half wave-


Fig. 21-31. Pulse-script not gate.
length so that it will be $\pi$ radians out of phase with $A$. Only one at a time of these inputs will contain energy, and hence the wave output pulse will be in the unit or in the zero phase script depending on which input contains the energy. For conversion from phase to pulse script consider Fig. 21-33. A unit phase input at $A$ will be reinforced at $C$ by the


Fig. 21-32. Converting from pulse to phase script.


Fig. 21-33. Converting from phase to pulse script.
constant. A zero phase input will interfere with and cancel the constant at $C$, and no output will result; the energy will be dissipated at $D$ (why?).

## EXERCISES

(a) Design a serial adder, using the Cryotron gates illustrated in Fig. 21-25.
(b) Design a microwave serial adder, using hybrid rings in the phase script. Take advantage of the majority principle, and use only four rings (cf. Exercise $c$ of Sec. 19-2 and Exercise $b$ of Sec. 21-4).

## 21-6. Additional Topics

## a. Selected Bibliography on the Physics of Magnetic Elements

Bates, L. F.: "Modern Magnetism," 3d ed., Cambridge University Press, New York, 1951.

Bauer, E. W., and L. P. Hunter: High Speed Coincident-flux Magnetic Storage Principles, J. Appl. Phys., vol. 27, no. 11, pp. 1257-1261, November, 1956.
Bozorth, R. M.: "Ferromagnetism," chaps. 5 and 7, D. Van Nostrand Company, Inc., Princeton, N.J., 1951.
Brown, D. R.: Squareness Ratio for Coincident-current Memory Cores, MIT Digital Computer Lab., Eng. Note E-464, July, 1952.
Coleman, R. P.: Relation between Magnetic-core Switching Time and the Width of Ferromagnetic Resonance Peaks, Proc. AIEE Conf. Magnetism and Magnetic Materials, 1956, pp. 620-624.
DeBlois, R. W.: Domain Wall Motion in Metals, J. Appl. Phys., vol. 29, pp. 459-467, 1958.

Digital Magnetic Circuits-Theory, Electrical Design, and Logical Design, Burroughs Corp. Tech. Rept. TR 59-27, vols. 1-3, April, 1959.
Gianola, U. F.: Switching in Rectangular Loop Ferrites Containing Air Gaps, J. Appl. Phys., July, 1958, p. 1122.
Gyorgy, E. M.: Rotational Model of Flux Reversal in Square Loop Soft Ferromagnets, J. Appl. Phys., vol. 29, p. 283, 1958.

Harrington, J. V.: On the Statics and Dynamics of Magnetic Domain Boundaries, MIT Lincoln Lab. Tech. Rept. 166, Jan. 13, 1958.
Hunter, L. P., and E. W. Bauer: High-speed Coincident-flux Magnetic Storage Principles, J. Appl. Phys., vol. 27, pp. 1257-1261, November, 1956.
Katz, H. W. (ed.): "Solid State Magnetic and Dielectric Devices," John Wiley \& Sons, Inc., New York, 1959.
Kilburn, T., G. R. Hoffman, and P. Wolstenholme: Reading of Magnetic Records by Reluctance Variation, Proc. IEE, vol. 103, pt. B, suppl. 2, Convention on Digital Computer Techniques, pp. 333-336, April, 1956.
Krell, A. I., C. Meyer, and R. D. Torrey: Switching Characteristics of Magnetic Cores as Circuit Elements, Transistor and Solid-state Circuits Conference, 1957.
McNamara, F.: Noise Problem in a Coincident-current Core Memory, IRE Trans. on Instrumentation, vol. I-6, pp. 153-156, June, 1957.
Menyuk, N., and J. B. Goodenough: Magnetic Materials for Digital Computer Components: Part I, A Theory of Flux Reversal in Polycrystalline Ferromagnetics, J. Appl. Phys., vol. 26, pp. 8-18, January, 1955; Part II, Magnetic Characteristics of Ultrathin Molybdenum Permalloy Cores, ibid., vol. 26, pp. 692-697, June, 1955.
Minnick, R. C., and R. L. Ashenhurst: Multiple-coincidence Magnetic Storage Systems, J. Appl. Phys., vol. 26, pp. 575-579, May, 1955.
Rajchman, J. A.: Survey of Magnetic and Other Solid-state Devices for the Manipulation of Information, IRE Trans. on Circuit Theory, vol. CT-4, pp. 210-225, September, 1957.
Rossing, T. D., and S. M. Rubens: Effect of a Transverse Field on Switching Rates of Magnetic Memory Cores, J. Appl. Phys., vol. 29, pp. 1245-1247, August, 1958.
Snoek, J. L.: "New Developments in Ferromagnetic Materials," Elsevier Press, Inc., Houston, Tex., 1947.
Van Sant, O. J.: Considerations for the Selection of Magnetic Core Materials for Digital Computer Elements, IRE Conv. Record, pt. 4, pp. 109-113, 1954.
b. Selected Bibliography on Magnetic-core Circuits, Both Diode-gate Amplifiers and Core Logic
Anderson, J. R.: A New Type of Ferroelectric Shift Register, IRE Trans. on Electronic Computers, vol. EC-5, pp. 184-191, December, 1956.
Andrews, L. J.: A Technique for Using Memory Cores as Logical Elements, Proc. Eastern Joint Computer Conf., December, 1956, pp. 1139-1147.
Auerbach, I. L.: Ferromagnetic Cores with Microsecond Access, Proc. Symposium on Large Scale Digital Computing Machines, August, 1953, pp. 118-129.
Bambrough, B.: Digital Computer Based on Magnetic Circuits, Proc. IEE, vol. 104, pt. B, suppls. 5-7, pp. 485-490, 1957.
Bonn, T. H.: Analysis of Magnetic Switching Circuits, Proc. Intern. Symposium on Switching Theory, April, 1957.
Devenny, C. F., and L. G. Thompson: Ferromagnetic Computer Cores, Tele-Tech \& Electronic Inds., vol. 14, no. 9, pp. 58-59, 84-94, September, 1955.
Digital Magnetic Circuits-Theory, Electrical Design, and Logical Design, Burroughs Corp. Tech. Rept. TR 59-27, vols. 1-3, April, 1959.
Dorey, P. F., and O. Eldridge: Core-transistor Logical Element, Proc. IEE, vol. 104, pt. B, suppls. 5-7, pp. 512-522, 1957.
Evans, W. G., W. G. Hall, and R. I. Van Nice: Magnetic Logic Circuits for Control Systems, Trans. AIEE, pt. II, Applications and Ind., vol. 75, pp. 166-171, July, 1956.

Freedman, A. L.: Magnetic Core Matrices for Logical Functions, Electronic Eng., June, 1959, pp. 358-361.
Geyger, W. A.: "Magnetic Amplifier Circuits," 2d ed., McGraw-Hill Book Company, Inc., New York, 1957.
Guterman, S., and W. M. Carey: A Transistor-magnetic Core Circuit; a New Device Applied to Digital Computing Techniques, IRE Conv. Record, pt. 4, pp. 84-94, 1955.
——, R. D. Kodis, and S. Ruhman: Circuits to Perform Logic and Control Functions with Magnetic Cores, IRE Conv. Record, pt. 4, pp. 124-132, 1954.
Hogue, E. W.: Magnetic Amplifiers for Digital Computers, Elec. Mfg., vol. 61, pp. 150-151, May, 1958.
-_: A Saturable Transformer Digital Amplifier with Diode Switching, Proc. Eastern Joint Computer Conf., December, 1956, pp. 58-64.
Isborn, C.: Application of Ferristor Type Saturable Reactors to Digital Instrumentation, Paper 56-33-2, Proc. Instr. Soc. Am. Ann. Conf., September, 1956.
Karnaugh, M.: Pulse Switching Circuits Using Magnetic Cores, Proc. IRE, vol. 43, pp. 570-584, May, 1955.
Kodis, R. D., S. Ruhman, and W. D. Woo: Magnetic Shift Register Using One Core per Bit, IRE Conv. Record, pt. 7, pp. 38-42, 1953.

- , S. S. Guterman, and S. Ruhman: Logical and Control Functions Performed with Magnetic Cores, Proc. IRE, vol. 43, pp. 291-298, March, 1955.
Loev, D., W. Miehle, J. Paivinen, and J. Wylen: Magnetic Core Circuits for Digital Data Processing Systems, Proc. IRE, vol. 44, no. 2, pp. 154-162, February, 1956.
Meyerhoff, A. J.: Magnetic Core Components for Digital Control Applications, Automatic Control, April, 1956, pp. 15-19; May, 1956, pp. 13-15; July, 1956, pp. 34-40.
Newhouse, V. L., and N. S. Prywes: High-speed Shift Registers Using One Core per Bit, IRE Trans. on Electronic Computers, vol. EC-5, pp. 114-120, September, 1956.

Papoulis, A.: The Nondestructive Read-out of Magnetic Cores, Proc. IRE, vol. 42, pp. 1283-1288, August, 1954.
Ramey, R. A.: The Single-core Magnetic Amplifier as a Computer Element, Trans. AIEE, Communs. and Electronics, vol. 71, pp. 442-446, January, 1953.
-_: On the Control of Magnetic Amplifiers, U.S. Naval Research Lab. NRL Rept. 3869, October, 1951. (Also available from Office of Technical Services, U.S. Department of Commerce, as PB 105747.)
-_: On the Mechanics of Magnetic Amplificr Operation, Trans. AIEE, vol. 70, pt. II, pp. 1214-1223, 1951. (Also available from Office of Technical Services, U.S. Department of Commerce, as PB 104106 and as U.S. Naval Research Lab. NRL Rept. 3799.)
Russell, L. A.: Diodeless Magnetic Core Logical Circuits, IRE Natl. Conv. Record, pt. 4, pp. 106-114, March, 1957.
Sack, H. S., et al.: Special Magnetic Amplifiers and Their Use in Computing Circuits, Proc. IRE, vol. 35, pp. 1375-1382, November, 1947.
Sands, E. A.: An Analysis of Magnetic Shift Register Operation, Proc. IRE, vol. 41, pp. 993-999, August, 1953.
Scarrott, G. G., W. J. Harwood, and K. C. Johnson: The Design and Use of Logical Devices Using Saturable Magnetic Cores, Proc. IEE, vol. 103, pt. B, suppl. 2, Convention on Digital Computer Techniques, pp. 302-312, April, 1956.
Storm, H. F.: "Magnetic Amplifiers," John Wiley \& Sons, Inc., New York, 1955.
Van Nice, R. I.: Magnetic Logic Circuit Control System Design Considerations, Trans. $A I E E$, vol. 75, pt. I, pp. 595-600, 1956.

## c. Selected Bibliography on Multiaperture Magnetic Devices

Abbas, S. A., and D. L. Critchlow: Calculation of Flux Patterns in Ferrite Multipath Structures, IRE Conv. Record, pt. 4, pp. 263-267, 1958.
Abbott, H. W., and J. J. Suran: Multihole Ferrite Core Configurations and Applications, Proc. IRE, vol. 45, pp. 1081-1093, August, 1957.
Baldwin, J. A., Jr., and J. L. Rogers: Inhibited Flux-A New Mode of Operation of the Three-hole Memory Core, J. Appl. Phys., vol. 30, pp. 58S-59S, April, 1959.
Bennion, D. R., and H. D. Crane: Design and Analysis of MAD Transfer Circuitry, Proc. Western Joint Computer Conf., March, 1959, pp. 21-36.
Bobeck, A. H.: A New Storage Element Suitable for Large-sized Memory ArraysThe Twistor, Bell System Tech. J., vol. 36, no. 6, pp. 1319-1340, November, 1957.
——: New Concept in Large-size Memory Arrays-The Twistor, J. Appl. Phys., vol. 29, pp. 485-486, March, 1958.
—__ and R. S. Title: The Twistor—Its Use in a Memory Array, Proc. Nonlinear Magnetics and Magnetic Amplifiers Special Tech. Conf., August, 1958, p. 234.
Crane, H. D.: A High-speed Logic System Using Magnetic Elements and Connecting Wire Only, Proc. IRE, vol. 47, pp. 63-73, January, 1959.
Engelbart, D. C.: A New All-magnetic Logic System Using Single Cores, Digest of Technical Papers, p. 66, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Gianola, U. F., and T. H. Crowley: The Laddic-A Magnetic Device for Performing Logic, Bell System Tech. J., vol. 38, no. 1, pp. 45-72, January, 1959.
Lockhart, N. F.: Logic by Ordered Flux Changes in Multipath Ferrite Cores, IRE Conv. Record, pt. 4, pp. 268-278, 1958.
Newhouse, V. L., N. R. Kornfield, and M. M. Kaufman: A Transistorized Ferrite Plate Memory, Proc. Natl. Electronics Conf., 1958, pp. 641-652.

Prywes, N. S.: Diodeless Magnetic Shift Registers Utilizing Transfluxors, IRE Trans. on Electronic Computers, vol. EC-7, pp. 316-324, December, 1958.
Rajchman, J. A.: Ferrite Apertured Plate for Random Access Memory, Proc. IRE, vol. 45, pp. 325-334, March, 1957.
: Principles of Transfluxor and Core Circuits, Proc. Intern. Symposium on Switching Theory, April, 1956.
——and A. W. Lo: The Transfluxor, Proc. IRE, vol. 44, pp. 321-332, March, 1956.
——and The Transfluxor-A Magnetic Gate with Stored Variable Setting, RCA Rev., vol. 16, pp. 303-311, June, 1955.
Rumble, W. G., and C. S. Warren: Coincident Current Applications of Ferrite Apertured Plates, IRE Wescon Record, pt. 4, pp. 62-66, 1958.
Warren, C. S.: Ferrite Apertured Plate Memories, Digest of Technical Papers, p. 18, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.

## d. Selected Bibliography on the Cryotron

Bonn, T. H.: Magnetic Computer Has High Speed, Electronics, Aug. 1, 1957, pp. 156-160.
Bremer, J. W.: Cryogenic Devices in Logical Circuitry and Storage, Elec. Mfg., vol. 61, no. 2, pp. 78-83, February, 1958.
Buck, D. A.: A Magnetically Controlled Gating Element, Proc. Eastern Joint Computer Conf., 1956, pp. 47-50.
-_: Superconductive Circuit Response Time: A Survey, Digest of Technical Papers, p. 28, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
——: The Cryotron, a Superconductive Computer Component, Proc. IRE, vol. 44, pp. 482-493, April, 1956.
Kraus, C. J.: Pro's and Con's on a Superconducting Memory, Digest of Technical Papers, p. 20, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
——: Operation of a Low-temperature Memory Element, Digest of Technical Papers, Transistor and Solid-state Circuits Conference, February, 1958.
McMahon, H. O.: Superconductivity and Its Application to Electric Circuits, Proc. Symposium on the Role of Solid State Phenomena in Elec. Circuits, 1957, pp. 187-195.
Richards, R. K.: Proposed New Cryotron Geometry and Circuits, Digest of Technical Papers, p. 30, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Slade, A. E., and H. O. McMahon: A Cryotron Catalog Memory System, Proc. Eastern Joint Computer Conf., 1956, pp. 115-120.
e. Kilomegagate Systems. Cryogenic techniques as well as other methods presently being developed give promise of feasibly obtaining billions of gates in a single computing system. The only known system of this type presently in existence is the mammalian brain. The following articles are concerned with problems of the analysis of brain mechanisms.
Farley, B. G., and W. A. Clark: Generalization of Pattern Recognition in a Selforganizing System, Proc. Western Joint Computer Conf., 1955, pp. 86-91.
—— and ——: Simulation of Self-organizing Systems by Digital Computer, IRE Trans. on Inform. Theory, vol. PGIT-4, pp. 16-84, September, 1954.
Hebb, D. O.: "The Organization of Behavior," John Wiley \& Sons, Inc., New York, 1959.

Rochester, N., J. H. Holland, L. H. Haibt, and W. L. Duda: Tests on a Cell Assembly Theory of the Action of the Brain, Using a Large Digital Computer, IRE Trans. on Inform. Theory, vol. IT-2, pp. 80-93, November, 1956.
Rosenblatt, F.: The Perceptron: A Theory of Statistical Separability in Cognitive Systems, Cornell Aeronaut. Lab. Rept. VG-1196-G-1, January, 1958.
——: The Perceptron, a Probabilistic Model for Information Storage and Organization in the Brain, Psychological Rev., vol. 65, pp. 386-408, 1958.
——: Two Theorems of Statistical Separability in the Perceptron, Proc. Symposium on the Mechanization of Thought Processes, 1958. (Awaiting publication by H. M. Stationery Office, London; also printed without appendix as Cornell Aeronaut. Lab. Rept. VG-1196-G-2, September, 1958.)
——: Perceptual Generalization over Transformation Groups, Proc. Interdisciplinary Conf. on Self-organizing Systems, 1959. (Awaiting publication by Office of Technical Services, U.S. Department of Commerce.)

## f. Selected Bibliography on Microwave Components

Albers-Schoenberg, E.: Ferrites for Microwave Circuits and Digital Computers, J. Appl. Phys., vol. 25, pp. 152-154, February, 1954.

Baker, R. H., T. H. Meisling, and G. Nielson: "Application of Frequency-domain Techniques to Computers," Stanford Research Institute, Stanford, Calif., September, 1956.
Blattner, D. J., and F. Steizer: Fast Microwave Logic Circuits, IRE Natl. Conv. Record, pt. 4, pp. 252-258, March, 1959.
——and ——: Microwave Carrier Technique for High Speed Digital Computing, Symposium on Microwave Techniques, Mar. 12, 1959, Washington, D.C.
Edson, W. A.: Frequency Memory in Multi-mode Oscillators, Stanford Univ. Tech. Rept. 16, July 19, 1954.
Forrer, M. P.: Investigation of Application of Frequency Memory Techniques, Gen. Elec. Microwave Lab. Rept. R55 ELS 12.3, Dec. 12, 1955.
——, L. Fein, and V. Met: Microwave Techniques for Computer Application, Quarterly and Final Reports on Office of Naval Research Contract Nonr-2127(00), December, 1956-December, 1958.
Giguere, W. J., J. H. Jamison, and J. C. Noll: Transistor Pulse Circuits for 160MC Clock Rates, Digest of Technical Papers, p. 68, IRE-AIEE, Solid-state Circuits Conference, 1959, University of Pennsylvania.
Ortel, W. C. G.: Nanosecond Logic by Amplitude Modulation at X-band, Symposium on Microwave Techniques for Computing Systems, Mar. 12, 1959, Washington, D.C.

Steizer, F., and W. R. Beam: Parametric Sub-harmonic Oscillators, Digest of Technical Papers, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Wigington, R. L.: A New Concept in Computing, Proc. IRE, vol. 47, pp. 516-523, April, 1959.

CHAPTER 22

## MEMORY AND INPUT-OUTPUT METHODS

## 22-1. Introduction

Memory systems were touched upon briefly in Chap. 17, where our major concern was their integration into the logical design of the control circuitry. In the present chapter some of the electronic features of memory systems are considered. Only magnetic-core and -film memories and magnetic tapes and drums are considered in the brief treatment here presented, since these are by far the most important. In Sec. 22-2 problems concerning the selection ratio and the read-write cycle are discussed. Section $22-3$ considers thin-film memories. We present the principle of nondestructive and simultaneous read-out in connection with thin-film memories, for it is felt that these concepts can most easily be given in this context. However, the principles involved can also be applied with single- or multiaperture cores, as is brought out in the Exercises. Section 22-4 emphasizes the problems involved in the interpretation of results obtained from magnetic tape and drum heads, in various forms of digital representation on magnetic surfaces. Magnetic tapes and drums are properly considered input-output equipment, and hence further consideration of input-output problems, in Secs. 22-5 and $22-6$, follows naturally. Conversion of information from analog to digital representation and the reverse, considered in Sec. 22-5, is of central importance to many input-output devices. An introduction to the important sampling theorem is presented, and the principles of analog-to-digital conversion, and the reverse, are illustrated by examples. We refrain from detailed discussion of such circuits as voltage comparators, electronic switches, and ramp or saw-tooth wave generators, since these are not digital circuits and since adequate treatments of them can be found elsewhere. Finally in Sec. 22-6 we present several examples of the various types of input-output devices, to illustrate the variety of applicable techniques and available methods.

## 22-2. Magnetic-core Memories

Increasing the Selection Ratio. In Sec. 17-6 the elements of magnetic-core-memory coincident current selection were described (see Fig. 17-16 on page 567). In the simple system described in that section, to select a word two currents, each of $-I_{c} / 2$ (half the coercive-force current), were passed through the cores, one current through the $X$ wire, the other
through the $Y$ wire, corresponding, respectively, to the $X$ and $Y$ parts of the desired address. Only the cores of the proper address will then have the full current $-I_{c}$; of these only the cores recording units will flip to zero and be sensed by the $Z$ wire. Some cores, not of the proper address, will be "half-selected," i.e., will have a current of $-I_{c} / 2$ threaded through them. The ratio of the current in the selected core to the current in a half-selected core is called the selection ratio, in this case $2: 1$.

We shall discuss two methods for increasing the selection ratio to $3: 1$. In Fig. 22-1 $a$ we show just a single $x-y$ plane. Here currents of $-I_{c} / 2$ are passed through the $x$ and $y$ wires, as before. However, through


Fig. 22-1. Two methods for increasing the selection ratio to 3:1.
all other $x$ and $y$ wires a current of $+I_{c} / 6$ is passed. The total current through the selected cores will be the desired $-I_{c}$, but that through the nonselected cores will be either $-I_{c} / 3$ or $+I_{c} / 3$; thus the selection ratio is $3: 1$. The selection just described is for reading a word; for writing, the currents would be reversed. The second method for increasing the selection ratio involves the use of extra wires (see Fig. 22-1b) each of which threads all the cores in a single $x-y$ plane. A current of $-2 I_{c} / 3$ is passed through the $x$ and $y$ wires corresponding to the desired address; a current of $+I_{c} / 3$ is passed through the extra wire. The result is a current of $-I_{c}$ in the selected core, and either $-I_{c} / 3$ or $+I_{c} / 3$ in the other cores, giving the $3: 1$ selection ratio. Again, for writing, the currents are reversed.

Core Selection Matrix and Read-Write Cycle for Core Memories. The theory of decoding matrices was discussed in Sec. 17-2, and in Chap. 18 selection matrices for the drum of the Pedagac were designed, using the diode-gated Pedagac packages. We now consider the design of selection matrices for core memories using cores as the gating elements. The technique is based on the methods of Sec. 21-4. Consider, for example, a 16 -word core memory, with $\alpha^{*} 1, \alpha^{*} 2$ the $x$ part of an address and $\alpha^{*} 3$,
$\alpha^{*} 4$ the $y$ part. The $x$ selection matrices appear as in Fig. 22-2. One of the cores, the selecting core, will flip to the unit state, and hence only one of the sense wires will carry a current, as desired. Of course for large memories several levels of gating may be necessary, as described in the theory of decoding matrices in Sec. 17-2.

Observe that, in writing into a core memory, all the cores of the selected memory location must be initially in the zero state. Then only the cores corresponding to the unit bits of the word will be flipped. In reading out of a core memory the attempt is made to flip all the


Fig. 22-2. Core selection matrix.
cores of the selected memory location to the zero state. The unit cores of the word will then flip, and hence the unit bits will be sensed-but the memory location will be left all zeros. Therefore the word that has been read out must be stored and written back into this memory location. 1 In order to facilitate the initial clearing before writing and the final writeback after reading, a single read-write cycle is usually established, which is repeated for every memory address selection, either read or write. First the selection matrices are set, and the selected word is read out of the memory into a memory buffer register, clearing the memory location. Note that at this time the selecting cores are the only cores of the $x$ and $y$ selection matrices that are in the unit state. Now the $x$ and $y$ reset signals are initiated, and the selecting cores flip back to the zero state, reversing the current in their sensing leads. As we have just seen, this reversed current performs the selection for writing into the memory. If the instruction being performed is "Read," then the word in the buffer is written back into the selected memory location as it is also transferred to some other part of the computer. If the instruction being performed is "write," the buffer is first loaded with the new word, which is then written into the selected memory address.

Memory Applications of Multiaperture Devices. A disadvantage of the core memory systems described above is that the current through a single wire cannot be greater than the coercive force of the core for selection by coincident currents. This limitation in drive current places an upper
limit on the memory-system speed with which the memory cores can be flipped. However, from the discussion of Sec. 21-2 it is clear that, if the selection, read, and write currents could be made large, the switching time could be made very small. We shall now describe a non-coincidentcurrent memory system with this advantage, utilizing three-hole cores.

The three-hole ferrite device has a single wire through each hole (see Fig. 22-3a). The $Y$ wire (through left hole) distinguishes the bits of the


Fig. 22-3. Three-hole multi-aperture-device memory.
words; the $W$ wire (through middle hole) distinguishes the words of the memory; the $S$ wire (through right hole) senses the bits for read-out. Starting from the clear state (see Fig. 22-3a, upper left) produced by a current in the $W$ wire, the unit state (upper right) is effected by a reversed current through the $W$ wire and the zero state (lower left) by currents through both the $Y$ and $W$ wires. A typical memory configuration is shown in Fig. 22-3b. To write a word, the $W$ wire for the desired memory location is selected, and through it a drive current is applied, upward as shown in the figure. At the same time currents are applied only in those $Y$ wires corresponding to the zero bits of the word being read in. But consider the effect that a current in a $Y$ wire has on a nonselected bit element. If the bit is in the zero state, the $Y$ current has no effect; if the bit is in the unit state, the $Y$ current will change the unit state to a disturbed unit state (lower right of Fig. 22-3a). Thus unit bits may be in either the normal unit or the disturbed unit stage. To read a word
out of the memory, a large current is applied again to the $W$ wire, in a direction opposite to the write selection current. The core will be set to the clear state (upper left). In so switching, the flux direction round the rightmost hole is the same as that of the zero state but is reversed from that of the normal unit and disturbed unit states. Hence the sense wire $S$ will have a current induced corresponding to a unit, but not to a zero (see Fig. 22-3b).

## EXERCISES

(a) Describe a technique for producing a 4:1 selection ratio.
(b) Two-dimensional coincident-current selection methods have been discussed in the text. How would a three-dimensional coincident-current selection method work? (Hint: Break the address into three parts.) What selection ratios will be obtained?
(c) Design a core $x$-selection matrix for 4 bits in the $x$ part of the address.
(d) Using the decoding techniques described in Sec. 17-2, design a two-level 8-bit $x$-selection matrix using cores.
(e) How would selection matrices operate for the three-hole core memory described in the text? How does this differ from the selection techniques described earlier?

## 22-3. Magnetic-film Memories

Thin Films. Thin-film memories require no threading of wires through holes and therefore can more easily be constructed by printed circuit techniques. The storage elements are vacuum-deposited nickel-ironalloy films with square hysteresis loops, shaped into $3 / 16$-in.-diameter round spots about 2,000 A thick. The films are deposited in the presence of a magnetic field and as a consequence show a preferred direction of magnetization. The direction of magnetization can be represented by a magnetic dipole (like a compass needle) which has two stable states parallel to the preferred direction, the unit and zero states (see Fig. $22-4 a$ ). An appropriately applied magnetic field can cause the film dipole to rotate out of its unit or zero state; when the field is removed, the dipole will rotate back to the nearest stable state (that state requiring the least angle of rotation). Three (printed) wires are required, the $W$ wire characteristic of a word, a $Y$ wire characteristic of a bit of the word, and an $S$ wire that senses the read-out signal for a bit, oriented as shown in Fig. 22-4e with respect to the preferred direction of the film spot.
The films of a storage location are always reset to zero before a word is written into it. The directions of the $W$ and $Y$ wires are parallel at the film spot, making an angle of $30^{\circ}$ with the spot's preferred direction. When it is desired to write into a memory location, a current is applied to the corresponding $W$ wire. For the unit bits of the word a current in the same direction as that of the $W$ wires is applied to the $Y$ wire; for the zero bits of the word a current in the opposite direction is applied to the $Y$ wire. For the unit bits the combined applied fields of both $W$ and $Y$ wires rotate the magnetization to the $W$ direction (see Fig. 22-4b); when the applied field is removed, the magnetization rotates to the unit
preferred state since this is closest. For the zero bits the effects of the fields applied by the $W$ and $Y$ wires cancel, and the magnetization stays in the zero state. The field applied to the nonselected word spots by the current in the $Y$ wire is not of itself sufficient to rotate the magnetization


Word 1
Word 2
Word 3

(e) Film memory

Fig. 22-4. (a) Film spot with compass representation; dashed lines show preferred direction, with 0 and 1 states. (b) Writing a unit, showing rotation to $W$ and then to the unit state. (c) Reading, showing rotation to $R$ and then to zero state. (d) Sensed currents when reading (both returning to the zero state). (e) Assembly of a film memory showing planes of printed wires and spot plane.
over $90^{\circ}$ from the preferred direction, and hence those spots are not affected.

To read a word from the memory, a current is applied to the $W$ wire in the direction opposite to that for writing. The zero-state spots rotate from the zero direction to $R$ (see Fig. 22-4c) ; the unit-state spots rotate from the unit direction also to $R$, but the rotation occurs in the opposite
sense to that of the zero-state spots. The sense wire $S$, placed perpendicular to the $W$ wire to minimize stray pickup, gets a negative induced current from the former rotation and a positive induced current from the latter rotation; these currents correspond, respectively, to sensed zeros and units (see Fig. 22-4d).
However, both unit and zero spots will return to the zero state, and, as in the case of the memories described above, the word must be read back by means of the usual read-write cycle. Figure $22-4 e$ shows a memory of three 4 -bit words; the three wire planes are printed separately and placed over the spots as shown. Actually for greater sensing signals two spots per bit are used in a slightly different arrangement.

Nondestructive and Simultaneous Read-out from Thin-film Memories. In all memory systems considered so far, a read-write cycle and a memory buffer register were necessary, because the read-out destroyed the stored information. A nondestructive read-out memory has the advantage of eliminating the buffer register and the circuitry needed for a complete read-write cycle. In addition nondestructive read-out memory systems frequently enable reading from one word of the memory while simultaneously writing into another. This is because in such memories the mechanism of the write process is distinct from the mechanism of the read process.
As an illustration, consider the nondestructive read-out thin-film memory of Fig. 22-5. For each bit there are a pair of film spots, one for storage and one to facilitate read-out. The remanent state of the storage film spot is sensed by switching the read-out film spot in such a way as not to alter the magnetic state of the storage spot. The storage film spot is made of high-coercivity material and the read-out spot of low-coercivity material (see Fig. 22-5a); the two spots for a bit are placed close together (see Fig. 22-5b), with their preferred directions at right angles. The flux of the storage spot passes through the read-out spot as shown in that figure. To sense the state of the storage spot, a current is applied to a $W$ wire running parallel to the preferred direction of the storage film. Suppose the magnetization of the read-out spot is initially parallel to its preferred direction with the north pole as indicated in Fig. 22-5c. Then two magnetic fields will be applied to the read-out film: the field of the storage film (shown as transverse arrows) and the field of the current in $W$. The latter field will reverse the direction of magnetization of the read-out film, but the direction of rotation for reversal will depend on the direction of the field due to the storage film, as shown in Fig. 22-5c. Depending on its direction, this rotation will induce an initial positive or negative current in a sense wire. Since the coercivity of the storage spot is greater than that of the read-out spot, the direction of magnetization of the former spot will not be affected provided that the reading current is only sufficient to flip the latter. A reverse current of the same limited magnitude must be applied through the $W$ wire to reset the read-out spot so that its north pole is in the proper initial direction.


Fig. 22-5. Nondestructive read-out thin-film memory. If the magnetization of the storage spot points to the 0 , then a zero is stored; if it points to the 1 , a unit. The $N$ and $S$ stand for the poles of the magnetization of the read-out film in the reset or normal state.

Figure 22-5d represents a memory of three 4-bit words. To read, the $W$ wire for the desired word is selected and pulsed, the spots being sensed nondestructively as just described. To write into the memory, a current in the reversed (writing) direction is passed through the proper word wire, as at the same time currents corresponding to the desired zeros and units are passed through the $Y$ wires. If a storage spot is to flip, both its $W$ and $Y$ wires must have currents; thus storage cores in nonselected
words will not respond. Simultaneous read and write can occur (involving different words) provided that the coercivity of the read-out film is sufficiently less than that of the storage film. If word 3 were being read, for example, as word 1 is written, the currents in the sensing wires will not be great enough to influence the writing of word 1 . The problem is rather to prevent the writing operation from influencing the reading of word 3 . The writing current in word 1 holds its read-out spots in the reset state, so that none will flip to give a false read-out as the word 1 storage spots are flipped. The currents in the $Y$ wires might contribute, with the resetting current in the $W$ wire of word 3 , to flipping a word- 3 storage spot. This will not occur, however, if the reading and resetting current is much less than the required writing current; the difference between the currents depends on the difference in the coercivity of the spots of the pair.

## EXERCISES

(a) In practice the rotation of a single spot may not induce sufficient current in the sense wire. How can the arrangement of Fig. 22-4 be revised so that two spots per bit are sensed?
(b) The two-aperture devices described earlier (Sec. 21-4) can be used for nondestructive and simultaneous read-out forms of memories. Using the principles developed in this section, design such a memory system. (Hint: Use the coincidentcurrent method to select the large hole for writing into, and the small hole for reading out of, the memory.) Be careful when explaining why simultaneous read-out can occur.

## 22-4. Magnetic Tapes and Drums

Return-to-zero Writing Method. Both magnetic tapes and drums operate on the principle of writing onto and reading from magnetic material deposited on a moving surface. Figure $22-6 a$ shows a reading and writing head. For writing, a current pulse $I$ induces flux, some of which magnetizes the material on the moving tape or drum surface (see Fig. 22-6b). In the sensing of such a magnetized spot, as the spot moves past the head the lines of flux will pass through the read coil, inducing a small voltage difference. The writing current and induced reading voltage are small (a few milliamperes or millivolts, respectively). Figure 22-6c illustrates a current pulse and the intensity of the resulting spot of flux along the length of the tape; the shape of the induced voltage pulse across the read coil is shown, as is the final result of amplifying and limiting this voltage pulse. It is desirable that the head be designed to write with a small current, to produce a small spot on the tape, and to produce as large a reading voltage as possible. The gap in the head should be small to localize the spot and reduce magnetic-circuit reluctance and should maximize fringe effects so that the lines of flux pass into the tape. A lowreluctance path will increase the flux through the head on reading, and hence the head should have a short path and a large relative cross-sectional area as well as a small gap, and should be made of high-permeability material.

One of the first methods used to record binary information on a magnetic surface is illustrated in Fig. 22-7. The sequence of bits is shown in (a). For a unit there is a positive current pulse, for a zero a negative current pulse, but after each pulse there is a return to zero as shown in (b). If the spots are sufficiently spaced, at, say, $m$ bits/in. on the tape, then the magnetization or flux per unit length is as shown in (c). If the spots are placed closer together, they may overlap, particularly for repeated units or repeated zeros, as shown in (d). When the spots are well spaced, as in (c), the voltage induced in reading this flux is as shown


Fig. 22-6. (a) Magnetic reading and writing head; (b) flux spot in the magnetic material; (c) writing current flux, reading voltage, and processed reading voltage as a function of time $t$ or distance $s$ on the moving surface.
in (e). These pulses can be amplified and limited; then when the output is sampled at appropriate times, a voltage curve similar to (b) as desired will have been formed. For example, the sampling times may correspond to the pulses above the line in (f). Since each positive voltage swing is followed by a negative swing and each negative swing by a positive swing [see (e)], the output can be checked by sampling a second time for each bit, as shown in ( $f$ ) by the pulses below the line (to indicate inversion). If a pair of samples do not agree, an error is indicated.

When the bits are packed densely, repeated units and repeated zeros require further consideration. For such repetitions can cause the accumulation of flux in the magnetic head, as shown in Fig. 22-8g, and this accumulation tends to saturate the head. The resulting voltage waveform is as shown in ( $h$ ). Amplifying and limiting this voltage can cause erroneous results in the sampling. The wavy pulse lines in (i) represent positions at which errors can result, since as the head approaches saturation some of the positive and negative induced voltage swings are close to zero, as indicated by the three arrows in ( $h$ ). In order to interpret a .waveform such as ( $h$ ) correctly, we might form its derivative, counting
on the slopes to preserve the information. However, the derivative of a curve is very sensitive to noise; hence it is better to take a difference instead between the voltage waveform and itself delayed by one-half the distance between bit centers. The two waves are depicted in Fig. $22-9 j$, their difference in $(k)$. This difference, while related to the derivative, is not so sensitive to errors due to noise (why?). When the waveform of ( $k$ ) is amplified and limited, the pulse train of ( $l$ ) results. These pulses are to be sampled within the first half period following the bit center (why?), as shown in ( $m$ ). When the sampled pulses are inverted, the desired result is obtained, as shown in ( $n$ ).

Non-return-to-zero Methods. Some of the problems that occur in the return-to-zero method arise from the fact that, when neighboring spots are magnetized in the same direction, their flux lines tend to link and thus between-bit sensing is weakened. In the first non-return-to-zero method that we shall discuss there is at least one reversal of magnetization direction per bit. Consider, for example, Fig. 22-10. Here a unit [of the word in ( $a$ )] is represented by a pulse crossing the zero axis from below, a zero by a pulse crossing from above [see arrows in (b)]. Between bit positions there may be an appropriate reversal, to get into position. The pulses of (b) represent the write current pulses. The voltage waveform of $(c)$ is the result of reading a tape in this mode when close bit packing is used. The differencing method can then be applied [see the dashed lines in (c)], and the resulting difference will appear as in (d). After amplifying and limiting, the waveform of (e) is obtained, which when sampled in the first half of the period results in the desired pulses, shown in (f). It has been reported that with this method pulses packed at 880 bits/in. can be read. Normal packing densities (for all methods) range from 200 to $400 \mathrm{bits} / \mathrm{in}$. for tapes.

A second non-return-to-zero method is illustrated in Fig. 22-11. In this method the flux on the tape is made to change direction only when a unit appears. Thus the write current appears as in (b) for the bit pattern of (a). The voltage waveform on reading will have a spike whenever a unit occurs [see (c)]. These spikes may be rectified to preserve symmetry [see dashed lines in (c)]. The amplified and limited result will then have a pulse for a unit, no pulse for a zero. The output from the head should be compared with a constant voltage of about half the normal peak, and any pulses below that level should be ignored as noise.

Clocking. In the previous paragraphs we have tacitly assumed some kind of sampling pulse generator synchronized with the reading of the tape so that the processed information is sampled at appropriate times. One technique for accomplishing this is to have on the tape an extra channel containing clocking pulses only. For example, in Fig. 22-12a we illustrate a four-channel tape with the fourth channel used for clock pulses. If this were the second non-return-to-zero scheme, the writing current pulses for each channel would appear as in (b); the voltage spikes that result from reading are shown in (c). Then to read channel 1, 2, or 3, the output of that channel is gated with the output of channel 4 as
(a)
(b)

(c)
(d)

(e)

(f) - Sampling times

Fig. 22-7. Return-to-zero recording.
(g)


Fig. 22-8. Return-to-zero: problem of repeated bits.
(j)

(l)


Fig. 22-9. Return-to-zero: method of differencing.
(a)
(b)

Bit sequence
b)
 Write current pulses
(c)

(d)
 Difference waveform
(e)


Fig. 22-10. Nonreturn to zero with differencing.

(c)


Fig. 22-11. Nonreturi to zero: change-over method.


Fig. 22-12. Clocking methods.
shown in (d). A slightly different scheme uses the extra channel to record an odd parity bit for pulses being read at the same time; this is illustrated in (e). As the 4 bits on each line are read out $[(f)$ and $(g)]$ by the four heads (one for each channel), the odd parity bit can be checked. The four outputs ( $g$ ) are combined in an or gate, which has a unit output $S$ for every line of pulses, because of the odd parity. Then $S$ can be gated with channels 1, 2, and 3 as a clocking pulse [as in ( $h$ )].

The first non-return-to-zero method lends itself to a self-clocking scheme. It is easily observed that there are either one or two axis crossovers per bit of the processed information (see Fig. 22-10d). Where there are two crossovers, only one of them contains the desired significant information; the problem is to determine which this is. Starting with a significant crossover, an "information gate" can be formed that is one-half period in length and starts three-fourths period delayed from the significant crossover. This gate will then "bracket" another significant crossover. The sign of the differential crossover spike, indicating which way the crossover was made, will indicate whether the bit is a unit or zero. This scheme permits some variability in the periods, since they can vary by one-fourth period and still allow the information to be sensed. The clock starts from the new crossover each time and so is adjusted continually. In order to start the process, an information sample of alternating zeros and units is used, since these contain only significant crossovers.

Drums and Tapes. We have previously described various arrangements of words on the drum in channels and sectors, as well as methods for synchronizing the drum with the computer and for memory selection (see Secs. 17-6 and 17-8). The rotating speeds vary from 440 to $12,500 \mathrm{rpm}$, with 50 to $100 \mathrm{bits} / \mathrm{in}$. along a channel and 15 to 30 channels/in. The reason for the low bit density is that to eliminate frictional wear the spacing between the head gap and the drum surface is as great as 0.001 to 0.002 in. This spacing results in considerable loss of spot resolution. In addition any eccentricity of the drum will vary the drum-to-head distance, introducing further aberrations. The drum surface is coated with a magnetic material, such as $\mathrm{Fe}_{2} \mathrm{O}_{3}$, or plated with the desired magnetic metal. There are a wide variety of drum diameters and lengths, diameters ranging from 2 in . to 4 ft , and lengths from $1 / 4 \mathrm{in}$. to 3 ft .

Disks coated with magnetic material can also be used for storage. Figure 22-13 shows one such mechanism, whose read-write head is moved mechanically along the rapidly spinning disks to the proper disk level and is then inserted to the proper radius. By using an air cushion the separation between the head and disk can be made very small and kept relatively constant even if the disk were somewhat warped. Both sides of the disk are used, making the total available surface area very large. Each disk contains $7 \times 10^{5}$ bits; for a system utilizing 50 disks, the average access time is about 0.6 sec .

Magnetic tapes are coated strips of plastic (usually Mylar) or other
nonmagnetic material, varying in width from $1 / 2$ in. to several inches, the wider tapes containing more channels. Usually seven channels are used; each 7-bit rank represents an al-


Fig. 22-13. Disk memory, showing magnetic head positioned between disks. (Photograph courtesy International Business Machines Corp.)
quickly brings the tape to full speed. may be stored loosely in bins, as shown in Fig. 22-14a. Frequently reels of tape are used, as shown in Fig. 22-14b. Here, in order that the tape-driving wheels need not accelerate the reels, the proper

(a) phabetic or numeric character, but the seventh bit is a parity check or clocking channel bit. As we have discussed above, the ranks are organized in blocks; there is space containing no information left between blocks (equivalent to about three ranks) as an allowance for starting and stopping the tape between blocks. The mechanism for moving the tape must be capable of producing high acceleration on starting and stopping, for the tape speed while reading or writing must be relatively constant. One method is to have the tape pass over rapidly spinning wheels (see Fig. 22-14a). When the tape is to be moved, it is squeezed between one of these spinning wheels and an idling pressure wheel that is driven against it; the increased friction between the tape and the spinning wheel To reduce inertia, the tape itself

(b)

Fig. 22-14. Magnetic-tape movement mechanisms. (Photograph courtesy Potter Instrument Co., Inc.)
amount of slack tape is maintained by servomechanisms that drive the reels. Complete loops of tape, or tape belts, have the advantage of not needing to be rewound to obtain information at the beginning, if the tape is located at the end. Short tape belts can also be used for temporary storage, as illustrated by the small retrieval computer of Fig. 8-9 on page 269.

## EXERCISES

(a) When the spots are well spaced, as in Fig. 22-7c, draw the amplified and limited waveform and the result of sampling.
(b) Draw the waveform of the derivative of Fig. $22-8 h$ and then the result of amplifying and limiting this derivative.
(c) Draw a possible flux pattern for the write current shown in Fig. 22-10b, together with the read-head voltage waveform and the differential spikes.

## 22-5. Conversion from Analog to Digital and from Digital to Analog

Analog and Digital Conversion. Mountains of raw data continue to pile up at such a rate that research laboratories and test facilities are burdened with unreduced information. The recordings produced by strip chart pens, galvanometer deflections from oscillographs, frequencymodulated carriers on magnetic tape, oscilloscope waveform photographs, as well as outputs of thermocouples, strain gauges, manometers, theodolites, etc., can have no meaning until processed and analyzed. Digital computers have the capability of processing such data at rates comparable to those with which it was produced. However, the data must first be converted into a form usable by the digital computer. Rapid automatic analog-to-digital converters can fulfill this need. In addition, when a computer is used to control experimental procedures or manufacturing processes, the digital control signals must be interpreted in terms of mechanical displacements or electrical responses; hence the need also arises for automatic and rapid digital-to-analog conversion.

Digital information is represented in the form of numbers; analog information is represented in forms other than numbers, such as a mechanically generated shaft-rotation angle or an electronically generated voltage value. In general the converters can be placed in two categories, depending on whether the analog information is in the form of mechanical or electrical measurements. Of course there can be conversion between mechanical and electrical analog information prior to (or after) the digital conversion. Converting an analog measurement into a number containing more significant digits (or bits) than required by the relative error (see Sec. 6-11) of the analog information would not be desirable. Conversely converting a digital number into an analog measurement with a system capable of smaller relative analog error than would be required by the number of significant digits in the original number is unnecessary. Thus the analog-to-digital or digital-to-analog equipment should be well matched with regard to relative error or significance. A large variety of analog-to-digital and digital-to-analog
converters are available, using many different techniques adapted to different special characteristics of the analog information. In this section we shall present by example some of the basic concepts involved.

Effects of Discrete Sampling. Usually analog information is presented to the converter in what appears as a continuously varying function (often of time), such as a varying angular velocity or a voltage waveform. The result of a single digital conversion, a number, can correspond to only one point of the analog function; the digital conversions must be made for a sequence of points-discrete samples-of the analog function.


Time $\longrightarrow$
Fig. 22-15. Sampling at frequency $4 f$ to obtain at least the rms value. The problem always arises of how close together the samples of analog information should be chosen, i.e., at what increments of the independent variable (e.g., time) the digital conversion of the analog representation of the dependent variable should be made. Consider, for example, a localized burst of oscillations of frequency $f$ of the dependent variable (see Fig. 22-15). Clearly, to ensure that at least the rms values of the variation of the oscillations will be "seen" in the sequence of digitalized values, the sampling rate must be no less than $4 f$. Figure $22-15$ shows two cases of a $4 f$ sampling rate, one where the maximum and the other where the rms variation value can be seen in the sampled sequence. (Note that the value seen will be at least the rms value.)

Consider next the problem of determining the necessary frequency of sampling that will enable the original signal to be recovered from the samples. By recovering a signal is meant the determination of all the coefficients of the Fourier series required for the exact reconstruction of that signal. We shall show that it is necessary to take more than two points per cycle of the highest significant frequency component in a signal in order to recover that signal. Consider a signal that is sampled at frequency $f$, that is, at times . . . , $-2 / f,-1 / f, 0,1 / f, 2 / f, \ldots$, . . . , $k / f$, . . for integral $k$. The frequency components of the signal greater than $f / 2$ cannot be distinguished from frequencies in the range 0 to $f / 2$. To see this (noting that $f / 2 \mathrm{cps}$ is the same as $\pi f$ radians $/ \mathrm{sec}$ ), we need simply observe that for $0 \leq \epsilon \leq f / 2$
and

$$
\begin{align*}
& \cos [(n \pi f+\epsilon) t+\varphi]=\cos [(\pi f-\epsilon) t-\varphi] \\
& \cos [(n \pi f-\epsilon) t+\varphi]=\cos [(\pi f-\epsilon) t+\varphi] \tag{22-1}
\end{align*}
$$

for odd integers $n>0$, whenever $t=k / f$, that is, whenever $t$ is a sampling time. Equations (22-1) mean that at times $k / f$ each frequency greater than $\pi f$ radians $/ \mathrm{sec}$, that is, $f / 2 \mathrm{cps}$, is indistinguishable from some
frequency in the range 0 to $f / 2$. In other words, we are dividing the frequency scale into intervals of length $f / 2$ and observing that any frequency will fall in an interval $n f / 2+\epsilon$ or $n f / 2-\epsilon$ (for $0 \leq \epsilon \leq f / 2$ and odd $n>0$ ) and hence, at $t=k / f$, will correspond to some frequency

(a) Correspondence of frequencies from 0 to $f / 2$ with frequencies greater than $f / 2$

(b) The correspondence visualized as folding

Fig. 22-16. The frequency scale folded to illustrate the sampling theorem.


Fig. 22-17. Distortion of a frequency below half the sampling rate $f$ by a frequency above half the sampling rate.
$\pi f-\epsilon$ in the interval 0 to $f / 2$. This correspondence is illustrated in Fig. 22-16 $a$, where the lines indicate the correspondences on the frequency scale. Figure $22-16 b$ shows how the correspondence can be visualized as a "folding" of the frequency scale, all frequencies on the same horizontal line being indistinguishable when $t=k / f$. Figure 22-17 illus-
trates the effect of this correspondence. The $\cos (\pi f+\epsilon) t$ wave appears identical to the $\cos (\pi f-\epsilon) t$ wave when $t=k / f$. The result is an effective doubling of the amplitude of the $\cos (\pi f-\epsilon) t$ wave, in so far as the information contained in the samples is concerned (see the vertical lines in the figure), since, by Eqs. (22-1), $\cos [(\pi f+\epsilon) k / f]=\cos [(\pi f-\epsilon) k / f]$.

Now suppose that a signal has negligible frequencies higher than $f^{*}$. Then, in order to sample the signal unambiguously, it must be sampled at a frequency $f$ such that $f / 2 \geq f^{*}$, whence the sampling frequency

$$
\begin{equation*}
f \geq 2 f^{*} \tag{22-2}
\end{equation*}
$$

This result is called the sampling theorem. It is important to point out a pitfall in the use of the sampling theorem. It does not mean that it is necessary only to take more than two points per cycle of the highest frequency which is of interest in a particular application. In other words, it is not true that high frequencies cannot be passed by lowfrequency sampling, since the high frequencies do affect the sample by falsely appearing as frequencies in the 0 to $f / 2$ range. Another way of putting this is: "Sampling is folding; sampling is not filtering." If high frequencies are present in a function for which a low sampling rate is to be used, i.e., for which only the low frequencies are of interest, then the high frequencies must first be filtered out before the analog-to-digital conversion.

Mechanical Conversion. Consider first the digital conversion of the angular position of an analog shaft. This may be accomplished by means of the drum of Fig. 22-18. In this simplified illustration 16 different positions can be recognized as the four brushes sense the conducting pattern (shaded areas) on the drum surface. Notice that a cyclic code is used so that in the transition from one angular position to the next no serious error can result, since only one bit position at a time changes between successive angular positions.

The digital-to-analog conversion for an angular shaft position could make use of the analog-to-digital converter. A digital comparator determines when the angular position of the rotating shaft has the same magnitude as the digital input; at the instant of successful comparison the motor is stopped (see Fig. 22-19).

Mechanical analog-to-digital conversion and the reverse are capable of high accuracy, to over 12 significant bits. For example, the instantaneous angular position of the Pedagac drum can be obtained to within the position of a single bit, and there are $2^{7} \times 23=2,944$, or more than $2^{11}$, bits around a channel. This incidentally can be adapted as another method for analog-to-digital conversion.

Electronic Digital-to-analog Conversion. Let us consider two illustrations of digital-to-analog conversion. Our digital input can be represented as $N=a_{-1} 2^{-1}+a_{-2} 2^{-2}+a_{-3} 2^{-3}+\cdots+a_{-m} 2^{-m}$, where of course $a_{-k}$ can have only the values 0 or 1 (see Sec. 3-2). Figure 22-20a illustrates a converter using constant-current sources, with the digital input taking the form of electronic switches opened or closed as shown,


Fig. 22-18. Direct-drive angular-shaft-position analog-to-digital converter.


Fig. 22-19. Angular-shaft-position digital-to-analog converter.
depending on the value of $a_{-k}$. In the figure we have illustrated only 5 bits, though a circuit to convert any number of bits, within the limits of accuracy, may be constructed by using an extended ladder. Note that the value of the end resistances is half that of the interior resistances. The output here is the voltage $V_{o}$ across the leftmost resistor. The precise analysis of the circuit will be left to the reader. But we shall note here that the three right-hand resistors can be combined into a single resistor of value $R$ connected between point $D$ and ground, so that, looking to the right from point $C$ (or $B$, or $A$ ), we see the same resistance, $2 R$, as from $D$. Similarly the resistance looking left from branches $B, C, D$, or $E$ is $2 R$, so that the current from $B, C$, or $D$ divides into three equal parts, while the currents from branches $A$ and $E$ divide with $1 / 3 I$ horizontal and $2 / 3 I$ vertical. To reach the output resistor the current from branch $C$ passes the node at $B$, where it is halved; also the current from branch $D$ passes the nodes at $C$ and $B$ and is thus halved twice; and so forth. Therefore the current through the output resistor will be $2 / 3 I$, if any, from branch $A$, plus $1 / 3 I$, if any, from branch $B$, plus $1 / 6 I$, if any, from branch $C$, plus • . ; and the output will be

$$
V_{o}=4 / 3 I R\left(a_{-1} 2^{-1}+a_{-2} 2^{-2}+a_{-3} 2^{-3}+a_{-4} 2^{-4}+a_{-5} 2^{-5}\right)
$$

(since $4 / 3 \times 2^{-1}=2 / 3$, etc.)
A digital-to-analog converter that employs a single constant voltage source is illustrated in Fig. 22-20b. Note that when $a_{-1}=1$ the $a_{-1}$ switch presents $V-V_{o}$ across the $2^{-1} R$ resistance in arm $A$; but if $a_{-1}=0$, the $a_{-1}$ switch leads to ground, presenting $V_{o}$ across the $2^{-1} R$ resistor, with the current in the opposite direction. The current in $\operatorname{arm} A$ can therefore be written as $I_{A}=\left(a_{-1} V-V_{o}\right) / 2^{-1} R$, where $a_{-1}$ is either a unit or a zero. This general form is true for the currents $I_{B}, I_{C}$, and $I_{D}$ in arms $B, C$, and $D$, respectively. But, with no load on $V_{o}, I_{A}+I_{B}+I_{C}+I_{D}=0$; hence

$$
\frac{a_{-1} V-V_{o}}{2^{-1} R}+\frac{a_{-2} V-V_{o}}{2^{-2} R}+\frac{a_{-3} V-V_{o}}{2^{-3} R}+\frac{a_{-4} V-V_{o}}{2^{-4} R}=0
$$

Solving for $V_{o}$,

$$
\begin{aligned}
V_{o} & =\frac{V\left(a_{-1} 2^{-1}+a_{-2} 2^{-2}+a_{-3} 2^{-3}+a_{-4} 2^{-4}\right)}{2^{-1}+2^{-2}+2^{-3}+2^{-4}} \\
& =\frac{V}{1-2^{-4}}\left(a_{-1} 2^{-1}+a_{-2} 2^{-2}+a_{-3} 2^{-3}+a_{-4} 2^{-4}\right)
\end{aligned}
$$

as desired.
Electronic Analog-to-digital Conversion. Three methods of analog-to-digital conversion will be described briefly. Many of the circuits involved, such as voltage comparators, voltage ramp generators, electronic switches, etc., are not primarily of a digital nature, and since their detailed design is well covered in other texts, we shall not consider it here. However, it is important to mention that many of these func-
tions can be performed by means of operational amplifiers, used in conjunction with standard analog-computer techniques.

Our first conversion method, the feedback method, makes use of a digital-to-analog converter, which might be of the types described above. For illustration, let us assume that the range of input voltage is 0 to $2^{4}-1$ volts. The decision unit first generates the binary number $2^{3}$,


Fig. 22-20. Two forms of digital-to-analog converter, using (a) constant-current sources and (b) a constant-voltage source.
or 1000, by making $a_{3}=1$; this is converted to an analog voltage $V_{d}$ and compared with the input voltage $V_{i}$. If $V_{d} \geq V_{i}$, then $a_{3}$ is left a unit; otherwise $a_{3}$ is returned to zero. Next $a_{2}$ is made a unit, and the analog representation of this number, namely, $V_{d}^{\prime}$, is generated and compared with the input voltage. If $V_{d}^{\prime} \geq V_{i}$, then $a_{2}$ is left a unit; otherwise $a_{2}$ is returned to zero. The process continues until all the bits of the converted number have been determined (see Fig. 22-21a).

The second, doubling method does not require digital-to-analog conversion. The bits of the digital result are sequentially generated, again in order from most significant to least significant bits. A standard voltage $V_{h}$, of one-half the full voltage range, is required. This is com-
pared with the input voltage in the voltage comparator. If $V_{i} \geq V_{h}$, the most significant bit is a unit; if $V_{i}<V_{h}$, it is a zero. If it is a unit, then $V_{i}-V_{h}$ is formed in the voltage subtractor and sent to the voltage doubler. If it is a zero, then $V_{i}$ is sent directly to the voltage doubler.


Fig. 22-21. Three types of electronic analog-to-digital converters.
Here either $2\left(V_{i}-V_{h}\right)$ or $2 V_{i}$ is formed and sent back as an input to the voltage comparator to be compared once more with $V_{h}$. The result of this comparison determines the next most significant bit, and the process continues until all the bits of the number are formed (see Fig. 22-21b). The two methods just described take one unit time interval for each bit of the number generated.

The third, or ramp, method is essentially a counting method, but it does not require extensive control circuitry. A linearly increasing voltage generator is initiated and its output sent to a zero comparator. When the voltage reaches the zero level, the counter is activated and begins to count clock pulses. Meanwhile the ramp, or increasing, voltage is being compared with the input voltage. When the ramp voltage equals the input voltage, the counter is stopped; the final digital count so obtained is proportional to the input voltage. In this method the time required depends on the magnitude of the analog voltage (see Fig. 22-21c).

## EXERCISES

(a) Describe both of the electronic digital-to-analog methods for $n$ bits (i.e., develop the appropriate formulas for a general integer $n$ ).
(b) Logically design the decision unit for the analog-to-digital converter of Fig. 22-21a.

## 22-6. Input-Output Methods

Electronic Digital Transducers. Almost all information put into a computer is generated in other than electronic binary form. Such input information may be generated by a computer programmer in the form of handwritten numbers on a coding sheet, by a strain gauge in the form of a voltage waveform, by missiles in the form of a radar signal, by bank checks in the form of printed serial numbers, by an experimental process in the form of the sequential frames of motion-picture film, and so forth. Similarly output information generated by the computer in electronic binary form usually must be converted into a more easily assimilated form: for example, the conversion of generated functions into graphs or tables, of military data into map or pictorial displays, of business information into bills and invoices, of processed statistical data into printed results, and so forth. A transducer may be considered a device to convert information from one form to another; if one of these is an electronic binary or digital form, the device is called an electronic digital transducer. The study of such computer input-output transducers is in itself a large field, which cannot be adequately covered in this short section. The methods and techniques involved are not, for the most part, closely related to digital circuits. However, brief descriptions of some specific examples will give the reader an understanding of many of the general problems that occur. The use of conventional electrictypewriter, punched-paper-tape, punched-card, and magnetic-tape inputs and outputs for computers has already been mentioned. We shall therefore in this section consider other forms of input-output devices, stressing the digital aspects of these mechanisms.

Let us first note that input digital transducers must perform three functions: The input information must first be put into digital form by an analog-to-digital converter or by some switching mechanism such as brushes sensing holes in cards, or intermittent light sensed by a photo-
tube. Next the digital information must be converted into the proper electrical form, using conventional electronic techniques. Finally the electronic bits must be transformed into a word format and appropriately synchronized with the clock of the computer. Output digital transducers must perform the reverse process. Some aspects of these problems have already been considered when the push buttons and input-output buffer of the Pedagac were described (Sec. 18-8).

Direct Switched Input. Other than push buttons, the so-called joy stick is the simplest mechanism for computer input. It consists of a


Fig. 22-22. Joy stick and display system.
stick that can be moved in two dimensions; the displacement of the stick is mechanically digitalized and recorded directly in a special word of the computer's memory, analogously to the signal sensing word of Sec. 8-3. One typical application of a joy stick is as an aid in tracking aircraft, inserting into the computer the $X, Y$ coordinates of a radarsignal pip on a cathode-ray tube. A code is written so that the displacement of the joy stick directs, through the computer, the position of a spot on the cathode-ray tube. Then by means of the joy stick the operator maneuvers the spot until it appears directly over the radar-signal pip. Then a button is pushed, and the computer records the position of the joy stick, which now gives the position of the radar-signal pip (see Fig. 22-22). A great many variations of this technique exist. For example, the position of the spot may be directly proportional to the displacement of the stick; a foot pedal might be added so that when it is pushed the spot will acquire a velocity proportional in magnitude and direction to the displacement of the stick.

Manual Write-in. Another simple input to a computer is a writing sensor plate, whose purpose is to enable numbers to be written directly into the computer. The scheme is based on a system of writing numbers around a pair of dots previously printed on a paper. The paper is
placed on a board that senses whether the pencil crosses the lines $a, b, c$, $d, e, f$, and $g$ as a digit is written in each position (see Fig. 22-23). Each digit crosses the lines or not in a different pattern, as shown in the array of the figure: a unit means that the pencil crosses the corresponding line when writing that number, and a zero that it does not, as recorded by the sensing plate. After the number has been completely written, the pencil is touched to the square in the lower right-hand corner, and the 7 bits of each number are recorded by the computer. The computer then interprets this code appropriately. A similar innovation can be made for the entire alphabet, printed or script. An application of such a scheme is to enable many long-distance telephone operators to record telephone numbers into an automatic bill-forming computer.

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $a$ | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |
| $b$ | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 |
| $c$ | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $d$ | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |
| $e$ | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 |
| $f$ | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| $g$ | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |



Sensing elements


Sensor plate for four digits
'Binary interpretation


Formation of the digits
Fig. 22-23. Writing sensor plate and binary interpretation of digits.
Character-reading Machines. $\dagger$ There are many methods for automatically reading printed matter into a computer. We have chosen to describe a method that utilizes digital circuitry extensively and is capable of reading 10,000 characters/sec. As shown in Fig. 22-24, a lens focuses a vertical-strip area of the character onto sensing phototubes. The phototubes divide the strip image into 11 squares, considering each as black (a unit) or white (a zero). These 11 bits are then recorded in 11 rows of a shift register. The character is sensed in this way five times as the paper on which it is printed moves past the lens. Each time, each of the 11 shift-register rows is shifted to accommodate the new information, which enters only on the right. When the fifth strip is sensed, the full character has been recorded as shown, as zeros or units in a $5 \times 11$ matrix. The machine is able to separate characters as they come past because the shifting is initialed only when the first black area is sensed; then the machine shifts only five times and after a short delay waits for the next black area. To avoid errors due to varying vertical displacement of the characters on the paper, after the 11 shift-register

[^12]rows have been loaded the columns become shift registers, and the recorded information is shifted down until a unit reaches the bottom row. The value ( 0 or 1 ) of each bit in the registers can now be sensed by two wires from each of the bit locations, the direct and inverted outputs. Seven wires (for example) are chosen from critical areas for each character, so that if that character is recorded the voltages of the seven


Fig. 22-24. Parallel-scan character-reading machine.
wires will add up to seven times the voltage on each wire. In order to determine which character is recorded in the registers, we need merely look for the one corresponding to the maximum voltage. This maximum type of decision is used to avoid errors due to broken printed characters, dirt spots, etc.
Another technique has the characters printed in magnetic ink. Again a vertical strip is sensed, this time by a magnetic recording head; an induced voltage waveform is generated, characteristic of the figure passing by (see Fig. 22-25a). The characters are so designed that the waveforms can easily be distinguished. This method has been standardized for reading serial numbers on bank checks (see Fig. 22-25b). For sorting mail automatically still another scheme has been proposed. On
the lower right-hand corner of each letter is sprayed a strip of magnetic material, which acts like magnetic tape. An operator reads the hand- or typewritten address and with a keyboard puts a coded address onto the


Fra. 22-25. Magnetic printing and character recognition. (a) Induced voltage waveform when magnetic head covers area shown as the number moves past; (b) checkreading machine showing the rotating drum that holds the check and the magnetic head that reads the stylized numbers. (Photograph courtesy International Business Machines Corp.)


Fig. 22-26. A letter that was sent across the country, showing the magnetic-ink strip in the lower right-hand corner. Even though "Not Here" was written over the strip, the code was not disturbed. (Photograph courtesy Rabinow Engineering Co., Inc.)
strip as the letter passes by the magnetic writing head. This magnetic address can be read for automatic sorting at various postal distribution points. Writing or stamping over the strip does not affect the code (see Fig. 22-26).

(a)

(b)

(c)

Fig. 22-27. (a) Mechanism of picture reader; (b) finding the boundary of the letter $L$; (c) the result of repeating the process; note what happened to a spot of dirt in the lower left-hand corner.

Picture-reading Machine. An input device of particular interest is a picture reader. Here a photomultiplier tube scans the picture as if it were marked off in squares like graph paper. If a particular square is darker than some relative index, then this square is recorded in the computer as a unit, otherwise as a zero (see Fig. 22-27a); in this way the picture is recorded in the memory. The contents of the memory can be
displayed on a cathode-ray tube so that a unit bit presents a bright spot and a zero a dark spot. This display indicates essentially how the zeros and units actually appear in the memory. Such a picture-reading machine has great potentialities. Maps may be rapidly recorded in a computer's memory for weather investigation, real-estate studies, or the simulation of military situations. Drawings of electronic circuits, chemical structures, and mechanical configurations can be recorded in the computer's memory for patent searching or other information retrieval processing. A pair of stereographic aerial photographs can be recorded in the computer's memory and the computer programmed to produce


Fig. 22-28. Picture-reading machine using negative.
a corresponding contour map, and so forth. As an example of picture processing, Fig. $22-27 b$ shows a letter $L$ processed so that only the boundary appears black. Processing this figure in the same way over and over again, we obtain the shape shown in Fig. 22-27c.

A second type of picture-reading machine places a negative or a positive transparency between a cathode-ray tube and a phototube. The computer is programmed to direct the electron beam scanning the picture and simultaneously to record from the phototube a unit or a zero (see Fig. 22-28).

Large Fixed Memory. $\dagger$ There are many applications of computers that require a fixed memory, such as a dictionary for a language-translating machine or an address-zone number correspondence for a mailsorting machine. Of the many mechanisms available we shall describe one that depends on the transmission of light through aligned holes in plates. Consider, for example, a memory with a 3 -bit address, with each of the eight addresses containing 4 bits (see Fig. 22-29). The memory consists of a cover plate and of three other plates each of which can be moved laterally into either of two possible positions, corresponding to a unit and a zero. Behind the plates four phototubes each sense one-fourth the area of the plates representing one of the 4 bits. An address is represented by the appropriate displacement of the three mov-
$\dagger$ Based on private communication with J. Rabinow.
able plates. Each of the four areas represents one of the four bit positions of a word. The presence of a unit (or zero) in a bit position is sensed if light passes through aligned holes (or not) in the appropriate area of all three of the plates. To insert a word initially, the plates are shifted according to the desired address, and holes are made through all three plates in only those areas representing unit bit positions. In practice holes are prepunched in all the plates and then filled by a layer of paint. Then, to insert a unit, a needle is passed through the holes,


Fig. 22-29. Plate memory.
easily punching out the paint layer. Each of the bit areas of the cover plate has as many holes in it as there are addresses. These holes serve as guides for inserting units into the corresponding' addresses. The figure shows the three plates in position for address 010; as shown, the contents of this address is 1010 . A memory of this type has been built for 3,000 addresses, each of 12 bits. Frequently it is desired to use more movable plates than necessary, to give the address registration more flexibility.

Another kind of fixed memory can be made with the cathode-ray picture reader described above. Here information can be read onto unexposed film by means of the beam spot; the processed negative can then be sensed by the same setup. An address might be a row number, and the bits in a row be the bits of the word, read out in a single scan.

High-speed Printers. Mechanical high-speed printers (see Fig. 22-30) can print 600 to 1,000 lines per minute, at 120 characters per line. A rotating drum contains 120 channels of metallic type-face forms, each channel having the complete alphabet and the digits. The paper lies between the type drum and a row of electronically controlled hammers, one for each channel. The entire line to be printed is recorded in a buffer storage unit. In its simplest form the binary code for each type face is the angle of rotation at which this type face will be opposite the hammer. The angle of the drum, converted to digital form, is compared with the character code for each channel. When a successful comparison is made, the hammer bangs the paper against this type face, printing the character. In a single revolution of the drum the proper character from each channel is printed-i.e., one line is printed per revolution of the drum.

An even higher-speed printer is based on the so-called Charactron tube. By this method over 4,500 lines of 120 characters can be printed per minute. At this rate a 300 -page book can be printed in 3 min . The Charactron tube displays alphabetic and numerical symbols by shaping the electron beam. The beam is shaped by passing it through a stencil plate with holes in the shape of letters (see Fig. 22-31a). The


Fig. 22-30. Mechanical high-speed printer showing type-face drum. (Photograph courtesy Potter Instrument Co., Inc.)
characters are formed by directing the beam through the appropriate hole. Masks with 64 characters have been made. This technique is coupled with that of the xerography process as follows (see Fig. 22-31b): A selenium-coated rotating drum is charged and exposed to the image of the characters formed by the Charactron tube. Special ink powder can then be transferred from the exposed part of the drum to paper. There are seven stages in this transfer process: the selenium drum is charged; the Charactron image is projected on the surface; the special ink powder is put on; the blank paper is charged; the image is transferred to the paper; the image is heat-fixed on the paper; and finally the drum is cleaned for the repeat process.

Picture Displays. Cathode-ray tubes can be used to display the plots of graphs by sending the $x$ and $y$ coordinates of each point into a digital-
to-analog converter to control the voltages for the $x$ and $y$ plates of the tube. In a similar fashion a television tube can be connected to a magnetic drum, so that as the drum rotates each line is displayed by the tube. In this setup the picture display is repeated each time the drum makes a revolution. To alter the picture, the programmer merely changes the pattern of bits, zeros and units, on the drum. In this way


Fig. 22-31. The Charactron tube coupled with the xerography process for high-speed printing.
the computer can display a moving picture of the successive results of computation. Simulations carried out by the computer, such as war games, traffic queueing problems, etc., can be directly displayed: Another scheme is to use an electroluminescent surface, which emits light when a voltage is applied across it. Wires buried in the surface can be controlled by the computer to generate voltages, and hence light, as desired for picture displays.

## EXERCISES

(a) Write a program for the Pedagac that will enable a joy stick and foot pedal to be used as described in this section.
(b) Suppose in the manual write-in system that the 1 is sometimes written to the left of the two dots, that the top of the 2 may curl round too far, that the middle of the 3 does not always cross the line connecting the two dots (line $d$ ), and that the tails of the 7 and the 9 are occasionally placed on the wrong side of the lower dot. How can the system handle such variations?
(c) For the manual write-in system, using four dots and 12 lines, demonstrate a way of writing the letters of the alphabet so that they may be distinguished, as well as the digits. Develop the binary coding table.
(d) Logically design the two-way shift register required for the parallel-scan character-reading machine, using dynamic flip-flops.
(e) How would the $G-H$ connections be made between flip-flops of the type described in Sec. 20-6 for the two-way shifting register of the parallel-scan reading machine?
( $f$ ) Write a code for the Pedagac that will develop the border, or outline, of a picture recorded in its memory.

## 22-7. Additional Topics

## a. Selected Bibliography on Memory Systems

Alexander, M. A., and M. Rosenberg: Ferrite-core Memory Is Fast and Reliable, Electronics, vol. 29, no. 2, pp. 158-161, February, 1956.
Bivans, E. W.: Synchronizing Magnetic Drum Storage Speed, Electronics, vol. 28, no. 8, pp. 140-141, August, 1955.
Blachman, N. M.: On the Wiring of Two-dimensional Multiple-coincidence Magnetic Memories, IRE Trans. on Electronic Computers, vol. EC-5, pp. 19-21, March, 1956.

Booth, A. D.: A Magnetic Drum Digital Storage System, Electronic Eng., vol. 21, pp. 234-238, July, 1949.
Buck, D. A., and W. I. Frank: Nondestructive Sensing of Magnetic Cores, Communs. and Electronics, vol. 72, no. 10, pp. 822-830, January, 1954.
Cohen, A. A.: Magnetic Drum Storage for Digital Information Processing Systems, Mathematical Tables and Other Aids to Computation, vol. 4, pp. 31-39, January, 1950.

Comstock, G. E.: 500,000,000-bit Random Access Memory, Instr. and Automation, vol. 29, pp. 2208-2211, November, 1956.
Conger, R. L.: Flat Plate Memory, Naval Ordnance Lab. Tech. Mem. 72-6, Nov. 14, 1955.

Digital Magnetic Circuits-Theory, Electrical Design, and Logical Design, Burroughs Corp. Tech. Rept. TR 59-27, vols. 1-3, April, 1959.
Eckert, J. P., Jr.: Survey of Digital Computer Memory Systems, Proc. IRE, vol. 41, pp. 1393-1406, October, 1953.
Everett, R. R.: Selection Systems for Magnetic Core Storage, MIT Servomechanisms Lab. Eng. Note E-413, August, 1951.
Forrester, J. W.: Digital Information Storage in Three Dimensions Using Magnetic Cores, J. Appl. Phys., vol. 22, pp. 44-48, January, 1951.
Foss, E., and R. S. Partridge: 32,000-word Magnetic-core Memory, IBM J. Research Develop., vol. 1, pp. 103-109, April, 1957.
Fuller, H. W., P. A. Husman, and R. C. Kelner: Techniques for Increasing Storage Density of Magnetic Drum Systems, Proc. Eastern Joint Computer Conf., December, 1954, Philadelphia, pp. 16-21.
Guterman, S., and R. D. Kodis: Magnetic Core Selection System, IRE Conv. Record, pt. 4, pp. 116-123, 1954.
——, ——, and S. Ruhman: Logical and Control Functions Performed with Magnetic Cores, Proc. IRE, vol. 43, pp. 291-298, March, 1955.
Hagen, G. E.: Air Floating, a New Principle in Magnetic Recording of Information, Computers and Automation, vol. 2, no. 8, pp. 23-25, November, 1953.
Helbig, W. A., W. G. Rumble, and C. S. Warren: Transistor Operated Magnetic Core Memory, Proc. Natl. Electronics Conf., vol. 12, pp. 289-299, 1957.
High-density Magnetic Recording, Harvard Computation Lab. Progr. Rept. 34, pt. II, August, 1954.
High-density Tape Recordings for Digital Computers, Elec. Mfg., vol. 290, p. 153, November, 1955. (Work done at the National Bureau of Standards.)
Hoagland, A. S.: A Logical Reading System for Nonreturn-to-zero Magnetic Recording, IRE Trans. on Electronic Computers, vol. EC-4, pp. 93-95, September, 1955. -: Magnetic Data Recording Theory: Head Design, Trans. AIEE, pt. I, Communs. and Electronics, vol. 75, pp. 506-512, November, 1956.
——: Magnetic Recording Head Design, Proc. Western Joint Computer Conf., February, 1956, San Francisco, pp. 26-31.

Hoh, A. W.: A Preliminary Report on the Prototype Diode-capacitor Memory, Proc. Argonne Conf. Digital Computers, August, 1953. (See also NBS Rept. 2713, June, 1953, and NBS Rept. 3374, May 1, 1954.)
Lubkin, S.: An Improved Reading System for Magnetically Recorded Digital Data, IRE Trans. on Electronic Computers, vol. EC-3, pp. 22-25, September, 1954.
Magnetic Memory Element Exhibits 4-millimicrosecond Switching Speed, Elec. Eng., vol. 78, pp. 236-237, March, 1959.
McGuigan, J. H.: Combined Reading and Writing on a Magnetic Drum, Proc. IRE, vol. 41, pp. 1438-1444, October, 1953.
Mee, C. D.: Magnetic Tape for Data Recording, Proc. IEE, vol. 105, pp. 373-380, July, 1958. (Discussion on pp. 380-382.)
Nordyke, H. W.: Magnetic Tape Recording Techniques and Performance, Proc. AIEE-IRE-ACM Computer Conf., December, 1952, New York, pp. 90-95.
Noyes, T., and W. E. Dickinson: Engineering Design of a Magnetic-disk Randomaccess Memory, Proc. Western Joint Computer Conf., February, 1956, San Francisco, pp. 42-44.
—— and -_: The Random-access Memory Accounting Machine: II. The Magnetic-disk Random-access Memory, IBM J. Research Develop., vol. 1, pp. 72-75, January, 1957.
Papian, W. N.: Ferromagnetic Cores for Three-dimensional Digital Storage Arrays, Proc. IRE, vol. 39, pp. 292-315, March, 1951.
———: New Ferrite-core Memory Uses Pulse Transformers, Electronics, vol. 28, no. 3, pp. 194-197, March, 1955.
——: A Coincident Current Magnetic Memory Cell for the Storage of Digital Information, Proc. IRE, vol. 40, pp. 475-478, April, 1952.
Potter, J. T., and P. C. Michel: High-density Digital Recording System, IRE Trans. on Electronic Computers, vol. EC-1, pp. 60-72, December, 1952.
Raffel, J., and S. Bradspies: Experiments on a Three-core Cell for High-speed Memories, IRE Conv. Record, pt. 4, pp. 64-69, 1955.
Rajchman, J.: A Myriabit Magnetic-core Matrix Memory, Proc. IRE, vol. 41, no. 10, pp. 1407-1421, October, 1953.
Renwick, W. A.: A Magnetic Core Matrix Store with Direct Selection Using a Magnetic Core Switch Matrix, Proc. IEE, vol. 104, pt. B, suppl. no. 7, pp. 436-444, 1957.
Robinson, A. A., V. L. Newhouse, M. J. Friedman, D. G. Bindon, and I. P. V. Carter: A Digital Store Using a Magnetic Core Matrix, Proc. IEE, vol. 103, pt. B, suppl. 2, Convention on Digital-computer Techniques, pp. 295-301, April, 1956.
Schmidbauer, O.: The Determination of Frequency Characteristics of Recording-tape Magnetization, Elektron. Rundschau, vol. 11, pp. 373-375, December, 1957.
Stuart-Williams, R., M. Rosenberg, and M. A. Alexander: "Recent Advances in Coincident-current Magnetic Memory Techniques," International Telemeter Corp., Los Angeles, 1954. (This paper was presented at the annual meeting of the Association for Computing Machinery, Ann Arbor, June, 1954.)
Summarized Proceedings of the Conference on Solid State Memory and Switching Devices, Brit. J. Appl. Phys., vol. 10, pp. 153-158, April, 1959.
Taylor, N. H.: Rapid-access Storage Including the Use of Magnetic Cores for Storage and Switching, Proc. IEE, vol. 103, pt. B, suppls. 1-3, pp. 327-330, 1956.
Thorensen, R., and W. R. Arsenault: A New Nondestructive Read for Magnetic Cores, Proc. Western Joint Computer Conf., 1955, pp. 111-116.
Transistorized Magnetic Core Memory, Computers and Automation, vol. 6, pp. 26-27, January, 1957.
Welsh, H. F., and H. Lukoff: The Uniservo-Tape Reader and Recorder, Proc. AIEE-IRE-ACM Computer Conf., December, 1952, New York, pp. 47-53.

Wier, J. W.: A High-speed Permanent Storage Device, IRE Trans. on Electronic Computers, vol. EC-4, pp. 16-20, March, 1955.
Wilkes, M. V., and D. W. Willis: A Magnetic-tape Auxiliary Storage System for the EDSAC, Proc. IEE, vol. 103, pt. B, suppl. 2, Convention on Digital-computer Techniques, pp. 337-345, April, 1956.
Williams, F. C., and J. C. West: Position Synchronization of a Rotating Drum, Proc. IEE, vol. 98, pt. II, pp. 29-34, February, 1951.
Younker, E. L.: A Transistor-driven Magnetic-core Memory, IRE Trans. on Electronic Computers, vol. EC-6, pp. 14-20, March, 1957.

## b. Selected Bibliography on Thin-film Techniques

Bittmann, E. E.: Thin Film Memories, Digest of Technical Papers, p. 20, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Blois, M. S.: Preparation of Thin Magnetic Films and Their Properties, J. Appl. Phys., vol. 26, pp. 975-980, August, 1955.
Callen, H. B.: Rotational Remagnetization of Thin Films, Digest of Technical Papers, p. 96, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Conger, R. L.: High Frequency Effects in Magnetic Films, Proc. AIEE Conf. on Magnetism and Magnetic Materials, 1956, pp. 610-619.
-: Magnetization Reversal in Thin Films, Phys. Rev., vol. 98, pp. 1752-1754, June, 1955.
: Thin Film Magnetization Reversal Studies, Proc. Nonlinear Magnetics and Magnetic Amplifiers, Special Tech. Conf., August, 1958.
Experimental Production of Thin Ferrite Films and a Survey of the Magnetic Properties of Thin Films, NAVORD Rept. 3962, March, 1955. (Also available from Office of Technical Services, U.S. Department of Commerce, as PB 121177.)
Fowler, C. A., E. M. Fryer, and J. R. Stevens: Magnetic Domains in Evaporated Thin Films of Nickel-Iron, Phys. Rev., vol. 104, pp. 645-649, November, 1956.

Gianola, U. F.: Nondestructive Memory Employing a Domain Oriented Steel Wire, J. Appl. Phys., vol. 29, pp. 849-853, May, 1958.

Goodenough, J. B., and D. O. Smith: Magnetic Properties of Thin Films, MIT Lincoln Lab., Tech. Rept. 197, ASTIA 210730, January, 1959.
House, C. B., and R. L. Van Allen: Nondestructive Readout of Multilevel Magnetic Memory, NRL Rept. 5071, February, 1958. (Also available from Office of Technical Services, U.S. Department of Commerce, as PB 131475.)
Kittel, C.: Theory of the Structure of Ferromagnetic Domains in Films and Small Particles, Phys. Rev., vol. 70, pp. 965-971, December, 1946.
Kudela, A. F.: The Thin Film, Flat Plate, Printed Circuit Memory, Naval Ordnance Lab. Tech. Mem. 72-7, Dec. 20, 1955.
Oakland, L. J., and T. D. Rossing: Coincident-current Nondestructive Readout from Thin Magnetic Films, J. Appl. Phys., suppl. to vol. 30, no. 4, pp. 54S-55S, April, 1959.
Olson, C. D., and A. V. Rohm: Flux Reversal in Thin Films of $82 \% \mathrm{Ni}, 18 \% \mathrm{Fe}$, J. Appl. Phys., vol. 29, pp. 274-282, March, 1958.

Olson, E. R.: Research and Development on Magnetic Films and Magnetic Matric Memory Units, Final Rept. AD-151 160, Servomechanisms, Inc., Contract AF 33(616)3039, WADC TR 57-707, April, 1958. (Available also from Office of Technical Services, U.S. Department of Commerce, as PB 135053.)

- Raffel, J. I.: Operating Characteristics of a Thin Film Memory, J. Appl. Phys., vol. 30, pp. 60S-61S, April, 1959.

Rohm, A. V., and S. M. Rubens: A Compact Coincident-current Memory, Proc. Eastern Joint Computer Conf., December, 1956, pp. 120-123.
Rossing, T. D., and R. M. Sanders: Reversible Rotation in Magnetic Films, J. Appl. Phys., vol. 29, pp. 288-289, March, 1958.
Smith, D. O.: Magnetization Reversal and Thin Films, J. Appl. Phys., vol. 29, pp. 264-273, March, 1958.
-_: Thin Magnetic Films for Digital Computer Memories, Electronics, June 26, 1959, p. 44.
c. Articles on Analog-to-digital and Digital-to-analog Conversion Processes

Bain, M. B.: Precision Digital-to-analog Conversion Methods for Graphical Plotters, Proc. Natl. Electronics Conf., 1955, pp. 268-277.
Barker, R. H.: A Transducer for Digital Data Transmission Systems, Proc. IEE, vol. 103, pt. B, pp. 42-51, January, 1956.
Beckett, F.: A Rapid Digital-to-analogue Converter for Numbers Having Eleven Binary Digits, Proc. IEE, vol. 103, pt. B, suppl. 3, Convention on Digitalcomputer Techniques, pp. 427-431, April, 1956.
Brown, J. H.: Measure Motion to 0.0001 Inch without Friction or Wear, Control Eng., vol. 2, no. 4, pp. 50-52, April, 1955.
Burke, H. E.: A Survey of Analog-to-digital Converters, Proc. IRE, vol. 41, pp. 1455-1462, October, 1953.
Cronin, F. R.: Automatic Converter to Prepare Analog Data for Digital Computation, M.S. thesis, Electrical Engineering Department, Massachusetts Institute of Technology, June, 1956.
Elliot, W. S., R. C. Robbins, and D. S. Evans: Remote Position Control and Indication by Digital Means, Proc. IEE, vol. 103, pt. B, suppl. 3, Convention on Digital-computer Techniques, pp. 437-446, April, 1956.
Evans, D. S.: The Digitizer-A High-accuracy Scale for Automatic Data Processing, Brit. Communs. Electronics, vol. 4, pp. 334-339, June, 1957.
Follingstad, H. G., J. N. Shive, and R. E. Yaeger: An Optical Position Encoder and Digit Register, Proc. IRE, vol. 40, pp. 1573-1583, November, 1952.
Forrand, W. A.: An Accurate Digital-analogue Function Generator, Proc. Electronic Computer Symposium, April-May, 1952, Los Angeles, pp. XVI-1-XVI-9.
Foss, F. A.: The Use of Reflected Code in Digital Control Systems, IRE Trans. on Electronic Computers, vol. EC-3, pp. 1-6, December, 1954.
Henn, W., and A. S. Robinson: A Digital Sine-Cosine Transducer, IRE Trans. on Instrumentation, vol. PGI-5, pp. 202-209, June, 1956.
Hollander, G. H.: Criteria for the Selection of Analog-to-digital Converters, Proc. Natl. Electronics Conf., 1953, pp. 670-683.
Horn, H. S.: Multiple-input Analog-to-digital Converter with 12-bit Accuracy and Fast, Non-sequential Switching, IRE Natl. Conv. Record, pt. 4, pp. 259-266, March, 1959.
Jury, E. I.: Analysis and Synthesis of Sampled Data Control Systems, Trans. AIEE, vol. 73, pt. I, pp. 332-346, September, 1954.
Kay, A. F.: Relay-scanning-design Technique Generates High Accuracy and Speed in Analogue-to-digital Transducer Measurements, Communs. and Electronics, no. 36, pp. 248-250, May, 1958.
Klein, M. L.: High Speed Analog-digital Converters, IRE Trans. on Instrumentation, vol. PGI-5, pp. 148-154, June, 1956.
Kuder, M. L.: Anodige, an Electronic Analogue-to-digital Converter, NBS Rept. 1117, Aug. 24, 1951.

Libaw, W. H., and L. J. Craig: A Photoelectric Decimal-coded Shaft Digitizer, IRE Trans. on Electronic Computers, vol. EC-2, pp. 1-4, September, 1953.
Linvill, W. K.: Sampled Data Control Systems through Comparison of Sampling with Amplitude Modulation, Trans. AIEE, Tech. Paper 51-324, vol. 70, pt. 2, pp. 1779-1786, 1951. (Discussion, p. 1787.)
——and J. M. Salzer: Analysis of Control Systems Involving Digital Computers, Proc. IRE, vol. 41, pp. 901-906, July, 1953.
——_ and R. W. Sittler: Extension of Conventional Techniques to the Design of Sampled Data Systems, IRE Conv. Record, 1953, pt. 1, Radar and Telemetry, pp. 99-104.
Lippel, B.: A High Precision Analog-to-digital Converter, Proc. Natl. Electronics Conf., 1951, pp. 206-215.
-_: Interconversion of Analog and Digital Data in Systems for Measurement and Control, Proc. Natl. Electronics Conf., 1952, pp. 636-646.
-: A Decimal Code for Analog-to-digital Conversion, IRE Trans. on Electronic Computers, vol. EC-4, pp. 158-159, December, 1955.
Mergler, H. W.: A Digital-analog Machine Tool System, Proc. Western Joint Computer Conf., February, 1954, Los Angeles, pp. 46-59.
Meter Reads Optically, Then Digitizes, Control Eng., vol. 3, no. 3, p. 107, March, 1956.
Mitchell, A. L.: Photoelectric Analog-to-digital Converters, Electronic Design, vol. 4, no. 9, pp. 20-23, May 1, 1956.
Mitchell, J. M.: A High-speed Multichannel Analog-digital Converter, Proc. Western Joint Computer Conf., February, 1954, Los Angeles, pp. 118-127.
Morrison, J. J.: An Automatic Graph Plotter, Trans. Soc. Instr. Tech., vol. 10, pp. 55-56, June, 1958.
Murphy, G. J., and R. D. Ormsby: A Survey of Techniques for the Analysis of Sampled Data Control Systems, IRE Trans. on Automatic Control, vol. PGAC-2, pp. 79-90, February, 1957.
Partos, P.: Industrial Data-reduction and Analogue-digital Conversion Equipment, J. Brit. IRE, vol. 16, pp. 651-678, December, 1956.

Putschi, H. N., J. A. Raper, and J. J. Suran: Digital/Analogue Converter Provides Storage, Electronics, vol. 30, pp. 148-151, Dec. 1, 1957.
Ragazzini, J. R., and G. F. Franklin: "Sampled-data Control Systems," McGrawHill Book Company, Inc., New York, 1958.
-_ and L. A. Zadek: The Analysis of Sampled Data Systems, Trans. AIEE, Tech. Paper 52-161, vol. 71, pt. 2, pp. 225-232, 1952.
Resnik, I. L.: Binary Conversion for Analog-digital Converters, Electronic Design, vol. 4, no. 12, pp. 42-45, June 15, 1956.
Retzinger, L. P., Jr.: An Input-output System for a Digital Computer, Proc. Western Joint Computer Conf., August, 1954, pp. 67-76.
Rigby, S.: Analog-to-digital Converter, Electronics, vol. 29, no. 1, pp. 152-155, January, 1956. (A frequency-modulation method.)
Salzer, J. M.: Frequency Analysis of Digital Computers Operating in Real-time, Proc. IRE, vol. 42, no. 2, pp. 457-466, February, 1954.
--: System Compensation with a Digital Computer, IRE Conv. Record, pt. 5, pp. 179-186, 1954.
Scarbrough, A. D.: An Analog-to-digital Converter, IRE Trans. on Electronic Computers, vol. EC-2, pp. 5-7, September, 1953.
Sisson, R. L., and A. K. Susskind: Devices for Conversion between Analog Quantities and Binary Pulse-coded Numbers, M.S. thesis, Department of Electrical Engineering, Massachusetts Institute of Technology, 1950.

Slaughter, D. W.: An Analog-to-digital Converter with an Improved Linear-sweep Generator, IRE Conv. Record, pt. 7, pp. 7-12, 1953.
Smith, B. D.: An Unusual Electronic Analog-digital Conversion Method, IRE Trans. on Instrumentation, vol. PGI-5, pp. 155-160, June, 1956.
Spaulding, C. P.: Sine-cosine Angular Position Encoders, IRE Trans. on Instrumentation, vol. PGI-5, pp. 161-167, June, 1956.
Speller, J. B.: A Digital Converter, Proc. Western Joint Computer Conf., August, 1957, pp. 29-31.
Susskind, A. K.: Approaches to Design Problems in Conversion Equipment, Proc. Western Joint Computer Conf., February, 1954, Los Angeles, pp. 105-112.
-_ (ed.): "Notes on Analog-digital Conversion Techniques," Technology Press, Boston, 1957.
Tompkins, H. E.: Unit-distance Binary-decimal Codes for Two-track Commutation, IRE Trans. on Electronic Computers, vol. EC-5, p. 139, September, 1956.
Towles, W. B.: A Transistorized Analogue-digital Converter, Electronics, vol. 31, pp. 90-93, Aug. 1, 1958.
Villars, C. P.: Design of a Transistorized 1.5 Megabit Analog-to-digital Encoder, Digest of Technical Papers, p. 38, IRE-AIEE Solid-state Circuits Conference, 1959, University of Pennsylvania.
Walton, C. A.: A Direct-reading Printed-circuit Commutator for Analogue-to-digital Data Conversion, IBM J. Research Develop., vol. 2, pp. 178-192, July, 1958.
Willis, J., and M. G. Hartley: A Cathode-ray-tube Analogue-to-serial Digital Converter, J. Sci. Instr., vol. 35, pp. 197-202, June, 1958.
Wister, A. J.: A Magnetically Coupled Low-cost High Speed Shaft Position Digitizer, Proc. Western Joint Computer Conf., 1953, pp. 203-207.
Zweizig, J. R.: A Digital Voltage Encoder, IRE Trans. on Electronic Computers, vol. EC-3, pp. 25-28, September, 1954.

## d. Selected Bibliography on Input-Output Methods

Bliss, W. H., and J. E. Ruedy: An Electron Tube for High-speed Teleprinting, $R C A$ Rev., vol. 16, pp. 5-15, March, 1955.
Carroll, J. M.: Trends in Computer Input-output Devices, Electronics, vol. 29, no. 9, pp. 142-149, September, 1956.
David, E. E., M. V. Mathews, and H. S. McDonald: A High-speed Data Translator for Computer Simulation of Speech and Television Devices, Proc. Western Joint Computer Conf., March, 1959.
Davidson, J. T., and R. L. Fortune: Automatic Translation of Printed Code to Impulses Acceptable to Computing Equipment, Proc. Western Joint Computer Conf., March, 1955, Los Angeles, pp. 29-33.
Diamond, T. L.: Devices for Reading Handwritten Characters, Proc. Eastern Joint Computer Conf., December, 1957, pp. 232-238.
Dineen, G. P.: Programming Pattern Recognition, Proc. Western Joint Computer Conf., March, 1955, Los Angeles, pp. 94-100.
Epstein, H.: The Electrographic Recording Technique, Proc. Western Joint Computer Conf., March, 1955, Los Angeles, pp. 116-118.
Gettings, H.: A Big Step in Digital Telemetry, Missiles and Rockets, July 13, 1959, pp. 37-40.
Greanias, E. C., C. J. Hoppel, M. Kloomok, and J. S. Osborne: The Design of a Logic for the Recognition of Printed Characters by Simulation, Proc. IEE, vol. 103, pt. B, suppl. 3, Convention on Digital-computer Techniques, pp. 456-462, April, 1956. (Also appears in IBM J. Research Develop., vol. 1, pp. 8-18, January, 1957.)

Heasley, C. C., Jr.: Some Communication Aspects of Character Sensing Systems, Proc. Western Joint Computer Conf., March, 1959, pp. 176-181.
Highleyman, W. H., and L. A. Kamentsky: Generalized Scanner for Pattern and Character Recognition Studies, Proc. Western Joint Computer Conf., March, 1959.

Johnson, R. B.: Writing around Dots, Patent No. 2,141,312, Apr. 10, 1956.
Kamentsky, L. A.: Pattern and Character Recognition Systems-Picture Processing by a Net of Neuron-like Elements, Proc. Western Joint Computer Conf., March, 1959.

Kirsch, R. A., et al.: Experiments in Processing Pictorial Information with a Digital Computer, Proc. Eastern Joint Computer Conf., December, 1957, pp. 221-230.
McPherson, R. G., and I. A. Sonderby: Digital and Pictorial Photographic Electronic Recorder, Communs. and Electronics, no. 36, pp. 194-196, May, 1958.
Ogle, J.: Optical Display for Data-handling System Output, Proc. Eastern Joint Computer Conf., December, 1957, pp. 230-232.
Pike, J. L., and E. F. Ainsworth: Input-output Devices for NBS Computers, NBS Circ. 551, Computer Development at the National Bureau of Standards, pp. 109-118, January, 1955.
Rabinow, J.: Report on DOFL First Reader, DOFL Rept. TR-128, Nov. 26, 1954.
Review of Input and Output Equipment Used in Computing Systems, Proc. Joint AIEE-IRE-ACM Computer Conf., December, 1952, New York.
Seehof, J., et al.: The National Cash Register High-speed Magnetic Printer, Proc. Eastern Joint Computer Conf., December, 1957, pp. 243-251.
Selfridge, O. G.: Pattern Recognition and Modern Computers, Proc. Western Joint Computer Conf., March, 1955, Los Angeles, pp. 91-93.
Shepard, D. H., and C. C. Heasley: Photoelectric Reader Feeds Business Machines, Electronics, vol. 28, no. 5, pp. 134-138, May, 1955.
Smith, H. M.: The Typotron, IRE Conv. Record, pt. 4, pp. 129-134, 1955.
Tersoff, A. I.: Automatic Registration in High-speed Character Sensing Equipment, Proc. Eastern Joint Computer Conf., December, 1957, pp. 238-243.
West, R. E.: High-speed Readout for Data Processing, Electronics, May 29, 1959, pp. 83-85.

## THE ELECTRONIC DESIGN OF THE PEDAGAC

## 23-1. Introduction

In this chapter the attempt is made to complete the thread of con-tinuity-from the systems design of a general-purpose computer, through its logical design, to its electronic design and final wiring tables. The chapter may at first seem specific in that it illustrates the electronic design of a single, simple machine. However, the reader should realize that the purpose of discussing the Pedagac is to bring up in a natural and realistic way some very important general problems applicable to all computer and control designs. Consideration of each problem had to be post-


Fig. 23-1. Type $C$ package schematic wiring diagram. (The portion of the figure enclosed in the dashed rectangle is discussed in Sec. 23-3.)
poned until all the necessary background had been developed. Now in this chapter we can finally discuss the all-important specific timing problem, illustrated by its solution for the Pedagac. Then there are the delay and negation problems, for which the Pedagac solutions are given. Finally we shall be in a position to appreciate the wiring-table problem, which in practical cases becomes far from trivial.

## 23-2. Problems in the Electronic Design of the Pedagac

Basic Design of Pedagac Packages. gated transistor-amplifier regeneration circuit (see Sec. 20-5). Figure $23-1$ is a schematic wiring diagram of a type $C$ package (see Sec. 18-2), which has three input and gates feeding an or gate. Note that the regenerative and gate is wired internally. The direct and inverted outputs can each drive six other packages. The time required for the leading edge of a negative input pulse to pass through both transistors, i.e., the transit time $t_{T}$, is 0.47 $\mu \mathrm{sec}$. Figure 23-2 illustrates the output waveforms from a package.


Fig. 23-2. Output waveforms of a Pedagac package driving eight direct and eight inversion inputs. (Top) Input at 200 kc ; (center) inverted output; (bottom) direct output. Each vertical division represents 1.25 volts; each horizontal division represents $0.135 \mu \mathrm{sec}$.

The Pedagac package is a diode-


Fig. 23-3. Clock-phase system of the Pedagac: eight phases, 50 per cent duty cycle. Observe that the delay time of the trailing edge of each pulse allows skipping of three clock phases (cf. Fig. 23-5). Compare this figure with Figs. 19-5 and 19-6 on pages 632 and 633.

Packages of types $A, B, D$, and $E$ differ from Fig. 23-1 only in that they contain, respectively, one, two, four, and five input and gates.

Timing and Repeater Problems. For the Pedagac we have chosen an eight-phase clock (see Sec. 19-3) with a unit time interval of $5 \mu \mathrm{sec}$. The pulse width $t_{W}$ is taken to be a little more than four of the clockphase divisions, or slightly more than half a unit time interval. Each clock-phase division is $5 / 8=0.62 \mu \mathrm{sec}$ in length. Since for the regeneration circuit it is sufficient to have an overlap time no shorter than the


Fig. 23-4. Tracing ( $\alpha$ ) from channel 3 of the drum to the first stage of the accumulator.


Fig. 23-5. Skipping phases for delay with type $F$ package.
transit time ( $0.47 \mu \mathrm{sec}$ for the Pedagac package), then an overlap of one clock-phase division ( $0.62 \mu \mathrm{sec}$ ) is adequate for the transfer of a signal from one package to the next (see Fig. 23-3). A detailed examination of the logical design diagram of the Pedagac shows that no signal (except 1CS in the current-address counter) traverses more than seven packages during a single minor cycle; the eight-phase clock is more than adequate to handle this. Figure 23-4 illustrates a signal that traverses seven packages from the memory to the accumulator in one unit time interval.

The 50 per cent pulse duty cycle coupled with the short necessary overlap time is desirable for skipping clock phases (see Sec. 19-3). For our purposes the most important application of the clock-phase-skipping capability is its use in connection with the electronic realization of the
unit delays that so frequently appear in the logical diagrams. The delay line will be represented by a regenerative Pedagac type of package with a minimum of inputs. In Fig. 23-5 we illustrate its use for the delay in a dynamic flip-flop. Suppose that the flip-flop package $B$ is gated with input clock phase 1. Then its output will last from clock phase 2 through and including clock phase 5 . But the delay package $F$ is gated with input clock phase 5 , and can therefore accept the output of package B. The output of the delay package $F$ will last from clock phase 6 through and including clock phase 1 of the next unit time interval; if its output is connected to the input of package $B$, then package $B$ can sense the delayed signal. The


Fig. 23-6. Generating $T_{0}$ and $\bar{T}_{0}^{\prime}$ outputs, using $F$-type packages as repeaters. delay package we shall call a type $F$ package; it is constructed especially for this purpose, with a single twoinput and gate and a regeneration gate.

Each Pedagac package is limited to a maximum of six outputs. But


Fig. 23-7. Fifty-pin 5- by 7-in. card. The printed-circuit card is fitted into the connector as shown; electrical contact is made by spring clips above and below the card. The large holes on the sides of the connector are for mounting on the racks. The small holes, three to each pin, are for wiring, as illustrated by the jumper wire. The projecting pins are for testing.
observe from the logical diagrams that some Pedagac signals will be required as inputs many more than six times. Such signals must pass


Fig. 23-8. Type 2 card. (The portions of the figure enclosed in the dashed circles are discussed in Sec. 23-3.) through multiplying repeater packages to gain more outputs. The repeater package is simply the $F$-type package, just described for use in delays. For example, 34 direct outputs of $T_{0}$ and 32 inverted outputs of $T_{0}$ (i.e., $\bar{T}_{0}$ ) are required. We let the direct output of the $T_{0}$ generator drive six $F$-type repeater packages; each output of the $F$-type packages is able to drive six more packages, for a total of 36 available direct $T_{0}$ outputs and 36 available inverted, or $\bar{T}_{0}$, outputs; these are more than adequate for this situation (see Fig. 23-6).

From our unit-time-interval specifications we can calculate the required speed of the magnetic memory drum of the Pedagac and the average access time. Since there are $2^{7}=128$ sectors around the drum and each sector contains 23 bits per channel; there are $128 \times 23=2,944$ bits per channel, or 2,944 unit time intervals per revolution. Since a unit time interval is $5 \mu \mathrm{sec}$, we have a basic clock rate of $1 /\left(5 \times 10^{-6}\right)=200 \mathrm{kc}$. The drum speed in rpm is therefore

$$
\frac{60}{2,944 \times 5 \times 10^{-6}}=4,076 \mathrm{rpm}
$$

The average access time in milliseconds is
$1 / 2($ time of 1 revolution $)=$ $1 / 2 \times 2.944 \times 5 \times 10^{-3}=7.4 \mathrm{msec}$

Pedagac Packages and Cards. The next step in the design of the Pedagac is a discussion of the assembly of the packages into cards, the printedcircuit modules of the Pedagac.
We have selected a $50-\mathrm{pin}$ card 7 in . long and 5 in. wide (see Fig. 23-7). The pins of the card fit into a connector, on the other side of which are holes for the insertion of taper-pin tipped wires. Each type $B, C, D$, and
$E$ package is paired with a type $F$ package, since many of these packages are associated with unit delays (e.g., the shift-register packages, etc.). For the Pedagac we make use of six types of cards:

Type 1 card with five type $A$ packages
Type 2 card with two type $B$ and two type $F$ packages
Type 3 card with one type $C$ and one type $F$ package
Type 4 card with one type $D$ and one type $F$ package
Type 5 card with one type $E$ and one type $F$ package
Type 6 card with nine type $F$ packages
Figure 23-8 illustrates a type 2 card with its associated pin connections; Table 23-1 lists the pin connections for all the cards. To reduce the required number of pins per package, each Pedagac card includes a common ground and a common power bias. Thus only two voltage pins are needed, pin 1 for ground and pin 50 for the required -10 -volt supply.

## EXERCISES

(a) From the specifications of the Pedagac, and from the fact that no signal traverses more than seven packages in a unit time interval, observe that a seven-phase clock seems feasible. Perform all the calculations analogous to those described above for such a seven-phase clock system. (Hint: What duty cycle will allow the use of $F$-type packages as a delay?) What will be the average access time?
(b) Consider a signal that must drive 26 packages. Design a repeater system using only 4 repeater packages such that all 26 signals are available at the same time. (Hint: Skip clock phases.)
(c) Signal 1CS may be required to traverse up to 12 packages in a unit time interval. One method of preventing this is to design the current-address register as a parallel counter (see Exercise $f$ of Sec. 18-7). Why is this unnecessary in the Pedagac? (Hint: See footnote on p. 582.)

## 23-3. Problems in Assigning Clock Phases

Negation Problem. With the background of the previous section we are now in a position to understand the negation problem. Consider a package with input clock pulse $c p 1$. If this package is putting out a unit, the unit will appear at approximately $c p 2$ through $c p 5$, being delayed from the input clock pulse by one clock-phase division. During $c p 6$ through $c p 8$ and the next $c p 1$, that is, "between" clock pulses, the output will be zero. But consider the inverted output. During cp2 through $c p 5$ it will have the opposite polarity to the direct output and will be zero. But during $c p 6$ through $c p 8$ and the next $c p 1$, that is, between clock pulses, the inverted output will be a unit. A problem arises because this negation output is a unit between clock pulses, whereas we have heretofore tacitly considered it to be zero. For example, consider an input and gate that is to form $X \cdot \bar{Y}$, gated at $c p 4$, with the $X$ output "on" from $c p 4$ through $c p 7$, but with the $Y$ output "on" from $c p 2$ through $c p 5$. Suppose that $Y$ is a unit. Then there should be a zero output from the $X \cdot \bar{Y}$ and gate; and there is during $c p 4$

Table 23-1. Card-pin Layout

Type 1 Card

| Pin No. | Package and gate No. | Function |
| :---: | :---: | :---: |
| 1 | $\ldots$ | Ground |
| 2 | 1 A1 | $c p x$ input |
| 3-7 | $1 A 1$ | Inputs |
| 8 | $1 A a$ | $c p x+1$ input |
| 9 | 1 A | Output |
| 10 | 1 A | Output |
| 11 | 2 Al | cpx input |
| 12-16 | $2 A 1$ | Inputs |
| 17 | $2 A a$ | $c p x+1$ input |
| 18 | 2 A | $\overline{\text { Output }}$ |
| 19 | 2 A | Output |
| 20 | 3 A1 | cpx input |
| 21-25 | 3 A1 | Inputs |
| 26 | $3 A a$ | $c p x+1$ input |
| 27 | 3A | $\overline{\text { Output }}$ |
| 28 | 3 A | Output |
| 29 | $4 A 1$ | cpx input |
| 30-34 | $4 A_{1}$ | Inputs |
| 35 | $4 A a$ | $c p x+1$ input |
| 36 | 4 A | $\overline{\text { Output }}$ |
| 37 | 4 A | Output |
| 38 | $5 A 1$ | cpx input |
| 39-43 | $5 A 1$ | Inputs |
| 44 | $5 A a$ | $c p x+1$ input |
| 45 | $5 A$ | $\overline{\text { Output }}$ |
| 46 | $5 A$ | Output |
| 47-49 | .... | Blank |
| 50 | $\ldots$ | -10 volts |


| Pin No. | Package and <br> gate No. | Function |
| :---: | :---: | :--- |
| $\mathbf{1}$ | $\ldots$. | Ground |
| 2 | $1 B 1$ | cpx input |
| $3-7$ | $1 B 1$ | Inputs |
| 8 | $1 B 2$ | cpx input |
| $9-13$ | $1 B 2$ | Inputs |
| 14 | $1 B a$ | cpx+1 input |
| 15 | $1 B$ | Output |
| 16 | $1 B$ | Output |
| 17 | $1 F 2$ | cpx+4 input |
| 18 | $1 F 2$ | Input |
| 19 | $1 F a$ | cpx+5 input |
| 20 | $1 F$ | Output |
| 21 | $1 F$ | Output |
| 22 | $2 B 1$ | cpx input |
| $23-27$ | $2 B 1$ | Inputs |
| 28 | $2 B 2$ | $c p x$ input |
| $29-33$ | $2 B 2$ | Inputs |
| 34 | $2 B a$ | cpx+1 input |
| 35 | $2 B$ | Output |
| 36 | $2 B$ | Output |
| 37 | $2 F 2$ | cpx+4 input |
| 38 | $2 F 2$ | Input |
| 39 | $2 F a$ | $c p x+5$ input |
| 40 | $2 F$ | $O$ Output |
| 41 | $2 F$ | Output |
| $42-49$ | $\ldots$ | Blank |
| 50 | $\cdots$ | -10 volts |
|  |  |  |

Type 4 Card

| Pin No. | Package and <br> gate No. | Function |
| :---: | :---: | :--- |
| 1 | $\ldots$. | Ground |
| 2 | $1 D 1$ | $c x$ input |
| $3-7$ | $1 D 1$ | Inputs |
| 8 | $1 D 2$ | cpxinput |
| $9-13$ | $1 D 2$ | Inputs |
| 14 | $1 D 3$ | $c p x$ input |

Table 23-1. Card-pin Layout (Continued)

| Type 3 Card (Continued) |  |  |
| :---: | :---: | :--- |
| Pin No. | Package and <br> gate No. | Function |
| $9-13$ | $1 C 2$ | Inputs |
| 14 | $1 C 3$ | cpx input |
| $15-19$ | $1 C 3$ | Inputs |
| 20 | $1 C a$ | cpx+1 input |
| 21 | $1 C$ | Output |
| 22 | $1 C$ | Output |
| 23 | $1 F 2$ | cpx input |
| 24 | $1 F 2$ | Input |
| 25 | $1 F a$ | cpx +1 input |
| 26 | $1 F$ | Output |
| 27 | $1 F$ | Output |
| $28-49$ | $\cdots$ | Blank |
| 50 | $\cdots$ | -10 volts |


| Pin No. | Package and <br> gate No. | Function |
| :---: | :---: | :--- |
| $15-19$ | $1 D 3$ | Inputs |
| 20 | $1 D 4$ | cpx input |
| $21-25$ | $1 D 4$ | Inputs |
| 26 | $1 D a$ | cpx + 1 input |
| 27 | $1 D$ | Output |
| 28 | $1 D$ | Output |
| 29 | $1 F 2$ | cpx+4 input |
| 30 | $1 F 2$ | Input |
| 31 | $1 F a$ | cpx+5 input |
| 32 | $1 F$ | Output |
| 33 | $1 F$ | Output |
| $34-49$ | $\cdots$ | Blank |
| 50 | $\cdots$ | -10 volts |

Type 5 Card

| Pin No. | Package and <br> gate No. | Function |
| :---: | :---: | :--- |
| 1 | $\ldots \ldots$ | Ground |
| 2 | $1 E 1$ | cpx input |
| $3-7$ | $1 E 1$ | Inputs |
| 8 | $1 E 2$ | cpx input |
| $9-13$ | $1 E 2$ | Inputs |
| 14 | $1 E 3$ | cpx input |
| $15-19$ | $1 E 3$ | Inputs |
| 20 | $1 E 4$ | cpx input |
| $21-25$ | $1 E 4$ | Inputs |
| 26 | $1 E 5$ | $c p x$ input |
| $27-31$ | $1 E 5$ | Inputs |
| 32 | $1 E a$ | $c p x+1$ input |
| 33 | $1 E$ | Output |
| 34 | $1 E$ | Output |
| 35 | $1 F 2$ | $c p x+4$ input |
| 36 | $1 F 2$ | Input |
| 37 | $1 F a$ | $c p x+5$ input |
| 38 | $1 F$ | Output |
| 39 | $1 F$ | Output |
| $40-49$ | $\ldots \ldots$ | Blank |
| 50 | $\cdots \cdots$ | -10 volts |


| Pin No. | Package and gate No. | Function |
| :---: | :---: | :---: |
| 1 |  | Ground |
| 2 | $1 F 2$ | cpx input |
| 3 | $1 F^{2}$ | Input |
| 4 | 1 Fa | $c p x+1$ input |
| 5 | $1 F$ | Output |
| 6 | $1 F$ | Output |
| 7 | $2 F 2$ | ${ }_{c p}$ input |
| 8 | 2 F 2 | Input |
| 9 | 2 Fa | $c p x+1$ input |
| 10 | $2 F$ | Output |
| 11 | $2 F$ | Output |
| $\ldots$ | $\ldots$ | ............ |
| 42 | 9 F 2 | cpx input |
| 43 | 9 F 2 | Input |
| 44 | 9 Fa | cpx+1 input |
| 45 | $9 F$ | $\overline{\text { Output }}$ |
| 46 | $9 F$ | Output |
| 47-49 | .... | Blank |
| 50 |  | -10 volts |

and $c p 5$. But at $c p 6$ the signal $Y$ is "off"; hence the signal $\bar{Y}$ would become a unit, and the $X \cdot \bar{Y}$ gate is turned on erroneously.

There are several solutions to the negation problem. One solution is to force the inverted output to zero between clock pulses by means of the clock pulse itself. But an inverted output unit should come out delayed, just as a direct output unit does. Hence a clock pulse one phase division later is used, as shown in Fig. 23-9. Then both the direct and


Fig. 23-9. Solving the negation problem with a delayed clock pulse. ( $T_{1}$ and $T_{2}$ are transistor amplifiers.)
inverted outputs will be "off" between clock pulses but will have opposite polarities during the clock pulses, as desired. A second solution to the problem is to send the inverted output into a type $F$ package and utilize only the direct output of the type $F$ package (why?). A third solution is to use an appropriate clock-pulse input to all and gates having the negation as input.

Assigning Clock Phases to Packages. Each package is associated with the clock pulse entering each of its input and gates and its regeneration gate. The phase of this clock pulse is called the clock phase of the package. For each package of the Pedagac an appropriate clock phase must be assigned depending on the times the input signals are available. As an example, Fig. 23-10 repeats Fig. 18-12, with the clock phases assigned to the packages. There are two steps in making such an assignment: the first is to determine the availability of each signal, the second to
assign package clock phases as determined by these availabilities. For example, in Fig. 23-11 we trace ( $\alpha$ ) from the memory to S1AR, assuming that ( $\alpha$ ) leaves the memory at $c p 1$. Note that any information from the memory will not be available to the arithmetic unit until $c p 5$. The result of the arithmetic operations is available at $c p 7$, at which time it enters S1AR for temporary storage. To assign a clock phase to a package, all the input signals are marked as to clock-phase availability; the clock phase of the package then becomes the clock phase of the last signal to enter the package, in order that the output will be on for the full half unit time interval. Figure 23-12 shows the availability of signals entering package S5AR. The last signal will enter at $c p 5$, and so a clock pulse of $c p 5$ is assigned to S5AR. Note, however, that the signal SHS is available only during $c p 1$ through $c p 4$; thus we must delay SHS by one or more clock-phase divisions before it enters the package. In Fig. $23-10$ we have included all the type $F$ packages necessary for delay purposes, in addition to assigning the proper clock phase to each package.

We have assumed above that ( $\alpha$ ) will be available from the memory at $c p 1$, even during $T_{0}$. However, this requires that the selection mechanism of the IF phases begin its operation earlier than $T_{0}$. For this reason all IF packages must be adjusted to present outputs earlier than was indicated in Fig. 18-17 at $T_{0}$. Investigation of the figure indicates that this is possible. Other signals must similarly be adjusted, particularly those concerned with the instruction register and currentaddress counter. We shall not go into the details of this process (see the Additional Topics), except to note that the minor cycle was made three unit time intervals longer than the number of bits in a word especially to allow time for the selection processes before $c p 1$ of $T_{0}$.

## EXERCISES

(a) If the polarity of the unit and zero pulses were reversed, how would this affect the negation problem discussed above?
(b) Discuss the assignment of clock phases to the input-output equipment.
(c) Discuss other possible means of correcting for a signal cut off before the clock phase of a package it must enter.
(d) Assuming that information from the drum [ $(\alpha)]$ is available at $c p 1$, assign clock phases to the packages of Fig. 18-11.

## 23-4. Minimum-wiring Theory $\dagger$

The Wiring Problem. Modern large-scale computers can require more than 100,000 wire connections between packages. (Even our Pedagac requires approximately 5,000 wire connections.) The planning of these connections turns out to be far from trivial and in fact can be accomplished feasibly only with the aid of a computer. Systematic rules must therefore be devised in order that the computer can be programmed. The wiring itself can be feasibly accomplished by hand; for a simple
$\dagger$ This section is based in part on H. Loberman and A. Weinberger, Formal Procedures for Connecting Terminals with a Minimum Total Wire Length, J. Assoc. Computing Machinery, vol. 4, no. 4, pp. 428-437, October, 1957.


Fig. 23-10. Logical diagram of the arithmetic unit: sign generator

and accumulator-with associated clock phases and delay packages.


Fig. 23-11. Tracing ( $\alpha$ ) from memory to S1AR, with clock-phase availability times.
calculation based on the assumption that a technician using taper-pin connectors (no soldering required) can place one wire per minute indi-


Fig. 23-12. Assignment of clock phase to package S5AR. cates that four men working a $40-\mathrm{hr}$ week would require approximately 3 months to wire such a computer.

The wiring problem takes on specific form as follows: The computer cards will be assembled into female connectors mounted on racks. For the Pedagac only one rack is needed, as illustrated in Fig. 23-13. The cards are assigned row and column positions in the rack, which means that each pin number on the other side of the female connector (i.e., the holes for taper pins) now is associated with a specific signal (see Fig. 23-7). The technician connecting the wires must be supplied with a table giving the row and column of the card and the pin number for each end of every wire to be connected. It is highly desirable, for efficiency as well as for electronic purposes, to plan the wiring table so that a minimum length of wire is used. For example, suppose in Fig. 23-14 that pin 1 must be connected to pins $2,3,4,5,6$, and 7, where for ease of access wires can be strung only along horizontal and vertical paths. The left-hand picture shows a bad connection; the right-hand picture shows the minimum connections.

We shall present below two algorithms for determining the minimum wire length. The algorithms are applied separately to each set of pins that is associated with a particular signal, including both its source and destination. The inputs to the algorithm are the distances between all possible pairs of this set of pins, calculated according to the wire-path rules determined by the rack setup. If there are $n$ pins, then there are $\binom{n}{2}=\frac{n(n-1)}{2}$ distances to be specified.


Fig. 23-13. Pedagac card rack.
Definitions. Before proceeding with the theory we must introduce further terminology, derived in part from mathematical topology and in part from electrical-circuit theory. A proper pattern of connections is one in which there is only one path from each terminal to every other terminal and there are no loops formed by redundant connections. Figure 23-15 shows two possible proper patterns for connecting five terminals. All terminals are referred to as nodes. The direct connection between two nodes is called a branch, the magnitude of which is the distance between its end nodes. A path between two nodes is a connection of one or more branches. A graph is a structure consisting of a number of


Fig. 23-14. Minimum and nonminimum wiring connections.


Fig. 23-15. Proper-pattern connections.
nodes connected pairwise by one or more branches. A tree is a graph having only one path between every two nodes (a proper pattern). A proper pattern where the length of wire is minimum is a minimum tree. A subtree is a tree consisting of $m$ of $n$ nodes, where $m<n$.

Two Algorithms. To connect $n$ nodes into a tree, it is obvious that exactly $n-1$ branches are required. If more than $n-1$ branches are used, there will be redundant connections forming loops. On the other hand, if fewer than $n-1$ branches are used, the tree will be incomplete. If $n-1$ branches are used, but incorrectly, then both loops and unconnected nodes will result. It can be shown that the number of possible trees for $n$ nodes is $n^{n-2}$; obviously, as $n$ becomes great, the number of possible trees becomes overwhelming. A system which would generate all trees and select the minimum tree therefore appears impractical. However, since the total number of branches between each node and every other node is $n(n-1) / 2$, then for $n>5$ the total number of branches is considerably smaller than the total number of trees. Solutions to systems which have a large number of nodes must make use of algorithms which work on the branches.

For the first of the two algorithms we shall describe, the branches are sorted according to length, from short to long. The first branch is always used, its nodes being recorded as belonging to a subtree. Then each branch is examined, in order, for one of four possible conditions. The rules governing these four cases are as follows (see the flow chart of Fig. 23-16) :

1. Neither of the nodes is present in a recorded subtree: the branch is accepted, and the nodes are recorded as constituting a new subtree.
2. Only one node is present in a recorded subtree: the branch is accepted, and the new node is added to the subtree containing the other node of this branch.
3. Each of the nodes is recorded, but in different subtrees: the branch is accepted, and two subtrees containing the nodes are combined into a single subtree.
4. Both nodes are present in the same subtree: the branch is rejected.

The process is completed when it is determined (1) that all the $n$ nodes are in the recorded tree or (2) that a total of $n-1$ branches have been recorded.

Using the above algorithm, let us now construct the minimum tree for signal SOB of the Pedagac. Signal SOB goes to seven different locations: we shall therefore have eight nodes in our tree (one output and seven input), with 28 possible branches [(8) $(8-1) / 2=28]$. The seven destinations of signal SOB are SOBH gate 3 , SOBH gate 5 , ASSG gate 1, PQSG gate 1, ASCG gate 2, ASCG gate 4, and GMIB gate 3. In order to simplify the writing of the 28 possible branches, let us assign code numbers to the various packages as follows: $\mathrm{SOB}=1$; $\mathrm{SOBH}-3=2$, SOBH-5 $=3 ;$ ASSG-1 $=4 ;$ PQSG-1 $=5 ;$ ASCG-2 $=6 ;$ ASCG-4 $=7$; and GMIB-3 $=8$.


Fig. 23-16. Flow chart for forming minimum tree by the first algorithm.

The branches ( $b r$ ) and their associated lengths (len) are shown below. (The method of determining the lengths of the branches will be indicated in the following section.)

| 1-2 | 3 | $b r$ | len |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1-3 | 3 | 2-3 | 3 | $b r$ | len |  |  |  |  |  |  |  |
| 1-4 | 8 | 2-4 | 8 | 3-4 | 8 | $b r$ | len |  |  |  |  |  |
| 1-5 | 7 | 2-5 | 7 | 3-5 | 7 | 4-5 | 6 | $b r$ |  |  |  |  |
| 1-6 | 15 | 2-6 | 15 | 3-6 | 15 | 4-6 | 12 | 5-6 | 13 | br |  |  |
| 1-7 | 15 | 2-7 | 15 | 3-7 | 15 | 4-7 | 12 | 5-7 | 13 | 6-7 | 3 | $b r$ |
| 1-8 | 46 | 2-8 | 46 | 3-8 | 46 | 4-8 | 49 | 5-8 | 48 | 6-8 | 56 | 7-8 |

Ordering the list according to the length of the branches, we obtain

| $1-2$ | $\mathbf{3}$ | $3-5$ | $\mathbf{7}$ | $5-7$ | $\mathbf{1 3}$ | $1-8$ | 46 |
| ---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $1-3$ | $\mathbf{3}$ | $1-4$ | 8 | $1-6$ | 15 | $2-8$ | 46 |
| $2-3$ | $\mathbf{3}$ | $2-4$ | 8 | $1-7$ | 15 | $3-8$ | 46 |
| $6-7$ | 3 | $3-4$ | 8 | $2-6$ | 15 | $5-8$ | 48 |
| $4-5$ | 6 | $4-6$ | 12 | $2-7$ | 15 | $4-8$ | 49 |
| $1-5$ | 7 | $4-7$ | 12 | $3-6$ | 15 | $6-8$ | 56 |
| $2-5$ | 7 | $5-6$ | 13 | $3-7$ | 15 | $7-8$ | 56 |

Rather than go through a detailed description of the procedure to form this particular tree, we have elected to illustrate the procedure by means of a diagram (Fig. 23-17) which indicates the various steps

(1)

(5)

(3)

(6)

(4)

(7)

Fig. 23-17. Seven stages in the construction of the eight-node SOB tree (not to scale).
in forming the tree. Note that in the tree we have disregarded the branch from the output node of the generating package to the input node of the associated $F$-type package. (Recall that the connection is necessary whenever a signal is recirculated within a card for dynamic flip-flop.) Since this branch will always be equal to the shortest possible length, it will always be incorporated in the tree. In order to reduce the size of the tree and the associated computations, we have chosen to ignore this branch in the present treatment. However, in the next section such branches will be included when the wiring tables are formed. Note further that the branch from SOB to SOBH gate 3 is actually measured from the output of the type $F$ package to gate 3 of the SOBH package and that the branches SOB to PQSG gate 1 and SOB to GMIB gate 3 are made from the output of the SOBH package.


Fig. 23-18. Flow chart for forming minimum tree by the second algorithm.

The flow chart for the second algorithm is shown in Fig. 23-18, which is self-explanatory. In the first algorithm several disconnected subtrees can be formed, and these subtrees must be checked as each new branch is considered. In the second algorithm a single tree is formed. However, the branches which were previously rejected must be rechecked each time a new node is added to the tree.

## EXERCISES

(a) Prove that the maximum number of trees possible is $n^{n-2}$.
(b) Write a Pedagac program for the first algorithm (see Fig. 23-16).
(c) Form the minimum tree for signal SOB, using the second algorithm. Use the data given above for the example of the first algorithm.
(d) Write a Pedagac program for the second algorithm (see Fig. 23-18).
(e) Compare the minimum-tree problem with the traveling-salesman problem (see J. B. Kruskal's article mentioned in the Additional Topics, Sec. 23-6).

## 23-5. Wiring Table for the Pedagac

We are now in a position to develop the minimum wiring table for the Pedagac. Since the Pedagac requires about 5,000 wires, we shall consider here only a portion of the arithmetic unit, specifically that shown in Fig. 18-12.

Figure 23-13 shows the Pedagac rack, Fig. 23-19 the card locations within the rack. The bus shown in Fig. 23-13 serves as a common source, from which are tapped the various clock-phase signals, the ground connection, and the -10 -volt supply. Situated immediately below the bus (not shown in the figure) are the channels through which the wires are strung. For the Pedagac we shall assume that all wires are to run along horizontal and vertical paths. With the location of the cards and the distance between cards known, the formula for the length of wire required to connect two terminals is

Length of wire $=K_{1} \times$ (difference in row numbers)
$+K_{2} \times($ difference in column number $)+K_{3}$
where $K_{1}=$ distance between rows $=7 \mathrm{in}$.
$K_{2}=$ between columns $=1 \mathrm{in}$.
and $K_{3}$ is a constant compensating for differences in pin numbers. Since a wire may be required between pin 8 of one card and pin 47 of another, we assign a length of 5 in . (the card height) to $K_{3}$; but for connections to be made between pins of a single card we have arbitrarily assigned $K_{3}=3 \mathrm{in}$.

Referring to Fig. 18-12, we see that there are 33 output signals (direct or inverted). Accordingly we must form 33 separate, distinct trees for the outputs in this figure. The majority of these trees will be trivial, consisting of only two or three nodes. The wiring table, based on these 33 minimum trees, can take on several forms. First, we may form a table in which the branches of the various trees are ordered according to

|  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { SS1 } \\ & \text { SS2 } \end{aligned}$ | $\begin{array}{\|c\|} \hline \mathrm{CHO}^{-} \\ \mathrm{CH4} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { EWOG } \\ \text { EWIG } \end{array}$ | SIIR ${ }^{3}$ | ASPS 5 | $\begin{aligned} & \text { SOAH } \\ & \text { CIAS } \end{aligned}$ | $\begin{array}{\|ll\|} \hline \text { GASC } & 2 \\ \text { GJCS } & 2 \end{array}$ | $\begin{array}{ll} \alpha 1 \\ \alpha 2 & 2 \end{array}$ | $\alpha * 1$ | $\alpha^{11}$ |
| $\begin{aligned} & \text { SS3 } \\ & \text { SS4 } \\ & \hline \end{aligned}$ | $\left.\begin{array}{\|cc} \mathrm{CH} 5- \\ \mathrm{CH} 9 \end{array} \right\rvert\,$ | $\begin{array}{\|ll\|} \hline \text { RIBG } & \\ \text { ROBG } & 1 \\ \hline \end{array}$ | $\begin{array}{lll} \hline S 21 R & 2 \\ S 31 R & \\ \hline \end{array}$ | Slar ${ }^{3}$ | ASCG 5 | $\begin{array}{ll} \hline \text { GLMS } \\ \text { GLAS } \end{array}$ | $\begin{aligned} & \alpha 3 \\ & \alpha 4 \end{aligned}$ | $\alpha * 2 \quad 3$ | $\alpha^{\prime} 2$ |
| $\begin{array}{\|l\|} \hline \text { SS5 } \\ \text { SS6 } \end{array}$ | $\left\|\begin{array}{c} \mathrm{CH1O-} \\ \mathrm{CH14} \end{array}\right\|$ | $\begin{array}{\|l\|l\|} \hline \text { STBG } & 2 \\ \text { SPBG } & \end{array}$ | $\begin{array}{ll} S 41 R & 2 \\ S 51 R & \end{array}$ | $\begin{array}{ll} \text { S2AR } & 2 \\ S 3 A R & \end{array}$ | ASAI 4 | $\left\|\begin{array}{ll} \text { GLES } & \\ \text { GLIS } & 2 \end{array}\right\|$ | $\begin{array}{ll} \alpha 5 & \\ \alpha 6 & 2 \end{array}$ | $\alpha * 3$ | $\alpha^{\prime} 3$ |
| SS7 | $\left\|\begin{array}{c} \mathrm{CH15-} \\ \mathrm{CH19} \end{array}\right\|$ | RUBG 2 | $\begin{array}{ll\|} \hline S 61 R & \\ S 71 R & 2 \end{array}$ | $\begin{array}{ll} \hline \text { S4AR } & \\ \text { S6AR } & 2 \\ \hline \end{array}$ | ASBI | $\begin{aligned} & \text { GDCS } \\ & \text { GSCC } \end{aligned}$ | $\begin{aligned} & \alpha 7 \\ & \alpha 8 \end{aligned}$ | $\alpha * 4$ | $\alpha^{\prime} 4$ |
|  | $\left\|\begin{array}{c} \mathrm{CH}_{20-}^{-} \\ \mathrm{CH} 24^{1} \end{array}\right\|$ | IFOG <br> IFIG | $\begin{array}{ll\|} \hline S 81 R & \\ S 91 R & 2 \\ \hline \end{array}$ | S5AR 4 | IFCF | GMCS 3 | $\begin{array}{ll\|} \alpha 9 & 2 \\ \alpha 10 & 2 \\ \hline \end{array}$ | $\alpha * 5$ | $\alpha^{\prime} 5$ |
| $\begin{array}{\|l\|} \hline \text { SC1S } \\ \text { SC2S } \\ \hline \end{array}$ | $\begin{gathered} \mathrm{CH}_{2} \mathrm{CH}^{-}-1 \\ \hline \end{gathered}$ | FOOG 2 FOIG 2 | $\begin{array}{l\|l\|} \hline S I O 1 R & 2 \\ S I 1 / R & \\ \hline \end{array}$ | S7AR 2 <br> S8AR  | ASRF 4 | GPQT 3 | $\begin{array}{ll\|} \alpha 11 & 2 \\ \alpha 12 & \\ \hline \end{array}$ | $\alpha * 6$ | $\alpha ' 6$ |
| $\begin{aligned} & \text { SC3S } \\ & \text { SC4S } \end{aligned}$ | $\begin{array}{\|l\|} \hline \mathrm{CH}^{\mathrm{CH}}{ }^{\text {CH3 }} 1 \\ \hline \end{array}$ | FBȮG 3 | $\begin{array}{ll\|} \hline S 121 R & 2 \\ S 131 R & \end{array}$ | $\begin{array}{ll} \hline \text { S9AR } & 2 \\ \text { S10AR } & \\ \hline \end{array}$ | ASCF 3 | GPQC 4 | $\begin{array}{ll} \omega 1 & \\ \omega 2 & 2 \end{array}$ | $\alpha * 7$ | $\alpha^{1} 7$ |
| $\begin{aligned} & \text { SC5S } \\ & \text { SC6S } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { WRO- } \\ \text { WR4 } \end{array}$ | FBIG 4 | $\begin{aligned} & \hline S 141 R^{2} \\ & S_{151 R}{ }^{2} \end{aligned}$ | $\begin{array}{l\|l\|} \hline \text { SIIAR } & \\ \text { SI2AR } & \end{array}$ | $\begin{array}{l\|l\|} \hline \text { RZDGG } \\ \text { OFLH } \end{array}$ | GOEP 4 | $\begin{array}{ll} \omega 3 & 2 \\ \omega 4 & 2 \end{array}$ | $\alpha * 8$ | $\alpha^{\prime} 8$ |
| SC7S | $\left\|\begin{array}{c} \text { WR5- } \\ \text { WR9 } \end{array}\right\|$ |  | $\begin{array}{ll} S_{S 16 I R} \\ S 17 R \end{array}$ | $\begin{array}{ll} \hline \text { S13AR } & 2 \\ S 14 A R \end{array}$ | ASSG 3 |  | $\begin{array}{ll\|} \hline \omega 5 & 2 \\ \omega 6 & \\ \hline \end{array}$ | $\alpha * 9$ | $\alpha^{\prime} 9$ |
| $\begin{array}{\|c\|} \hline \text { SClaS- } \\ \text { SC5aS } \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline \text { WR10- } \\ \text { WR14 } \end{array}$ | BSPG 4 | Sl8IR 2 | $\begin{array}{\|l\|l\|} \hline \text { S15AR } \\ \text { S16AR } \end{array}$ | PQSG 3 | $\begin{array}{\|ll\|} \hline \text { GPQS } & 1 \\ \text { GDRI } & 1 \\ \hline \text { GDDS } \end{array}$ | IRSG 1 | $\alpha * 10 \quad 3$ | $\alpha^{\prime} 103$ |
| $\begin{array}{ll\|} \hline \text { Scgas } \\ \text { MCIaS } \\ \text { MCaS } \end{array}$ | $\left\|\begin{array}{c} \text { WR 15- } \\ \text { WR19 } \end{array}\right\|$ | BU1 |  | $\begin{array}{ll\|} \hline S 17 A R & \\ S_{18 A R} & \\ \hline \end{array}$ | SPDG 5 | SHAI 2 |  | $\alpha * 113$ | $\alpha^{\prime} 11{ }^{3}$ |
| MCCL ${ }^{3}$ | $\left.\begin{array}{\|c}  \\ \text { WR20- } \\ \text { WR } 24^{1} \end{array} \right\rvert\,$ | $\begin{array}{\|ll\|} \hline \text { BU2 } & 2 \\ \text { BU3 } & 2 \end{array}$ |  | $\begin{array}{ll} \hline S 19 A R \\ S 20 A R \end{array}$ | SOBH 5 | SHA2 3 | munno 1 | $\alpha * 12$ 3 | $\alpha^{\prime} 123$ |
| MC1S 3 | $\begin{gathered} \text { WR } 25-1 \\ \text { WR29 } \end{gathered}$ | $\begin{array}{ll} \hline \text { BUA } \\ \text { BU5. } \end{array}$ |  | $\begin{aligned} & \text { S21AR }_{2} \\ & S_{2} 2 A R \end{aligned}$ | OCCF 2 | SHA3 4 |  |  | $\begin{aligned} & \alpha^{\prime} 1 \mathrm{a}-1 \\ & \alpha^{\prime} 5 \mathrm{a} \\ & \hline \end{aligned}$ |
| $\begin{array}{lr} \hline \text { MC2S } & 2 \\ \text { MC4S } & \\ \hline \end{array}$ | $\begin{array}{l\|l\|} \hline \text { WR30 } \\ \text { WR31 } \end{array}$ | BU6 2 <br> BU7  |  | ISPS 4 | OCRF 3 | SHA4 |  |  | $\begin{aligned} & \alpha^{\prime} 6 a^{\prime} \\ & \alpha^{\prime} 10 \mathrm{a} \end{aligned}$ |
| $\begin{array}{ll} \hline \text { MC8S } & 2 \\ \text { MC16S } \end{array}$ | $\begin{array}{\|c\|} \hline \text { REO- } \\ \hline \text { RE4 } \end{array}$ | $\begin{array}{ll} \hline \text { BU8 } \\ \text { BU9 } \end{array}$ |  | S1ER 4 | MUSG 3 | SHA5 3 |  |  | $\begin{aligned} & \alpha^{\prime} 11 \mathrm{a} \\ & \alpha^{\prime \prime} 12 a^{1} \end{aligned}$ |
| $\begin{array}{\|l\|} \hline T^{1} \\ T^{12} \\ T^{19} \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline \text { RE5- } \\ \text { RE9 } \end{array}$ | $\begin{array}{lll} \text { BUlO }^{\text {BUII }} & 2 \end{array}$ |  | $\begin{array}{ll} \operatorname{S2ER}^{S 2} & 2 \\ S 3 E R & \end{array}$ |  |  |  |  | $\begin{array}{ll\|} \hline \text { JCLG } \\ 1 C S G & 1 \\ \text { STCG } \\ \hline \end{array}$ |
| $\begin{aligned} & \text { UTSG } \\ & \text { UClS } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { RE10-14 } \\ \text { RE14 } \end{array}$ | $\begin{array}{\|l\|l\|} \hline \text { BU12 } & \\ B_{13} & \end{array}$ |  | S4ER  <br> S5ER  <br> 2  |  |  | $\begin{aligned} & 8939 \\ & 0.80 甘 \\ & \hline \end{aligned}$ |  |  |
| $\begin{aligned} & \text { UC2S } \\ & \text { UC4S } \end{aligned}$ | $\begin{gathered} \text { RE15-1 } \\ \text { RE19 } \end{gathered}$ | $\begin{array}{l\|} \hline \text { BU14 } \\ \text { BU15 } \end{array}$ |  | S6ER 2 <br> $S 7 E R$  |  |  |  |  |  |
| $\begin{aligned} & \hline \text { UC8S } \\ & \text { UC16S } \end{aligned}$ | $\begin{gathered} \text { RE20-1 } \\ \text { RE24 } \end{gathered}$ | $\begin{array}{ll} B_{B U 16} \\ B_{1} & 2 \end{array}$ |  | S8ER  <br> $S 9 \mathrm{ER}$ 2 |  | $\begin{aligned} & \text { F1SG } \\ & \text { F2SG } \end{aligned}$ |  |  |  |
| $\begin{array}{\|ll\|} \hline \begin{array}{lll} \text { UClaS } & \\ T_{22}^{\text {UCBaS }} & 1 \\ \hline \end{array}{ }^{2} \\ \hline \end{array}$ | $\begin{array}{\|c\|} \text { RE25- } \\ \text { RE29 } \end{array}$ | $\begin{array}{\|l\|l\|} \hline \text { BU18 }^{2} \\ \text { BU19 }^{2} \\ \hline \end{array}$ |  | $\begin{aligned} & \hline \text { S10ER } \\ & \text { SIIER } \\ & \hline \end{aligned}$ |  | F3SG 4 |  |  |  |
| $T_{0}-T_{4} \quad 1$ | $\begin{array}{l\|l\|} \hline \text { RE30 } \\ \text { RE31 } \\ \hline \end{array}$ |  |  | $\begin{aligned} & \hline \text { S12ER }^{2} \\ & \text { S13ER } \end{aligned}$ |  | IFIG |  |  |  |
| $\begin{array}{\|ll\|} \hline T_{5} & 1 \\ T_{18} & 1 \\ \hline T_{19} \cdot T_{21} & 1 \\ \hline \end{array}$ | $\begin{array}{l\|l\|} \hline \mathrm{MO1O}^{-} \\ \text {MO9 } & 1 \\ \hline \end{array}$ |  |  | $\begin{aligned} & \hline \text { S14ER }_{2} \\ & \text { S15ER }^{2} \end{aligned}$ |  | IF2G 5 |  |  |  |
| $\begin{array}{ll} \hline T_{0.18}^{1} & { }^{2} \\ T_{1.22} & \end{array}$ | $\begin{aligned} & \text { MO5. } \\ & \text { MO8 i } \end{aligned}$ |  |  | $\begin{aligned} & \text { S16ER } \\ & \text { Sl }^{2} 7 E R \end{aligned}$ |  | $\begin{aligned} & \mathrm{IF3G} \\ & \mathrm{I}^{\prime} \mathrm{F} 1 \mathrm{G} \end{aligned}$ |  |  |  |
| $\begin{array}{\|ll\|} \hline T_{1.18} & { }^{2} \\ T_{1.19} & \\ \hline \end{array}$ | GM0 $\chi^{3}$ |  |  | S18ER 4 |  | I*F1G 5 |  |  |  |
| $\begin{array}{\|ll\|} \hline T_{1.17} & 2 \\ T_{0.22} & \\ \hline \end{array}$ | GMIB 3 |  |  |  |  | ISFG 5 |  |  |  |

Fig. 23-19. Location of cards in the Pedagac rack shown in Fig. 23-13. Numbers at tops of cards indicate their types. Packages for each card are as indicated.

Table 23-2. Schematic Wiring Table for Fig. 18-12 $\dagger$

|  | 1 | 2 | 3 | 4 |  | 1 | 2 | 3 | 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 4-A-25 | $\overline{\mathrm{SOB}}$ | 5-B-4 | 13 | 41 | 6-A-31 | $\overline{\text { ASP }}$ | 6-B-12 | 6 |
| 2 | 5-B-4 | SOB | 5-I-8 | 12 | 42 | 6-A-33 | ASP | 6-C-4 | 7 |
| 3 | 5-B-4 | $\overline{\mathrm{SOB}}$ | 5-B-16 | 3 | 43 | $6-B-12$ | $\overline{\text { ASP }}$ | 6-C-7 | 6 |
| 4 | $5-B-10$ | SOB | 5-I-2 | 12 | 44 | $6-B-17$ | $P 1$ | 6-B-26 | 3 |
| 5 | $5-B-10$ | SOB | 5-B-22 | 3 | 45 | 6-B-22 | P1 | 6-B-24 | 3 |
| 6 | 5-H-4 | OFR | 6-C-21 | 17 | 46 | 6-B-22 | $P 1$ | 6-C-3 | 6 |
| 7 | 5-H-4 | OFR | 5-J-10 | 7 | 47 | 6-C-4 | ASP | 6-C-24 | 3 |
| 8 | 5-H-10 | SEZ | 5-H-21 | 3 | 48 | 6-C-7 | $\overline{\text { ASP }}$ | 6-C-28 | 3 |
| 9 | $5-H-15$ | SEZ | 5-I-14 | 6 | 49 | 6-C-10 | P2 | 6-C-21 | 3 |
| 10 | 5-H-16 | SEZ | 5-H-18 | 3 | 50 | 6-C-16 | P2 | 6-C-18 | 3 |
| 11 | 5-H-30 | OF | 5-H-40 | 3 | 51 | 6-C-21 | $P 2$ | 6-C-23 | 3 |
| 12 | 5-H-34 | $\overline{\mathrm{OF}}$ | 5-N-4 | 11 | 52 | 6-C-24 | ASP | 6-D-4 | 6 |
| 13 | 5-H-35 | OF | 5-H-38 | 3 | 53 | 6-C-28 | $\overline{\text { ASP }}$ | 6-D-7 | 6 |
| 14 | 5-H-35 | OF | 5-M-4 | 10 | 54 | 6-C-30 | P3 | 6-C-40 | 3 |
| 15 | 5-I-8 | $\overline{\mathrm{SOB}}$ | 5-L-31 | 8 | 55 | 6-C-35 | P3 | 6-C-38 | 3 |
| 16 | 5-I-8 | $\overline{\mathrm{SOB}}$ | 5-J-8 | 6 | 56 | 6-C-40 | P3 | 6-D-3 | 6 |
| 17 | 5-I-14 | SEZ | 5-J-15 | 6 | 57 | $6-D-4$ | ASP | 6-D-24 | 3 |
| 18 | 5-I-21 | SAS | 5-L-2 | 8 | 58 | 6-D-7 | $\overline{\text { ASP }}$ | 6-D-28 | 3 |
| 19 | 5-J-2 | SOB | 5-L-33 | 7 | 59 | 6-D-10 | $P 4$ | 6-D-21 | 3 |
| 20 | 5-J-2 | SOB | 5-I-2 | 6 | 60 | $6-D-16$ | $P 4$ | $6-D-18$ | 3 |
| 21 | 5-J-4 | $\overline{\mathrm{OFR}}$ | 6-C-19 | 19 | 61 | $6-D-20$ | $P 4$ | 6-E-10 | 6 |
| 22 | 5-J-4 | $\overline{\mathrm{OFR}}$ | 5-K-12 | 6 | 62 | 6-D-21 | P4 | $6-E-15$ | 6 |
| 23 | 5-J-10 | OFR | 5-K-18 | 6 | 63 | 6-D-23 | P5 | 6-E-32 | 6 |
| 24 | 5-J-15 | $\overline{\text { SEZ }}$ | 5-K-24 | 6 | 64 | 6-D-24 | ASP | 6-E-5 | 6 |
| 25 | 5-J-22 | SQP | 5-L-8 | 7 | 65 | 6-D-28 | $\overline{\mathrm{ASP}}$ | $6-E-17$ | 6 |
| 26 | $5-K-11$ | SOD | 5-K-37 | 3 | 66 | 6-D-30 | P6 | 6-D-40 | 3 |
| 27 | 5-K-11 | SOD | 5-K-27 | 3 | 67 | 6-D-35 | P6 | 6-D-38 | 3 |
| 28 | $5-K-16$ | $\overline{\mathrm{SOD}}$ | 5-K-36 | 3 | 68 | 6-D-40 | P6 | 6-F-3 | 7 |
| 29 | 5-K-33 | SOD | 6-X-4 | 25 | 69 | 6-E-4 | ACC | 6-M-40 | 13 |
| 30 | 5-K-33 | SOD | 5-K-35 | 3 | 70 | 6-E-5 | ASP | $6-E-10$ | 3 |
| 31 | 5-L-15 | SOB | 5-L-27 | 3 | 71 | 6-E-7 | P5 | 6-E-30 | 3 |
| 32 | 5-L-27 | SOB | 5-L-37 | 3 | 72 | $6-E-10$ | ASP | 6-E-15 | 3 |
| 33 | 5-L-33 | SOB | 5-L-35 | 3 | 73 | 6-E-15 | ASP | 6-F-4 | 6 |
| 34 | 5-L-33 | SOB | 9-Y-13 | 46 | 74 | 6-E-17 | $\overline{\text { ASP }}$ | 6-F-7 | 6 |
| 35 | 5-M-4 | ACC | 6-M-40 | 12 | 75 | 6-E-22 | P5 | $6-E-32$ | 3 |
| 36 | 5-M-4 | ACC | 5-N-4 | 6 | 76 | 6-F-4 | ASP | 6-F-24 | 3 |
| 37 | 5-M-4 | OF | 5-M-10 | 3 | 77 | 6-F-7 | $\overline{\text { ASP }}$ | 6-F-28 | 3 |
| 38 | 5-M-10 | OF | 5-N-16 | 6 | 78 | 6-F-10 | P7 | 6-F-21 | 3 |
| 39 | 5-N-4 | ACC | $5-N-10$ | 6 | 79 | 6-F-16 | P7 | 6-F-18 | 3 |
| 40 | $5-N-16$ | $\overline{\mathrm{ACC}}$ | 6-M-39 | 13 | 80 | 6-F-21 | P7 | 6-F-23 | 3 |

Table 23-2. Schematic Wiring Table for Fig. 18-12 $\dagger$ (Continued)

|  | 1 | 2 | 3 | 4 |  | 1 | 2 | 3 | 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 81 | 6-F-24 | ASP | 6-G-4 | 6 | 118 | 6-J-10 | P15 | 6-J-21 | 3 |
| 82 | 6-F-28 | $\overline{\text { ASP }}$ | 6-G-7 | 6 | 119 | 6-J-16 | P15 | 6-J-18 | 3 |
| 83 | 6-F-30 | P8 | 6-F-40 | 3 | 120 | 6-J-21 | P15 | 6-J-23 | 3 |
| 84 | 6-F-35 | $P 8$ | 6-F-37 | 3 | 121 | 6-J-24 | ASP | 6-K-4 | 6 |
| 85 | 6-F-40 | $P 8$ | 6-G-3 | 6 | 122 | 6-J-28 | $\overline{\text { ASP }}$ | 6-K-7 | 6 |
| 86 | 6-G-4 | ASP | 6-G-24 | 3 | 123 | 6-J-30 | P16 | 6-J-40 | 3 |
| 87 | 6-G-7 | $\overline{\text { ASP }}$ | 6-G-28 | 3 | 124 | 6-J-35 | P16 | 6-J-37 | 3 |
| 88 | 6-G-10 | $P 9$ | 6-G-21 | 3 | 125 | 6-J-40 | P16 | 6-K-3 | 6 |
| 89 | 6-G-16 | $P 9$ | 6-G-18 | 3 | 126 | 6-K-4 | ASP | 6-K-24 | 3 |
| 90 | 6-G-21 | $P 9$ | 6-G-23 | 3 | 127 | 6-K-7 | $\overline{\text { ASP }}$ | 6-K-28 | 3 |
| 91 | 6-G-24 | ASP | 6-H-4 | 6 | 128 | 6-K-10 | ${ }_{P 17}$ | 6-K-21 | 3 |
| 92 | 6-G-28 | $\overline{\text { ASP }}$ | 6-H-7 | 6 | 129 | 6-K-16 | P17 | 6-K-18 | 3 |
| 93 | 6-G-30 | P10 | 6-G-40 | 3 | 130 | 6-K-21 | P17 | 6-K-23 | 3 |
| 94 | 6-G-35 | P10 | 6-G-37 | 3 | 131 | 6-K-24 | ASP | 6-L-4 | 6 |
| 95 | 6-G-40 | P10 | 6-H-3 | 6 | 132 | 6-K-28 | $\overline{\text { ASP }}$ | 6-L-7 | 6 |
| 96 | 6-H-4 | ASP | 6-H-24 | 3 | 133 | 6-K-30 | ${ }^{P} 18$ | 6-K-40 | 3 |
| 97 | 6-H-7 | $\overline{\text { ASP }}$ | 6-H-28 | 3 | 134 | 6-K-35 | P18 | 6-K-37 | 3 |
| 98 | $6-\mathrm{H}-10$ | P11 | 6-H-21 | 3 | 135 | 6-K-40 | P18 | 6-L-3 | 6 |
| 99 | 6-H-16 | P11 | 6-H-18 | 3 | 136 | 6-L-4 | ASP | 6-L-24 | 3 |
| 100 | 6-H-21 | P11 | 6-H-23 | 3 | 137 | 6-L-7 | $\overline{\text { ASP }}$ | 6-L-28 | 3 |
| 101 | 6-H-24 | ASP | 6-I-4 | 6 | 138 | 6-L-10 | P19 | 6-L-21 | 3 |
| 102 | 6-H-28 | $\overline{\text { ASP }}$ | 6-I-7 | 6 | 139 | 6-L-16 | P19 | 6-L-18 | 3 |
| 103 | 6-H-30 | P12 | 6-H-40 | 3 | 140 | 6-L-21 | P19 | 6-L-23 | 3 |
| 104 | 6-H-35 | P12 | 6-H-37 | 3 | 141 | 6-L-24 | ASP | 6-M-4 | 6 |
| 105 | 6-H-40 | P12 | 6-I-3 | 6 | 142 | 6-L-28 | $\overline{\text { ASP }}$ | 6-M-7 | 6 |
| 106 | 6-I-4 | ASP | 6-I-24 | 3 | 143 | 6-L-30 | P20 | 6-L-40 | 3 |
| 107 | 6-I-7 | $\overline{\text { ASP }}$ | 6-I-28 | 3 | 144 | 6-L-35 | P20 | 6-L-37 |  |
| 108 | 6-I-10 | P13 | 6-I-21 | 3 | 145 | 6-L-40 | P20 | 6-M-3 | 6 |
| 109 | 6-I-16 | $P 13$ | 6-I-18 | 3 | 146 | 6-M-4 | ASP | 6-M-24 | 3 |
| 110 | 6-I-21 | P13 | 6-I-23 | 3 | 147 | 6-M-7 | $\overline{\text { ASP }}$ | 6-M-28 | 3 |
| 111 | 6-I-24 | ASP | 6-J-4 | 6 | 148 | 6-M-10 | P21 | 6-M-21 | 3 |
| 112 | 6-I-28 | $\overline{\text { ASP }}$ | 6-J-7 | 6 | 149 | 6-M-16 | $P 21$ | 6-M-18 | 3 |
| 113 | 6-I-30 | P14 | 6-J-40 | 6 | 150 | 6-M-21 | P21 | 6-M-23 | 3 |
| 114 | 6-I-35 | P14 | 6-I-37 | 3 | 151 | 6-M-24 | ASP | 6-N-4 | 6 |
| 115 | 6-I-40 | P14 | 6-J-3 | 6 | 152 | 6-M-28 | $\overline{\mathrm{ASP}}$ | 6-N-7 | 6 |
| 116 | 6-J-4 | ASP | 6-J-24 | 3 | 153 | 6-M-30 | P22 | 6-M-40 | 3 |
| 117 | 6-J-7 | $\overline{\mathrm{ASP}}$ | 6-J-28 | 3 | 154 | 6-M-35 | P22 | 6-M-37 | 3 |

$\dagger$ Column 1 indicates row, column, and pin number of first node of the branch. Column 2 indicates name of tree of which the branch is part. Column 3 indicates row, column, and pin number of second node of the branch. Column 4 indicates the length of the branch.
node locations, i.e., ordered by rack, row, column, and pin number. This type of table is referred to as the schematic wiring table; Table 23-2 is the schematic wiring table for the outputs of Fig. 18-12. This is the table to be used by the wiring technicians. A second type of table, the alphabetic table, is formed directly from the minimum trees, by ordering the signal names alphabetically. Table 23-3 is a portion of the alphabetic table for Fig. 18-12.

Table 23-3. Portion of Alphabetic Table for Fig. 18-12

| Signal name | Origin |  |
| :---: | :---: | :---: |
| ACC | Destination |  |
| ACC | $6-M-40$ | $5-M-4$ |
| ACC | $5-M-4$ | $5-N-4$ |
| ACC | $6-N-4$ | $5-N-10$ |
| ACC | $6-M-30$ | $6-E-4$ |
|  |  | $5-N-16$ |
| SOB | $5-L-33$ | $5-L-35$ |
| SOB | $5-L-33$ | $9-Y-13$ |
| SOB | $5-L-37$ | $5-L-27$ |
| SOB | $5-L-27$ | $5-L-15$ |
| SOB | $5-L-33$ | $5-J-2$ |
| SOB | $5-J-2$ | $5-I-2$ |
| SOB | $5-I-2$ | $5-B-10$ |
| SOB | $5-B-10$ | $5-B-22$ |

## EXERCISES

(a) Complete the alphabetic table for Fig. 18-12.
(b) Form the trees for Fig. 18-11, using the first algorithm.
(c) Form the trees for Fig. 18-11, using the second algorithm.
(d) Form the schematic wiring table for Fig. 18-11.
(e) Form the alphabetic table for Fig. 18-11.

## 23-6. Additional Topics

## a. Articles Concerning Wiring Diagrams

Cayley, A.: A Theorem on Trees, "Mathematical Papers," vol. 13, pp. 26-28, Cambridge University Press, London, 1897.
Kruskal, J. B., Jr.: On the Shortest Spanning Subtree of a Graph and the Traveling Salesman Problem, Proc. Am. Math. Soc., vol. 7, pp. 48-50, 1956.
Loberman, H., and A. Weinberger: Formal Procedures for Connecting Terminals with a Minimum Total Wire Length, J. Assoc. Computing Machinery, vol. 4, no. 4, pp. 428-437, October, 1957.
Weinberger, A., and H. Loberman: Symbolic Designations for Electrical Connections, J. Assoc. Computing Machinery, vol. 4, no. 4, pp. 420-427, October, 1957.
b. With the information given in Chaps. 18 and 23 assign clock-phase signals to all the and gates of the Pedagac packages.
c. Prepare complete schematic and/or alphabetic wiring tables for the Pedagac.

## APPENDIX

Table A-1. Arithmetic-unit Externally Generated Operations Signals (See Fig. 18-10)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $A_{1}$ | $\begin{aligned} & {[\alpha 1] \cdot\left[T^{2}\right] \cdot\left[T_{5}\right]} \\ & +\left[\bar{A}_{1 d}\right] \cdot\left[T^{2}\right] \\ & \cdot\left[\bar{T}_{5}\right] \end{aligned}$ | As generated | $\begin{aligned} & \text { GSIC } \\ & \text { SHA1 } \\ & \text { SHA2 } \\ & \text { SHA3 } \\ & \text { SHA4 } \\ & \text { SHA5 } \end{aligned}$ | $\begin{aligned} & \overline{1}_{1} \\ & \overline{2}_{d} \\ & 2_{d}, \overline{3}_{d} \\ & 2_{d,}, \overline{4}_{d} \\ & 2_{d}, \overline{5}_{d} \\ & 2_{d} \end{aligned}$ | SHA1 | Least significant bit of shift count-down |
| $A_{2}$ | $\begin{gathered} {\left[\alpha_{2}\right] \cdot\left[T^{2}\right] \cdot\left[T_{5}\right]} \\ +\left[T^{2}\right] \cdot\left[\bar{T}_{5}\right] \\ \cdot\left[A_{1 d} \cdot A 2_{d}\right. \\ \left.+\vec{A}_{1 d} \cdot \vec{A}_{2 d}\right] \end{gathered}$ | As generated | $\begin{array}{\|l} \text { GSIC } \\ \text { SHA2 } \\ \text { SHA3 } \\ \text { SHA4 } \\ \text { SHA5 } \end{array}$ | $\begin{aligned} & \bar{u}_{d} \\ & 2_{d}, \overline{3}_{d} \\ & 3_{d}, \overline{4}_{d} \\ & 3_{d}, \overline{5}_{d} \\ & 3_{d} \end{aligned}$ | SHA2 | Fourth significant bit of shift count-down |
| $A_{3}$ | $\left\lvert\, \begin{gathered} {[\mathrm{c} 3] \cdot\left[T^{2}\right] \cdot\left[T_{5}\right]} \\ +\left[T^{2}\right] \cdot\left[\bar{T}_{5}\right] \\ \cdot\left[A_{1 d} \cdot A_{3 d}\right. \\ +A_{2 d} \cdot A_{3 d} \\ +\bar{A}_{1 d} \cdot \bar{A}_{2 d} \\ \left.\cdot \bar{A}_{3 d}\right] \end{gathered}\right.$ | As generated | $\begin{aligned} & \text { GSIC } \\ & \text { SHA3 } \\ & \text { SHA4 } \end{aligned}$ | $\left\lvert\, \begin{aligned} & \overline{1} \\ & 2_{d}, 3_{d}, \\ & \frac{4_{d}}{d} \\ & 4_{d} \end{aligned}\right.$ | SHA3 | Third significant bit of shift count-down |
| A4 | $\begin{aligned} & {[\alpha 4] \cdot\left[T^{2}\right] \cdot\left[T_{5}\right]} \\ & +\left[T^{2}\right] \cdot\left[\bar{T}_{5}\right] \\ & \cdot\left[A_{1 d} \cdot A_{4 d}\right. \\ & +A_{2 d} \cdot A_{4 d} \\ & +A_{3 d} \cdot A_{4 d} \\ & \left.+\bar{A}_{1 d} \cdot \bar{A}_{2 d} \cdot A_{5 d}\right] \end{aligned}$ | As generated | GSIC <br> SHA4 | $\begin{aligned} & \overline{1} \\ & 2_{d,}, 3_{d}, \\ & \mathbf{4}_{d} \end{aligned}$ | SHA4 | Second significant bit of shift count-down |
| $A_{5}$ | $\begin{gathered} {[\alpha 5] \cdot\left[T^{2}\right] \cdot\left[T_{5}\right]} \\ +\left[T^{2}\right] \cdot\left[\bar{T}_{5}\right] \\ \cdot\left[A_{5 d}\right] \cdot\left[A_{1 d}\right] \\ +\left[A_{2 d}\right] \end{gathered}$ | As generated | $\begin{aligned} & \text { GSIC } \\ & \text { SHA4 } \\ & \text { SHA5 } \end{aligned}$ | $\left\lvert\, \begin{aligned} & \overline{1} \\ & 5_{d} \\ & 2_{d}, 3_{d} \end{aligned}\right.$ | SHA5 | Most significant bit of shift count-down |
| ADD | 53 D | As generated | $\begin{array}{\|l\|} \hline \text { ASCG } \\ \text { IF2G } \\ \text { (GAS } \end{array}$ | $\begin{aligned} & 3,4 \\ & 1 \\ & \text { SC } 1 \text { ) } \end{aligned}$ | (53D) | Addition decode signal |

Table A-1. Arithmetic-unit Externally Generated Operations
Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| ASC | $\begin{aligned} & {[53 D] \cdot\left[\bar{T}_{0}\right]} \\ & \quad+[54 D] \cdot\left[\bar{T}_{0}\right] \end{aligned}$ | $\bar{T}_{0}$ | $\begin{aligned} & \text { ASSG } \\ & \text { SOBH } \end{aligned}$ | $\begin{aligned} & 1,2 \\ & 1, \overline{3} \end{aligned}$ | GASC | Add-subtract control signal, on during addition and subtraction instruction |
| CLS | 50 D | As generated | $\begin{aligned} & \text { ASBI } \\ & \text { SOBH } \\ & \text { F3SG } \end{aligned}$ | $\left\lvert\, \begin{aligned} & \overline{2} \\ & 4 \\ & 2 \end{aligned}\right.$ | (50D) | Clear instruction control signal; this signal inhibits contents of accumulator from entering adder, thereby clearing accumulator; it also ensures that sign of accumulator is positive after clearing |
| DCS | $\begin{aligned} & {[41 D] \cdot\left[\overline{T^{19}}\right] \cdot\left[T_{1}\right]} \\ & \quad+\left[\mathrm{DCS}_{d}\right] \cdot\left[\tilde{T}_{19}\right] \end{aligned}$ | $T_{1-18}^{1-18}$ | $\begin{aligned} & \text { ASAI } \\ & \text { ASBI } \\ & \text { GDCS } \end{aligned}$ | $\begin{array}{\|l} 2 \\ 3 \\ 2_{d} \end{array}$ | GDCS | Division control signal |
| DDS | $[41 \mathrm{D}] \cdot\left[\overline{T^{19}}\right]$ | $T^{1-18}$ | ASCG SPDG S1ER S18ER ISPS | $\begin{aligned} & \frac{\overline{1}}{\overline{1}} \overline{2}, \overline{3}, \\ & 4, \overline{5} \\ & 1,2,3, \\ & 4,5 \\ & 3 \\ & 1,3, \overline{4} \\ & 3 \end{aligned}$ | GDDS | Division decode signal |
| DRI | $[41 \mathrm{D}] \cdot\left[T_{21}\right]$ | $T_{21}$ | S1ER | $\overline{4}$ | GDRI | Division recirculation inhibit signal; it kills recirculation in S1 of ier |
| JCS | $\begin{aligned} & {[43 D] \cdot[\overline{\mathrm{SOB}}]} \\ & \cdot\left[T_{22}\right] \cdot[F 1] \\ & +[44 D] \cdot\left[T_{22}\right] \\ & \cdot[F 1] \end{aligned}$ | $F 1, T_{22}$ | $\begin{aligned} & \text { JCLG } \\ & \text { 1CSG } \end{aligned}$ | $\frac{1}{1}$ | GJCS | Jump control signal |
| LAS | $\begin{aligned} & {[72 D] \cdot\left[T_{1}\right]} \\ & \quad+\left[\mathrm{LAS}_{d}\right] \cdot\left[\bar{T}_{19}\right] \end{aligned}$ | $T_{1-18}$ | $\begin{aligned} & \text { S1AR } \\ & \text { GLAS } \end{aligned}$ | $\begin{aligned} & \overline{1} \\ & 2_{d} \end{aligned}$ | GLAS | Logical-add signal |
| LDS | $\begin{aligned} & 71 D+72 D \\ & +73 D+74 D \end{aligned}$ | As generated | $\begin{aligned} & \text { ITCF } \\ & \text { CIAS } \\ & \text { S1AR } \\ & \text { IF2G } \end{aligned}$ | $\begin{array}{\|l} 3 \\ 1, \overline{2} \\ 2 \\ 3 \end{array}$ | GLDS | Logical decode signal; this signal is on when any of the four logical instructions is present |

Table A-1. Arithmetic-unit Externally Generated Operations Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| LES | $\begin{aligned} & {[73 D] \cdot\left[T_{1}\right]} \\ & \quad+\left[\mathrm{LES}_{d}\right] \cdot\left[\bar{T}_{19}\right] \end{aligned}$ | $T_{1-18}$ | ITCF | $\overline{3}$ | GLES | Logical-equivalence signal |
|  |  |  | S1AR | $\overline{2}$ |  |  |
|  |  |  | GLES | ${ }^{2}{ }_{\text {d }}$ |  |  |
| LIS | $\begin{aligned} & {[74 D] \cdot\left[T_{1}\right]} \\ & \quad+\left[\mathrm{LIS}_{d}\right] \cdot\left[\hat{T}_{19}\right] \end{aligned}$ | $T_{1-18}$ | ITCF | $\overline{3}$ | GLIS | Logical-inequivalence signal |
|  |  |  | CIAS | $\overline{1}$ |  |  |
|  |  |  | S1AR | $\overline{2}$ |  |  |
|  |  |  | GLIS | $\underline{2 d}_{\text {d }}$ |  |  |
| LMS | $\begin{aligned} & {[71 D] \cdot\left[T_{1}\right]} \\ & \quad+\left[\mathrm{LMS}_{d}\right] \cdot\left[\bar{T}_{19}\right] \end{aligned}$ | $T_{1-18}$ | CIAS | $\overline{1}$ | GLMS | Logical-multiply signal |
|  |  |  | S1AR | $\overline{1}$ |  |  |
|  |  |  | GLMS | ${ }^{2}{ }_{\text {d }}$ |  |  |
| MCS | $\begin{aligned} & {[42 D] \cdot\left[\overline{T^{19}}\right] \cdot\left[T_{1}\right]} \\ & +[32 D] \cdot\left[T^{19}\right] \\ & \cdot\left[T_{1}\right] \\ & +\left[\mathrm{MCS}_{d}\right] \cdot\left[\bar{T}_{19}\right] \end{aligned}$ | $T_{1-18}^{1-18}$ | ASAI | 3, 4 | GMCS | Multiply control signal |
|  |  |  | ASBI | 4 |  |  |
|  |  |  | S1ER | 1 |  |  |
|  |  |  | ISPS | 1 |  |  |
|  |  |  | GMCS | $3_{\text {d }}$ |  |  |
| MDS | $32 D+42 D$ | As generated | ASCG | 5 | GMDS | Multiplication decode signal |
|  |  |  | ASAI | $\overline{1}$ |  |  |
|  |  |  | ASPS | 5 |  |  |
|  |  |  | MUSG | 1,2 |  |  |
|  |  |  | S1ER | 2 |  |  |
|  |  |  | ISPS | 2 |  |  |
| MMI | $[42 D] \cdot\left[T^{19}\right]$ | $T^{19}$ | ASPS | $\overline{1}$ | GMMI | Major-multiplication inhibit signal; prevents contents of accumulator from recirculating during 19th minor cycle |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| OEP | $[\overline{\mathrm{PQS}}] \cdot\left[T^{1}\right] \cdot\left[T_{22}\right]$ | $T_{22}$ at end of operation | SOAH |  | GOEP | Operation-ending pulse |
|  | $\cdot[F 2]+[\mathrm{PQS}]$ |  | SOBH | 1, $2, \overline{5}$ |  |  |
|  | $\cdot\left[T^{19}\right] \cdot\left[T_{22}\right]$ |  | PQSG |  |  |  |
|  | $\cdot[F 2]+[\mathrm{SHS}]$ |  | MCCL | $22_{d}, 3_{d}$ |  |  |
|  | $\cdot\left[T^{2}\right] \cdot\left[T_{22}\right] \cdot[F 3]$ |  | F2SG |  |  |  |
|  | $+[\overline{\mathrm{SHS}}] \cdot\left[T^{1}\right]$ |  | F3SG |  |  |  |
|  | - $\left[T_{22}\right] \cdot[F 3]$ |  | I*F1G | $3_{\text {d }}, 4_{\text {d }}$ |  |  |
|  | $[32 D] \cdot\left[T^{19}\right] \cdot\left[T_{1}\right]$ | $T_{1-18}^{1-18}$ | S1IR | 1, 2, $\overline{3}$ | GPQC | Product-quotien control signal |
| PQC | +[41D] $\cdot\left[{ }^{\left(T^{19}\right.}\right]$ |  | S2IR | 1, $\overline{2}$ |  |  |
|  | - $\left[T_{1}\right]+[42 D]$ |  | S3IR | 1, $\overline{2}$ |  |  |
|  | $\cdot\left[\overline{T^{19}}\right] \cdot\left[T_{1}\right]$ |  | GPQC |  |  |  |
|  | $+\left[\mathrm{PQC}_{d}\right] \cdot\left[\bar{T}_{19}\right]$ |  |  |  |  |  |

Table A-1. Arithmetic-unit Externally Generated Operations Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| PQS | $32 D+41 D+42 D$ | As generated | PQSG <br> SOBH <br> IF2G <br> GOEP <br> ASBI | $\begin{aligned} & 1, \frac{4}{2}, 3 \\ & 2, \frac{3}{3} \\ & \frac{4}{1}, 2 \\ & \frac{1}{1} \end{aligned}$ | GPQS | Product-quotient sign read-in; gates SOA and SOB into prod-uct-quotient sign generator |
| PQT | $\begin{aligned} & {[32 D] \cdot\left[T^{19}\right] \cdot\left[T_{1}\right]} \\ & +[41 D] \cdot\left[T^{19}\right] \\ & \cdot\left[T_{1}\right] \\ & +\left[\mathrm{PQT}_{d}\right] \cdot\left[\bar{T}_{19}\right] \end{aligned}$ | $T_{1-18}^{19}$ | $\begin{array}{\|l} \text { ASBI } \\ \text { ISPI } \\ \text { GPQT } \end{array}$ | $\begin{array}{\|l} 5 \\ 4 \\ 3_{d} \end{array}$ | GPQT | Product-quotient transfer signal |
| SCC | $\begin{aligned} & \text { [SIC }] \cdot\left[\bar{T}_{1}\right] \cdot\left[\bar{T}_{2}\right] \\ & \cdot\left[\bar{T}_{3}\right] \cdot\left[\bar{T}_{4}\right] \\ & +\left[\mathrm{SCC}_{4}\right] \cdot\left[\bar{T}_{1}\right] \\ & \cdot[F 3] \end{aligned}$ | $T_{\text {SIC-22 }}^{2}{ }^{\text {a }}$ | $\begin{array}{\|l\|l} \text { ASPS } \\ \text { GSCC } \end{array}$ | $\begin{array}{\|l} \overline{4} \\ 2_{d} \end{array}$ | GSCC | Shift control signal |
| SHS | 70 D | As generated | $\begin{array}{\|l} \text { ASPS } \\ \text { GOEP } \\ \text { F3SG } \\ \text { S5AR } \end{array}$ | $\begin{aligned} & \overline{2}, 3,4 \\ & 3, \overline{4} \\ & 1 \\ & 1,2, \overline{3} \end{aligned}$ | (70D) | Shift decode signal |
| SIC | $\begin{aligned} & {\left[\bar{A}_{1}\right] \cdot\left[\bar{A}_{2}\right] \cdot\left[\bar{A}_{3}\right]} \\ & \cdot\left[\bar{A}_{4}\right] \cdot\left[\bar{A}_{6}\right] \end{aligned}$ | As generated | GSCC | 1 | GSIC | Shift inhibit control signal |
| SUB | $54 D$ | As generated | $\begin{array}{\|l\|} \hline \text { ASCG } \\ \text { IF2G } \\ \hline \end{array}$ | $\begin{aligned} & 1,2 \\ & 2 \\ & C 2) \end{aligned}$ | (54D) | Subtraction decode signal |
| TRS | 52 D | As generated | $\begin{aligned} & \text { GMIB } \\ & \text { IF3G } \end{aligned}$ | $\begin{aligned} & 2,3 \\ & 1 \end{aligned}$ | (52D) | Transfer decode signal |

Table A-2. Arithmetic-unit Internally Generated Signals
(See Figs. 18-11 to 18-13)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| A | $[(\alpha)] \cdot[\overline{\mathrm{MDS}}] \cdot\left[T^{1}\right]$ <br> - $[F 2]+[1 \mathrm{CN}]$ <br> - [DCS] $\cdot\left[\overline{T^{1}}\right]$ <br> - $[F 2]+[(\alpha)]$ <br> - [MCS] • [MUS] <br> - [ $T^{11} \cdot\left[F^{2}\right.$ ] <br> $+[1 \mathrm{CN}] \cdot[\mathrm{MCS}]$ <br> - [MUS] $\cdot\left[T^{11}\right]$ <br> - [F2] | $F 2$ | $\begin{aligned} & \text { ASRF } \\ & \text { ASCF } \end{aligned}$ | $\begin{aligned} & 1, \overline{2}, \overline{3}, 4 \\ & 1,3 \end{aligned}$ | ASAI | $\alpha$ input to adder-subtractor |

Table A-2. Arithmetic-unit Internally Generated Signals (Continued)

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Name of signal} \& \multirow{2}{*}{Equation} \& \multirow[t]{2}{*}{Time period present} \& \multicolumn{2}{|l|}{Destination} \& \multirow[t]{2}{*}{Generation location} \& \multirow{2}{*}{Remarks} \\
\hline \& \& \& Package \& Gate \& \& \\
\hline (ACC) \& \[
\begin{aligned}
\& {\left[P 21_{d}\right] \cdot[\mathrm{ASP}]} \\
\& \quad+\left[P 22_{d}\right] \cdot[\overline{\mathrm{ASP}}]
\end{aligned}
\] \& \(F 2\) or F3 \& \[
\begin{aligned}
\& \text { OCRF } \\
\& \text { OCCF } \\
\& \text { S5AR }
\end{aligned}
\] \& \[
\begin{aligned}
\& 1,2, \overline{3} \\
\& 1 \\
\& 1
\end{aligned}
\] \& Accu-mulator \& Contents of accumulator entering output complementer \\
\hline ASP \& \[
\left\lvert\, \begin{aligned}
\& {[\overline{\mathrm{MMI}}] \cdot\left[\bar{T}_{0}\right] \cdot\left[F^{2} 2\right]} \\
\& +[\overline{\mathrm{SHS}}] \cdot\left[\bar{T}_{0}\right] \\
\& \cdot[F 3]+[\mathrm{SHS}] \\
\& \cdot[\overline{\mathrm{SCC}}] \cdot\left[\bar{T}_{0}\right] \\
\& \cdot\left[T^{2}\right] \cdot[F 3] \\
\& +[\mathrm{MDS}] \cdot\left[T_{0}\right] \\
\& \cdot\left[\overline{T^{1}}\right] \cdot[F 2] \\
\& +[\mathrm{SHS}] \cdot\left[T^{1}\right] \\
\& \cdot\left[\bar{T}_{0}\right] \cdot[F 3]
\end{aligned}\right.
\] \& F2 or F3 \& \begin{tabular}{l}
S1AR \\
S2AR \\
through S22AR except: S5AR
\end{tabular} \& \(\overline{3}\)
\(1, \overline{2}\)

$1,2,3, \overline{4}$ \& ASPS \& Accumulator shift pulse signal <br>

\hline B \& \[
$$
\begin{gathered}
{\left[\bar{T}_{0}\right] \cdot[\overline{O F}] \cdot[\mathrm{ACC}]} \\
+\left[\bar{T}_{0}\right] \cdot\left[\mathrm{CC}_{d}\right] \\
\cdot[\mathrm{ACC}] \\
+\left[\bar{T}_{0}\right] \cdot[\mathrm{OF}] \\
\cdot[\overline{\mathrm{ACC}}] \cdot\left[\mathrm{CC}_{d}\right]
\end{gathered}
$$

\] \& $F 2$ or $F 3$ \& | S1ER |
| :--- |
| MUSG |
| ASBI |
| GMIB | \& \[

$$
\begin{aligned}
& 1,2 \\
& 1 \\
& 1,2,3_{d}, 4 \\
& 2
\end{aligned}
$$
\] \& OCRF \& Contents of accumulator out of output complementer <br>

\hline $B^{\prime}$ \& | $[B] \cdot[\overline{\mathrm{PQS}}] \cdot[F 2]$ |
| :--- |
| - $\left[T_{0-18}^{1}\right] \cdot\left[\bar{T}_{0}\right]$ |
| $+[B] \cdot[$ CLS $]$ |
| $[F 3] \cdot\left[\bar{T}_{0}\right] \cdot\left[T^{1}\right]$ |
| $+\left[B_{d}\right] \cdot[\mathrm{DCS}]$ |
| $[F 2]+[B]$ |
| [MCS] • [F2] |
| $\left[\overline{T^{1}}\right]+[($ IER $)]$ |
| [PQT] $\cdot[F 2]$ | \& F2 or F3 \& \[

$$
\begin{aligned}
& \text { IFCF } \\
& \text { ASRF }
\end{aligned}
$$

\] \& \[

\frac{1, \overline{2}, 3}{\overline{1}, 2, \overline{3}, 4}
\] \& ASBI \& $B$ input into adder-subtractor <br>

\hline $B^{\prime \prime}$

$C$ \& $$
\begin{aligned}
& {\left[B^{\prime}\right] \cdot[\mathrm{OPS}]+\left[\overline{B^{\prime}}\right]} \\
& \cdot[\overline{\mathrm{OPS}]} \cdot[F 2] \\
& +\left[B^{\prime}\right] \cdot[\mathrm{LDS}] \\
& \cdot[\overline{\mathrm{LES}}] \cdot[\overline{\mathrm{LIS}}] \\
& \cdot[F 2]
\end{aligned}
$$ \& F2 \& ASCF \& 2, 3 \& ITCF \& $B$ input into carry generator <br>

\hline C \& $$
\begin{aligned}
& {[\mathrm{LDS}] \cdot[\overline{\mathrm{LMS}}]} \\
& \cdot[\overline{\mathrm{LIS}]} \cdot[F 2] \\
& +[\overline{\mathrm{LDS}}] \cdot\left[C_{d}^{\prime}\right] \\
& \cdot\left[\bar{T}_{0}\right] \cdot[F 2]
\end{aligned}
$$ \& $F 2$ \& \[

$$
\begin{aligned}
& \text { ASCF } \\
& \text { ASRF }
\end{aligned}
$$

\] \& \[

\frac{1}{1}, \frac{2}{2}, 3,4
\] \& CIAS \& Carry input into addersubtractor <br>

\hline $C^{\prime}$ \& \[
$$
\begin{aligned}
& {[A] \cdot[C] \cdot\left[\bar{T}_{0}\right]} \\
& \quad+\left[B^{\prime \prime}\right] \cdot[C] \cdot\left[\bar{T}_{0}\right] \\
& \quad+[A] \cdot\left[B^{\prime \prime}\right] \cdot\left[\bar{T}_{0}\right]
\end{aligned}
$$

\] \& F2 \& \[

$$
\begin{aligned}
& \text { CIAS } \\
& \text { S1AR }
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 2_{d} \\
& 2
\end{aligned}
$$
\] \& ASCF \& Carry signal from addersubtractor carry generator <br>

\hline
\end{tabular}

Table A-2. Arithmetic-unit Internally Generated Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| CC | $\begin{gathered} {[(\mathrm{ACC})] \cdot[\mathrm{OF}] \cdot\left[\bar{T}_{0}\right]} \\ +[\mathrm{CC} \\ \cdot\left[\bar{T}_{0}\right] \cdot[\mathrm{OF}] \end{gathered}$ | $F 2$ or $F 3$ | $\begin{aligned} & \text { OCCF } \\ & \text { OCRF } \end{aligned}$ | $\frac{2_{d}}{\overline{2}_{d}, 3_{d}}$ | OCCF | Carry from output complementer |
| (ICN) | $\begin{aligned} & {\left[P 17_{d}\right] \cdot[\mathrm{PQC}]} \\ & \quad+\left[P 18_{d}\right] \cdot[\overline{\mathrm{PQC}}] \end{aligned}$ | F2 | $\begin{aligned} & \text { S1IR } \\ & \text { ASAI } \end{aligned}$ | $\begin{array}{\|l\|} \hline 2 \\ 2,4 \end{array}$ | S18IR | Contents of icand register |
| (IER) | $\left[P 17_{d}\right] \cdot[\mathrm{SPI}]$ <br> $+[(\mathrm{IER})] \cdot[\overline{\mathrm{SPI}}]$ <br> - [F2] • [DDS] <br> $+\left[\bar{T}_{21}\right] \cdot[(\mathrm{IER})]$ <br> - [ड्SPI $] \cdot[F 2]$ <br> - [DDS] <br> $+[\mathrm{SOD}] \cdot[F 2]$ <br> $\cdot[\mathrm{DDS}] \cdot\left[T_{21}\right]$ | $F 2$ | S1ER MUSG ASBI | $\begin{array}{\|l} 3 \\ 2 \\ 5 \end{array}$ | S18ER | Contents of ier register |
| MUS | $\begin{aligned} & {[B] \cdot[\mathrm{MDS}] \cdot\left[T^{11}\right]} \\ & \cdot\left[T_{1}\right] \cdot[F 2] \\ & +[(\mathrm{IER})] \\ & \cdot[\mathrm{MDS}] \cdot\left[T^{1}\right] \\ & \cdot\left[T_{1}\right] \cdot[F 2] \\ & +\left[\mathrm{MUS}_{d}\right] \cdot\left[\bar{T}_{0}\right] \\ & \cdot[F 2] \end{aligned}$ | $F 2, T_{1-22}^{1-18}$ | $\begin{aligned} & \text { MUSG } \\ & \text { ASAI } \end{aligned}$ | $\begin{array}{\|l\|} \hline 3_{d} \\ 3,4 \end{array}$ | MUSG | Multiply control signal; this signal is used to gate contents of $\alpha$ and contents of icand register into the adder during multiplication instructions |
| OF | $\begin{aligned} & \text { [OFR] } \cdot\left[T_{0}\right] \\ & +\left[\mathrm{OF}_{d}\right] \cdot\left[\bar{T}_{0}\right] \end{aligned}$ | $T_{0-22}$ | $\begin{aligned} & \text { OFLH } \\ & \text { OCRF } \\ & \text { OCCF } \end{aligned}$ | $\begin{array}{\|l\|} \hline \frac{2 d}{} \\ \frac{1}{1}, 3 \\ 1,2 \end{array}$ | OFLH | Overflow signal to output complementer |
| OFR | $\begin{aligned} & \left\{\left[P 1_{d}\right] \cdot[\text { ASP }]\right. \\ & \left.+\left[P 2_{d}\right] \cdot[\overline{\mathrm{ASP}}]\right\}_{d} \end{aligned}$ | $\begin{aligned} & T_{21}, \\ & T_{\text {OEP }} \end{aligned}$ | $\begin{array}{\|l} \hline \text { ASSG } \\ \text { SPDG } \\ \text { OFLH } \end{array}$ | $\begin{array}{\|l} \overline{1}, 2 \\ \overline{2}, 3 \\ 1 \end{array}$ | S2AR | Overflow due to result of arithmetic operation; this signal is used to determine sign of $B$ as well as to determine value of quotient bit |

Table A-2. Arithmetic-unit Internally Generated Signals (Continued)

| $\begin{aligned} & \text { Name } \\ & \text { of } \\ & \text { signal } \end{aligned}$ | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| OPS | $\begin{aligned} & {[\mathrm{SOA}] \cdot[\mathrm{SOB}]} \\ & \cdot[\mathrm{SUB}] \cdot[\overline{\mathrm{DDS}}] \\ & \cdot[F 2]+[\mathrm{SOA}] \\ & \cdot[\mathrm{SOB}] \cdot[\mathrm{SUB}] \\ & \cdot[\overline{\mathrm{DDS}]} \cdot[\mathrm{F} 2] \\ & +[\overline{\mathrm{SOA}]} \cdot[\overline{\mathrm{SOB}}] \\ & \cdot[\mathrm{ADD}] \cdot[\overline{\mathrm{DDS}}] \\ & \cdot[F 2]+[\mathrm{SOA}] \\ & \cdot[\mathrm{SOB}] \cdot[\mathrm{ADD}] \\ & \cdot[\mathrm{DDS}] \cdot[F 2] \\ & +[\mathrm{MDS}] \\ & \cdot[\mathrm{DDS}] \cdot[F 2] \end{aligned}$ | $F 2$ | ITCF | 1, $\overline{2}$ | ASCG | Operation selector signal; the presence of this signal causes adder to add; absence causes adder to subtract |
| P5AR ${ }^{-}$ | $\begin{aligned} & {\left[P 5_{d}\right] \cdot[\mathrm{ASP}]} \\ & +\left[P 4_{d}\right] \cdot[\mathrm{ASP}] \\ & \cdot[\mathrm{SHS}] \\ & +\left[P 4_{d}\right][\mathrm{ASP}] \\ & \cdot[\mathrm{SHS}] \cdot\left[T^{1}\right] \\ & \cdot[F 3]+[(\mathrm{ACC})] \\ & \cdot[\mathrm{ASP}] \cdot[\mathrm{SHS}] \\ & \cdot\left[T^{2}\right] \cdot[F 3] \end{aligned}$ | As generated | $\begin{array}{\|l} \hline \text { S5AR } \\ \text { S6AR } \end{array}$ | $\begin{aligned} & 4_{d} \\ & 1_{d} \end{aligned}$ | S5AR | Contents of stage 5 of accumulator register |
| $P n$ | $\begin{aligned} & {\left[P(n-1)_{d}\right]} \\ & \cdot[\text { shift pulse sig- } \\ & \text { nal }]+\left[P n_{d}\right] \\ & \frac{\cdot[\text { shift pulse sig- }}{\text { nal }]} \end{aligned}$ | As generated | $\left\{\begin{array}{l} \mathrm{S} n \mathrm{IR} \\ \text { or } \\ \mathrm{S} n \mathrm{ER} \\ \text { or } \\ \mathrm{S} n \mathrm{AR} \end{array}\right\}$ | [Highest gate number in package] ${ }_{d}$ | $\begin{aligned} & \text { SnIR } \\ & \text { SnER } \\ & \text { SnAR } \end{aligned}$ | Recirculation of contents of $n$th stage of icand, ier, or accumulator register |
| $R$ | $\begin{aligned} & {[A] \cdot\left[\bar{B}^{\prime}\right] \cdot[\bar{C}]} \\ & \cdot\left[\bar{T}_{0}\right]+[\bar{A}] \cdot\left[\bar{B}^{\prime}\right] \\ & \cdot[\bar{C}] \cdot\left[\bar{T}_{0}\right]+[\bar{A}] \\ & \cdot\left[B^{\prime}\right] \cdot[C] \cdot\left[\bar{T}_{0}\right] \\ & \\ & +[A] \cdot\left[B^{\prime}\right] \cdot[C] \\ & \cdot\left[\bar{T}_{0}\right] \end{aligned}$ | F2, F3 | $\begin{array}{\|l} \text { RZDG } \\ \text { S1AR } \end{array}$ |  | ASRF | Results from adder-subtractor |
| SAS | $\begin{aligned} & {[\mathrm{SOB}] \cdot[\overline{\mathrm{OFR}}]} \\ & \cdot[\mathrm{ASC}] \cdot[F 2] \\ & +[\mathrm{SOB}] \cdot[\mathrm{OFR}] \\ & \cdot[\mathrm{ASC}] \cdot[F 2] \\ & +[\mathrm{SEZ}] \cdot[F 2] \end{aligned}$ | F2 | SOBH | 1 | ASSG | Sign of $R$ as result of addition or subtraction |
| SEZ | $\begin{aligned} & {[R] \cdot\left[\bar{T}_{0}\right]} \\ & \quad+\left[\mathrm{SEZ}_{d}\right] \cdot\left[\bar{T}_{0}\right] \end{aligned}$ | $F 2$ | $\begin{aligned} & \text { RZDG } \\ & \text { ASSG } \\ & \text { PQSG } \\ & \text { SPDG } \end{aligned}$ | $\begin{aligned} & \frac{2}{2 d} \\ & \frac{3}{3} \\ & \frac{3}{3} \\ & \frac{1}{4} \end{aligned}$ | RZDG | Sum equals zero signal |
| SOA | $\begin{aligned} & {[(\alpha)] \cdot\left[T^{1}\right] \cdot\left[T_{0}\right]} \\ & \cdot[F 2]+\left[\mathrm{SOA}_{d}\right] \\ & \cdot[\overline{\mathrm{OEP}}] \end{aligned}$ | $\begin{aligned} & T_{0}^{1} \text { to } \\ & \text { OEP, } \\ & F 2 \end{aligned}$ | $\begin{array}{\|l} \text { SOAH } \\ \text { ASCG } \\ \text { PQSG } \end{array}$ | $\begin{aligned} & 2_{d} \\ & 1, \overline{2}, \overline{3}, 4 \\ & 1, \overline{2} \end{aligned}$ | SOAH | Sign of $\alpha$ |

Table A-2. Arithmetic-unit Internally Generated Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $\overline{\text { SOB }}$ | $\begin{aligned} & {[\mathrm{SAS}] \cdot[\mathrm{ASC}]} \\ & \cdot[\mathrm{OEP}] \cdot[\mathrm{F} 2] \\ & +[\mathrm{SQP}] \cdot[\mathrm{PQS}] \\ & \cdot[\mathrm{OEP}] \cdot[\mathrm{F2}] \\ & +[\mathrm{SOB}] \cdot[\mathrm{PQS}] \\ & +[\mathrm{CLS}] \cdot\left[T_{0}\right] \\ & \cdot[F 3] \\ & +\left[\mathrm{SOB}_{d}\right] \cdot[\mathrm{OEP}] \end{aligned}$ | F2, F3 | SOBH ASSG PQSG ASCG GMIB GJCS | $\overline{3_{d}, 5_{d}}$ $1, \overline{2}$ $1, \overline{2}$ $\overline{1}, 2, \overline{3}, 4$ 3 $\overline{1}$ | SOBH | Sign of contents of accumulator |
| SOD | $\left\lvert\, \begin{aligned} & {[\mathrm{DDS}] \cdot\left[T_{0^{1}}\right] \cdot[F 2]} \\ & +[\mathrm{SOOD}] \\ & \cdot[\mathrm{OFR}] \cdot[\mathrm{DDS}] \\ & \cdot\left[T_{21}\right] \cdot[F 2] \\ & +\left[\mathrm{SOD}{ }_{d}\right] \\ & \cdot[\mathrm{OFR}] \cdot[\mathrm{DDS}] \\ & \cdot\left[T_{21}\right] \cdot[F 2] \\ & +[\mathrm{SEZ}] \cdot[\mathrm{DDS}] \\ & \cdot\left[T_{21}\right] \cdot[F 2] \\ & +[\mathrm{SOD}] \\ & \cdot[\mathrm{DDS}] \cdot\left[T_{21}\right] \\ & \cdot[F 2] \end{aligned}\right.$ | $F 2$ | $\begin{array}{\|l\|l\|} \hline \text { SPDG } \\ \text { S18ER } \end{array}$ | $\begin{aligned} & 2_{d}, \overline{3}_{d}, 5_{d} \\ & 1 \end{aligned}$ | SPDG | Quotient signal |
| SPI | $\left\lvert\, \begin{gathered} {[\mathrm{MCS}] \cdot\left[T^{1}\right] \cdot[F 2]} \\ +[\mathrm{MDS}] \cdot\left[T_{0}\right] \\ \cdot\left[T^{11}\right] \cdot[F 2] \\ +[\mathrm{DDS}] \cdot\left[T_{1-17}\right] \\ \cdot[F 2] \\ +[\mathrm{PQT}] \cdot[F 2] \end{gathered}\right.$ | $F 2$ | $\left\{\begin{array}{l} \text { S1ER } \\ \text { S2ER } \\ \text { through } \\ \text { S17ER } \\ \text { S18ER } \end{array}\right\}$ | $\left\lvert\, \begin{aligned} & \overline{4} \\ & 1, \overline{2} \\ & 2, \overline{3}, \overline{4} \end{aligned}\right.$ | ISPS | Ier shift pulse signal |
| SQP | $\begin{aligned} & {[\mathrm{SOA}] \cdot[\mathrm{SOB}]} \\ & \cdot[\mathrm{PQS}] \cdot[F 2] \\ & +[\mathrm{SOA}] \cdot[\mathrm{SOB}] \\ & \cdot[\mathrm{OEP}] \cdot[\mathrm{PQS}] \\ & \cdot[F 2]+[\overline{\mathrm{SEZ}}] \\ & \cdot[\mathrm{PQS}] \cdot[F 2] \\ & \hline \end{aligned}$ | F2 | SOBH | 2 | PQSG | Sign of quotient or product |

Table A-3. Current-address and Instruction Signals
(See Fig. 18-14)

| $\begin{gathered} \text { Name } \\ \text { of } \\ \text { signal } \end{gathered}$ | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| 00D | $\begin{aligned} & \overline{\omega \bar{\omega} \cdot \overline{\omega 5} \cdot \overline{\omega 4}]}[\overline{\omega \bar{\omega}} \cdot \overline{\omega 2} \cdot \overline{\omega 1}] \end{aligned}$ | As generated | FBIG | 1 | G00D | Input-unit read-in decode signal |
| 21 D | $\begin{aligned} & {[\overline{\omega 6} \cdot \omega 5 \cdot \overline{\omega 4}]} \\ & \cdot[\overline{\omega 3} \cdot \overline{\omega 2} \cdot \omega 1] \end{aligned}$ | As generated | IFOG | 1 | G21D | Output-unit read-out decode signal |

Table A-3. Current-address and Instruction Signals (Continued)

| $\begin{aligned} & \text { Name } \\ & \text { of } \\ & \text { signal } \end{aligned}$ | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| 32 D | $\left\lvert\, \begin{aligned} & {[\overline{\omega 6} \cdot \omega 5 \cdot \omega 4]} \\ & \cdot[\overline{\omega 3} \cdot \omega 2 \cdot \overline{\omega 1}] \end{aligned}\right.$ | As generated | GMCS <br> GMDS <br> GPQC <br> GPQS <br> GPQT | $\begin{aligned} & \frac{2}{1} \\ & \frac{1}{1} \\ & 1 \\ & 1 \end{aligned}$ | G32D | Minor-multiplication decode signal |
| 41 D | $\left\lvert\, \begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \overline{\omega 4}]} \\ & \cdot[\overline{\omega 3} \cdot \overline{\omega 2} \cdot \omega 1] \end{aligned}\right.$ | As generated | GDCS <br> GDDS <br> GDRI <br> GPQC <br> GPQS | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \frac{3}{1} \\ & \frac{1}{1} \end{aligned}$ | G41D | Division decode signal |
| 42 D | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \overline{\omega 4}]} \\ & \cdot[\overline{\omega 3} \cdot \omega 2 \cdot \overline{\omega 1}] \end{aligned}$ | As generated | GMDS <br> GMMI <br> GPQC <br> GPQS <br> GMCS | $\left\lvert\, \begin{aligned} & \frac{2}{1} \\ & 1 \\ & \frac{2}{1} \\ & \frac{1}{1} \end{aligned}\right.$ | G42D | Major-multiplication decode signal |
| 43 D | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \overline{\omega 4}]} \\ & \cdot[\overline{\omega 3} \cdot \omega 2 \cdot \omega 1] \end{aligned}$ | As generated | $\begin{aligned} & \text { GJCS } \\ & \text { I*F1G } \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | G43D | Conditional jump decode signal |
| 44 D | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \overline{\omega 4}]} \\ & \because[\omega 3 \cdot \overline{\omega 2} \cdot \overline{\omega 1}] \end{aligned}$ | As generated | $\begin{aligned} & \text { GJCS } \\ & \text { I*F1G } \end{aligned}$ | $\left\lvert\, \begin{aligned} & 2 \\ & 2 \end{aligned}\right.$ | G44D | Normal-jump decode signal |
| 50 D | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \omega 4]} \\ & \cdot[\overline{\omega 3} \cdot \overline{\omega 2} \cdot \overline{\omega 1}] \end{aligned}$ | As generated | Directly to signal | CLS | G50D | Clear-accumulator decode signal |
| 52 D | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \omega 4]} \\ & \cdot[\overline{\omega 3} \cdot \omega 2 \cdot \overline{\omega 1}] \end{aligned}$ | As generated | Directly t signal | TRS | G52D | Transfer-contents-ofaccumulator decode signal |
| 53 D | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \omega 4]} \\ & \cdot[\omega 3 \cdot \omega 2 \cdot \omega 1] \end{aligned}$ | As generated | GASC Directly to signal | $\begin{aligned} & 1 \\ & \text { ADD } \end{aligned}$ | G53D | Addition decode signal |
| $54 D$ | $\begin{aligned} & {[\omega 6 \cdot \overline{\omega 5} \cdot \omega 4]} \\ & \cdot[\omega 3 \cdot \overline{\omega 2} \cdot \overline{\omega 1}] \end{aligned}$ | As generated | GASC <br> Directly to signal | $\frac{2}{2}$ | G54D | Subtraction decode signal |
| 60 D | $\left[\begin{array}{l} {[\omega 6 \cdot \omega 5 \cdot \overline{\omega \overline{4}}]} \\ \cdot[\overline{\omega 3} \cdot \overline{\omega 2} \cdot \overline{\omega 1}] \end{array}\right.$ | As generated | ISFG | 2 | G60D | Stop decode signal |
| $70 D$ $71 D$ | $\begin{aligned} & {[\omega 6 \cdot \omega 5 \cdot \omega 4]} \\ & \cdot[\overline{\omega 3} \cdot \overline{\omega 2} \cdot \overline{\omega 1}] \end{aligned}$ | As generated | Directly to signal | SHS | G70D | Shift decode signal |
| $71 D$ | $\begin{gathered} {[\omega 6 \cdot \omega 5 \cdot \omega 4]} \\ \cdot[\omega 3 \cdot \overline{\omega 2} \cdot \omega 1] \end{gathered}$ | As generated | GLDS <br> GLMS | $\left\lvert\, \begin{aligned} & \overline{1} \\ & 1 \end{aligned}\right.$ | G71D | Logical-multiply decode signal |
| 72 D | $\begin{gathered} {[\omega 6 \cdot \omega 5 \cdot \omega 4]} \\ \cdot[\overline{\omega 3} \cdot \omega 2 \cdot \overline{\omega 1}] \end{gathered}$ | As generated | $\begin{aligned} & \text { GLAS } \\ & \text { GLDS } \end{aligned}$ | $\frac{1}{1}$ | G72D | Logical-addition decode signal |

Table A-3. Current-address and Instruction Signals (Continued)

| $\begin{aligned} & \text { Name } \\ & \text { of } \\ & \text { signal } \end{aligned}$ | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| 73 D | $\begin{gathered} {[\omega 6 \cdot \omega 5 \cdot \omega 4]} \\ \cdot[\overline{\omega 3} \cdot \omega 2 \cdot \omega 1] \end{gathered}$ | As generated | $\begin{aligned} & \text { GLDS } \\ & \text { GLES } \end{aligned}$ | $\begin{aligned} & \overline{1} \\ & 1 \end{aligned}$ | G73D | Logical-equivalence decode signal |
| $74 D$ | $\stackrel{[\omega 6 \cdot \omega 5 \cdot \omega 4]}{\cdot[\omega 3 \cdot \overline{\omega 2} \cdot \overline{\omega 1}]}$ | As generated | $\begin{aligned} & \text { GLDS } \\ & \text { GLIS } \end{aligned}$ | $\overline{1}$ | G74D | Logical-inequivalence |
| 1CS | $[\overline{\mathrm{JCS}}] \cdot[F 1] \cdot\left[T_{22}\right]$ | $F 1, T_{22}$ | $\begin{aligned} & \alpha i a\left\{\begin{array}{l} i \text { from } \\ 1 \text { to } 12 \end{array}\right. \\ & \alpha i\left\{\begin{array}{l} i \text { from } \\ 1 \text { to } 12 \end{array}\right. \end{aligned}$ | 1 $\begin{aligned} & 1,2\end{aligned}$ | 1CSG | Current-ad-dress-register stepping signal |
| JCL | $[\mathrm{JCS}] \cdot[F 1] \cdot\left[T_{22}\right]$ | $F 1, T_{22}$ | $\alpha i\left\{\begin{array}{l} i \text { from } \\ 1 \text { to } 12 \end{array}\right.$ | $\overline{1}, 3$ | JCLG | Jump load signal (this signal is used to load cur-rent-address register with the $\alpha$ portion of the instruction) |
| STC | [STB] • [ISF] | As generated | $\begin{aligned} & \alpha i\left\{\begin{array}{l} i \text { from } \\ 1 \text { to } 12 \end{array}\right. \\ & \alpha^{\prime} i \\ & \omega j\{j=1-6 \end{aligned}$ | $\left\lvert\, \begin{aligned} & \overline{1} \\ & \overline{1}, \overline{2} \\ & \overline{1} \end{aligned}\right.$ | STCG | Start clear signal |
| IRS | $[F 1] \cdot\left[T_{1-18}\right]$ | $F 1, T_{1-18}$ | $\begin{aligned} & \omega j\{j=1-6 \\ & \omega j\{j=1-5 \\ & \alpha i\{i=1-12 \end{aligned}$ | $\begin{aligned} & \frac{1}{1} \\ & \frac{1}{1}, 2 \end{aligned}$ | IRSG | Instruction register shift signal |
| ${ }_{\alpha} 1$ | $\begin{aligned} & \{[\alpha 2] \cdot[\text { IRS }] \\ & +[\overline{\mathrm{STC}]} \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 1]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 1 \\ & \alpha^{*} 1 \\ & \alpha^{\prime} 1 \\ & \text { SHA1 } \end{aligned}$ | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 1 \end{aligned}$ | $\alpha 1$ | $\alpha 1$ bit of instruction register |
| $\alpha 2$ | $\begin{aligned} & \{[\alpha 3] \cdot[\text { IRS }] \\ & +[\overline{\text { STC }}] \cdot[\overline{\text { IRS }}] \\ & \cdot[\alpha 2]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 1 \\ & \alpha 1 \\ & \alpha 2 \\ & \alpha^{*} 2 \\ & \alpha^{\prime 2} \\ & \text { SHA2 } \end{aligned}$ | $\left\lvert\, \begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \\ & 1 \end{aligned}\right.$ | $\alpha 2$ | $\alpha 2$ bit of instruction register |
| ${ }^{2} 3$ | $\begin{aligned} & \{[\alpha 4] \cdot[\text { IRS }] \\ & +\left[\mathrm{S}^{\prime T C}\right] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 3]\}_{d} \end{aligned}$ | As generated | $\begin{array}{\|l} \alpha 2 \\ \alpha 3 \\ \alpha^{*} 3 \\ \alpha^{\prime} 3 \\ \text { SHA3 } \end{array}$ | $\begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\alpha 3$ | $\alpha 3$ bit of instruction register |
| $\alpha 4$ | $\begin{aligned} & \{[\alpha 5] \cdot[\text { IRS }] \\ & +[\overline{\text { STC }]} \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 4]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 3 \\ & \alpha 3 \\ & \alpha 4 \\ & \alpha^{*} 4 \\ & \alpha^{\prime} 4 \\ & \text { SHA4 } \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \\ & 1 \end{aligned}$ | $\alpha 4$ | $\alpha 4$ bit of instruction register |

Table A-3. Current-address and Instruction Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $\alpha 5$ | $\begin{aligned} & \{[\alpha 6] \cdot[\mathrm{IRS}] \\ & \quad+[\overline{\mathrm{STC}}] \cdot[\mathrm{IRS}] \\ & \cdot[\alpha 5]\}_{d} \end{aligned}$ | As generated | $\alpha 4$ <br> $\alpha 5$ <br> $\alpha^{*} 5$ <br> $\alpha^{\prime} 5$ <br> SHA5 |  | $\alpha 5$ | $\alpha 5$ bit of instruction register |
| $\alpha 6$ | $\begin{aligned} & \{[\alpha 7] \cdot[\text { IRS }] \\ & +[\overline{\mathrm{STC}}] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 6]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 55 \\ & \alpha 6 \\ & \alpha^{*} 6 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 1 \\ & 3 \\ & 3 \end{aligned}$ | $\alpha 6$ | $\alpha 6$ bit of instruction register |
| $\alpha 7$ | $\begin{aligned} & \{[\alpha 8] \cdot[\text { IRS }] \\ & +[\overline{\mathrm{STC}}] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 7]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 6 \\ & \alpha^{2} \\ & \alpha^{*} 7 \\ & \alpha^{\prime} 7 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \end{aligned}$ | $\alpha 7$ | $\alpha 7$ bit of instruction register |
| $\alpha 8$ | $\begin{aligned} & \{[\alpha 9] \cdot[\text { IRS }] \\ & +[\overline{\mathrm{STC}}] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 8]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 7 \\ & \alpha 8 \\ & \alpha^{* 8} \\ & \alpha^{\prime} 8 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \end{aligned}$ | $\alpha 8$ | $\alpha 8$ bit of instruction register |
| ${ }_{\alpha} 9$ | $\begin{aligned} & \{[\alpha 10] \cdot[\text { IRS }] \\ & +[\mathrm{STC}] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\alpha 9]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 8 \\ & \alpha 9 \\ & \alpha^{*} 9 \\ & \alpha^{\prime} 9 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \end{aligned}$ | $\alpha 9$ | $\alpha 9$ bit of instruction register |
| $\alpha 10$ | $\begin{aligned} & \{[\alpha 11] \cdot[\mathrm{IRS}] \\ & +[\mathrm{STC}] \cdot[\mathrm{IRS}] \\ & \cdot[\alpha 10]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 9 \\ & \alpha 10 \\ & \alpha^{*} 10 \\ & \alpha^{\prime} 10 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \end{aligned}$ | $\alpha 10$ | $\alpha 10$ bit of instruction register |
| $\alpha 11$ | $\begin{aligned} & \{[\alpha 12] \cdot[\mathrm{IRS}] \\ & +[\mathrm{STC}] \cdot[\mathrm{IRS}] \\ & \cdot[\alpha 11]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 10 \\ & \alpha 11 \\ & \alpha^{*} 11 \\ & \alpha^{\prime} 11 \end{aligned}$ | $\left\lvert\, \begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \end{aligned}\right.$ | $\alpha 11$ | $\alpha 11$ bit of instruction register |
| $\alpha 12$ | $\begin{aligned} & \{[\omega 1] \cdot[\text { IRS }] \\ & +[\overline{\mathrm{STC}}] \cdot[\mathrm{IRS}] \\ & \cdot[\alpha 12]\}_{d} \end{aligned}$ | As generated | $\begin{aligned} & \alpha 11 \\ & \alpha 12 \\ & \alpha^{*} 12 \\ & \alpha^{\prime} 12 \end{aligned}$ | $\left\lvert\, \begin{aligned} & 2 \\ & 1 \\ & 3 \\ & 3 \end{aligned}\right.$ | $\alpha 12$ | $\alpha 12$ bit of instruction register |
| $\alpha^{*} 1$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 1\right]+[\mathrm{IF} 1]} \\ & \cdot\left[\alpha^{\prime} 1\right]+\left[F^{\prime}\right] \\ & \cdot[\overline{\mathrm{IF} 1]} \cdot[\alpha 1] \end{aligned}$ | As generated | To memor ors | select- | $\alpha^{*} 1$ | Memoryselector address |
| $\alpha^{*} 2$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 2\right]} \\ & \quad+[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 2\right] \\ & +\left[\overline{F^{1} 1}\right] \cdot[\overline{\mathrm{IF} 1}] \\ & +[\alpha 2] \end{aligned}$ | As generated | To memory ors | select- | $\alpha^{*} 2$ | Memoryselector address |
| $\alpha^{* 3}$ | $\begin{aligned} & {[F 1] \cdot\left[\dot{\alpha}^{\prime} 3\right]} \\ & +[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 3\right] \\ & +[\overline{F 1}] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha 3] \end{aligned}$ | As generated | To memor ors | select- | $\alpha^{*} 3$ | Memoryselector address |

Table A-3. Current-address and Instruction Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $\alpha^{*} 4$ | $\begin{aligned} & \hline[F 1] \cdot\left[\alpha^{\prime} 4\right] \\ & +[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 4\right] \\ & +[\overline{F 1}] \cdot[\mathrm{IF} 1] \\ & \cdot[\alpha 4] \end{aligned}$ | As generated | To memory ors | loct- | $\alpha^{*} 4$ | Memoryselector address |
| $\alpha^{* 5}$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 5\right]} \\ & \quad+[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 5\right] \\ & +[\overline{F 1}] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha 5] \end{aligned}$ | As generated | To memory ors | elect- | $\alpha^{*} 5$ | Memoryselector address |
| $\alpha^{*} 6$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 6\right]} \\ & +[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 6\right] \\ & +[\overline{F 1}] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha 6] \end{aligned}$ | As generated | To memor ors | elect- | $\alpha^{*} 6$ | Memoryselector address |
| $\alpha^{*} 7$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 7\right]} \\ & \quad+[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 7\right] \\ & +\left[\overline{F^{1} 1}\right] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha]] \end{aligned}$ | As generated | To memo ors | ect- | $\alpha^{*} 7$ | Memoryselector address |
| $\alpha^{* 8}$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 8\right]} \\ & +[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 8\right] \\ & +[\overline{F 1}] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha 8] \end{aligned}$ | As generated | To memo ors | ect- | $\alpha^{*} 8$ | Memoryselector address |
| $\alpha^{*} 9$ | $\begin{aligned} & {\left[F^{\prime} 1\right] \cdot\left[\alpha^{\prime} 9\right]} \\ & +[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 9\right] \\ & +[\overline{\mathrm{F} 1}] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot\left[\alpha^{2}\right] \end{aligned}$ | As generated | To memo ors | ect- | $\alpha^{*} 9$ | Memoryselector address |
| $\alpha * 10$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 10\right]} \\ & \quad+[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 10\right] \\ & +[\overline{\mathrm{F} 1}] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha 10] \end{aligned}$ | As generated | To memor ors | lect- | $\alpha^{*} 10$ | Memoryselector address |
| $\alpha^{*} 11$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 11\right]} \\ & +[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 11\right] \\ & +[\bar{F} 1] \cdot[\overline{\mathrm{IF} 1}] \\ & \cdot[\alpha 11] \end{aligned}$ | As generated | To memor ors | ect- | $\alpha^{*} 11$ | Memoryselector address |
| $\alpha^{*} 12$ | $\begin{aligned} & {[F 1] \cdot\left[\alpha^{\prime} 12\right]} \\ & \quad+[\mathrm{IF} 1] \cdot\left[\alpha^{\prime} 12\right] \\ & +[\overline{F 1}] \cdot[\overline{\mathrm{IF1} 1}] \\ & \cdot[\alpha 12] \end{aligned}$ | As generated | To memory ors | select- | $\alpha^{*} 12$ | Memoryselector address |
| $\alpha^{\prime} 1$ | $\begin{aligned} & {[\overline{\mathrm{ICS}] \cdot[\overline{\mathrm{STC}}]}} \\ & \cdot\left[\alpha^{\prime} 1_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +[\overline{\mathrm{STC}}] \cdot[1 \mathrm{CS}] \\ & \cdot\left[\alpha^{\prime} 1 d\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 1] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 1 \mathrm{a} \\ & \alpha^{\prime} 1 \\ & \alpha^{*} 1 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 1$ | 1st bit of cur-rent-address register |
| $\alpha^{\prime} 2$ | $\begin{aligned} & {\left[\overline{\left.\alpha^{\prime} 1 \mathrm{a}\right]} \cdot[\mathrm{STC}]\right.} \\ & {\left[\alpha^{\prime} 2_{d}\right] \cdot[\overline{\mathrm{JCL}}]} \\ & +\left[\mathrm{S}^{\prime}\right] \cdot\left[\alpha^{\prime} 1 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime} 2 d\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 2] \\ & \hline \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 2 \mathrm{a} \\ & \alpha^{\prime} 2 \\ & \alpha^{*} 2 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d,} \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime 2}$ | 2d bit of cur-rent-address register |

Table A-3. Current-address and Instruction Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $\alpha^{\prime} 3$ | $\begin{aligned} & {\left[\overline{\left.\alpha^{\prime} 2 \mathrm{a}\right]} \cdot[\overline{\mathrm{STC}}]\right.} \\ & \cdot\left[\alpha^{\prime} 3_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +\left[\alpha^{\prime} T \mathrm{STC}\right] \cdot\left[\alpha^{\prime} 2 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime} 3\right. \\ & d \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 3 \mathrm{a} \\ & \alpha^{\prime} 3 \\ & \alpha^{*} 3 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d,} \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 3$ | 3d bit of cur-rent-address register |
| $\alpha^{\prime} 4$ | $\begin{aligned} & {\left[\alpha^{\prime} 3 \mathrm{a}\right] \cdot[\overline{\mathrm{STC}}]} \\ & \cdot\left[\alpha^{\prime} 4_{d}\right] \cdot[\mathrm{JCL}] \\ & +[\mathrm{STC}] \cdot\left[\alpha^{\prime} 3 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime} 4 d\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 4] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 4 \mathrm{a} \\ & \alpha^{\prime} 4 \\ & \alpha^{*} 4 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d,} \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 4$ | 4th bit of cur-rent-address register |
| $\alpha^{\prime} 5$ | $\begin{aligned} & {\left[\overline{\alpha^{\prime} 4 \mathrm{a}}\right] \cdot[\mathrm{STC}]} \\ & \cdot\left[\alpha^{\prime} 5_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +[\overline{\mathrm{STC}}] \cdot\left[\alpha^{\prime} 4 \mathrm{a}\right] \\ & \cdot\left[\overline{\alpha^{\prime} 5}\right] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 5 \mathrm{a} \\ & \alpha^{\prime} 5 \\ & \alpha^{*} 5 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 5$ | 5th bit of cur-rent-address register |
| $\alpha^{\prime} 6$ | $\begin{aligned} & {\left[\alpha^{\prime} 5 \mathrm{Sa}\right] \cdot[\mathrm{STC}]} \\ & \cdot\left[\alpha^{\prime} 6_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +[\overline{\mathrm{STC}}] \cdot\left[\alpha^{\prime} 5 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime} 6 d\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 6] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 6 a \\ & \alpha^{\prime} 6 \\ & \alpha^{*} 6 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 6$ | 6th bit of cur-rent-address register |
| $\alpha^{\prime} 7$ | $\begin{aligned} & {\left[\alpha^{\prime} 6 \mathrm{ab}\right] \cdot[\mathrm{STC}]} \\ & \cdot\left[\alpha^{\prime} 7_{d}\right] \cdot[\mathrm{JCL}] \\ & +\left[\mathrm{STC}^{\mathrm{ST}}\right] \cdot\left[\alpha^{\prime} 6 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime} 7_{d}\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 7] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 7 \mathrm{a} \\ & \alpha^{\prime} 7 \\ & \alpha^{*} 7 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 7$ | 7th bit of cur-rent-address register |
| $\alpha^{\prime} 8$ | $\begin{aligned} & {\left[\overline{\left.\alpha^{\prime} 7 a\right]} \cdot[\mathrm{STC}]\right.} \\ & \cdot\left[\alpha^{\prime} 8_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +[\overline{\mathrm{STC}}] \cdot\left[\alpha^{\prime} 7 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime}{ }^{\prime} d\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 8] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 8 \mathrm{a} \\ & \alpha^{\prime} 8 \\ & \alpha^{*} 8 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 8$ | 8th bit of cur-rent-address register |
| $\alpha^{\prime} 9$ | $\begin{aligned} & {\left[\alpha^{\prime} 8 \mathrm{Ba}\right] \cdot[\mathrm{STC}]} \\ & \cdot\left[\alpha^{\prime} 9_{d}\right] \cdot[\mathrm{JCL}] \\ & +[\mathrm{STC}] \cdot\left[\alpha^{\prime} 8 \mathrm{a}\right] \\ & \cdot\left[\alpha^{\prime} 9_{d}\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 9] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 9 \mathbf{a} \\ & \alpha^{\prime} 9 \\ & \alpha^{*} 9 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d,}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 9$ | 9th bit of cur-rent-address register |
| $\alpha^{\prime} 10$ | $\begin{aligned} & {\left[\alpha^{\prime} 9 \mathrm{aa}\right] \cdot[\mathrm{STC}]} \\ & \cdot\left[\alpha^{\prime} 10_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +[\overline{\mathrm{STC}}] \cdot\left[\alpha^{\prime} 9 \mathrm{a}\right] \\ & \cdot\left[{\alpha^{\prime} 10}^{\prime}\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 10] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 10 \mathrm{a} \\ & \alpha^{\prime} 10 \\ & \alpha^{*} 10 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d,} \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 10$ | 10th bit of cur rent-address register |
| $\alpha^{\prime} 11$ | $\begin{aligned} & {\left[\alpha^{\prime} 10 \mathrm{a}\right] \cdot[\mathrm{STC}]} \\ & \cdot\left[\alpha^{\prime} 11_{d}\right] \cdot[\mathrm{JCL}] \\ & +\left[\overline{\mathrm{STC}]} \cdot\left[\alpha^{\prime} 10 \mathrm{a}\right]\right. \\ & \cdot\left[\alpha^{\prime} 11_{d}\right] \\ & +[\mathrm{JCL}] \cdot[\alpha 11] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 11 \mathrm{a} \\ & \alpha^{\prime} 11 \\ & \alpha^{*} 11 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 11$ | 11th bit of cur-rent-address register |

Table A-3. Current-address and Instruction Signals (Continued)

| Name <br> of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $\alpha^{\prime} 12$ | $\begin{aligned} & {\left[\overline{\alpha^{\prime} 11 \mathrm{a}}\right] \cdot[\overline{\mathrm{STC}}]} \\ & \cdot\left[\alpha^{\prime} 12_{d}\right] \cdot[\overline{\mathrm{JCL}}] \\ & +[\overline{\mathrm{STC}}] \cdot\left[\alpha^{\prime} 11 \mathrm{a}\right] \\ & \cdot\left[\overline{\alpha^{\prime} 12}{ }^{\prime}\right] \end{aligned}$ | As generated | $\begin{aligned} & \alpha^{\prime} 12 \mathrm{a} \\ & \alpha^{\prime} 12 \\ & \alpha^{*} 12 \end{aligned}$ | $\begin{aligned} & 1_{d} \\ & 1_{d}, \overline{2}_{d} \\ & 1,2 \end{aligned}$ | $\alpha^{\prime} 12$ | 12th bit of cur-rent-address register |
| $\alpha^{\prime} 1 \mathrm{a}$ | $\left[\alpha^{\prime} 1_{d}\right] \cdot[1 \mathrm{CS}]$ | As generated | $\begin{aligned} & \alpha^{\prime} 2 \\ & \alpha^{\prime} 2 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 1 \mathrm{a}$ | 1st auxiliary bit |
| $\alpha^{\prime} 2 \mathrm{a}$ | $\left[\alpha^{\prime} 2_{d}\right] \cdot\left[\alpha^{\prime} 1 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 3 \\ & \alpha^{\prime} 3 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 2 \mathrm{a}$ | 2d auxiliary bit |
| $\alpha^{\prime} 3 \mathrm{a}$ | $\left[\alpha^{\prime} 3_{d}\right] \cdot\left[\alpha^{\prime} 2 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 4 \\ & \alpha^{\prime} 4 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 3 \mathrm{a}$ | 3d auxiliary bit |
| $\alpha^{\prime} 4 \mathrm{a}$ | $\left[\alpha^{\prime} 4_{d}\right] \cdot\left[\alpha^{\prime} 3 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 5 \\ & \alpha^{\prime} 5 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \frac{7}{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 4 \mathrm{a}$ | 4th auxiliary bit |
| $\alpha^{\prime} 5 \mathrm{a}$ | $\left[\alpha^{\prime} 5_{d}\right] \cdot\left[\alpha^{\prime} 4 \mathrm{a}\right]$ | As generated | $\alpha^{\prime} 6$ $\alpha^{\prime} 6 \mathrm{a}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 5 \mathrm{a}$ | 5th auxiliary bit |
| $\alpha^{\prime} 6 \mathrm{a}$ | $\left[\alpha^{\prime} 6_{d}\right] \cdot\left[\alpha^{\prime} 5 \mathrm{a}\right]$ | As generated | $\alpha^{\prime} 7$ $\alpha^{\prime} 7 \mathrm{a}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 6 \mathrm{a}$ | 6th auxiliary bit |
| $\alpha^{\prime} 7 \mathrm{a}$ | $\left[\alpha^{\prime} 7_{d}\right] \cdot\left[\alpha^{\prime} 6 \mathrm{a}\right]$ | As generated | $\alpha^{\prime} 8$ $\alpha^{\prime} 8 \mathrm{a}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 7 \mathrm{a}$ | 7th auxiliary bit |
| $\alpha^{\prime} 8 \mathrm{a}$ | $\left[\alpha^{\prime} 8_{d}\right] \cdot\left[\alpha^{\prime} 7 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 9 \\ & \alpha^{\prime} 9 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 8 \mathrm{a}$ | 8th auxiliary bit |
| $\alpha^{\prime} 9 \mathrm{a}$ | $\left[\alpha^{\prime} 9_{d}\right] \cdot\left[\alpha^{\prime} 8 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 10 \\ & \alpha^{\prime} 10 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & \underline{1} \end{aligned}$ | $\alpha^{\prime} 9 \mathrm{a}$ | 9th auxiliary bit |
| $\alpha^{\prime} 10 \mathrm{a}$ | $\left[\alpha^{\prime} 10_{d}\right] \cdot\left[\alpha^{\prime} 9 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 11 \\ & \alpha^{\prime} 11 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 10 \mathrm{a}$ | 10th auxiliary bit |
| $\alpha^{\prime} 11 \mathrm{a}$ | $\left[\alpha^{\prime} 11_{d}\right] \cdot\left[\alpha^{\prime} 10 \mathrm{a}\right]$ | As generated | $\begin{aligned} & \alpha^{\prime} 12 \\ & \alpha^{\prime} 12 \mathrm{a} \end{aligned}$ | $\begin{aligned} & \overline{1}, 2 \\ & 1 \end{aligned}$ | $\alpha^{\prime} 11 \mathrm{a}$ | 11th auxiliary bit |
| $\omega 1$ | $\begin{aligned} & \{[\omega 2] \cdot[\text { IRS }] \\ & +[\omega 1] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\mathrm{STC}]\}_{d} \end{aligned}$ | As generated | $\propto 12$ <br> $\omega 1$ <br> To instr decoder | $\left\lvert\, \begin{aligned} & 2 \\ & 1 \end{aligned}\right.$ <br> tion | $\omega 1$ | 1st bit of instruction register |
| $\omega 2$ | $\begin{aligned} & \{[\omega 3] \cdot[\text { IRS }] \\ & +[\omega 2] \cdot[\overline{\operatorname{IRS}]} \\ & \cdot[\mathrm{STC}]\}_{d} \end{aligned}$ | As generated | $\omega 1$ <br> $\omega 2$ <br> To instr decoder | $12$ $1$ <br> tion | $\omega 2$ | 2d bit of instruction register |
| $\omega 3$ | $\begin{aligned} & \{[\omega 4] \cdot[\text { IRS }] \\ & +[\omega 3] \cdot[\overline{\operatorname{IRS}}] \\ & \cdot[\overline{S T C}]\}_{d} \end{aligned}$ | As generated | $\omega 2$ <br> $\omega 3$ <br> To instr decoder | $\mid 2$ $1$ <br> tion | $\omega 3$ | 3d bit of instruction register |
| $\omega 4$ | $\begin{aligned} & \{[\omega 5] \cdot[\text { IRS }] \\ & +[\omega 4] \cdot[\overline{\operatorname{IRS}]} \\ & \cdot[\overline{\mathrm{STC}}]\}_{d} \end{aligned}$ | As generated | $\omega 3$ <br> $\omega 4$ To instru decoder | $\left\lvert\, \begin{aligned} & 2 \\ & 1 \\ & \text { ction } \end{aligned}\right.$ | $\omega 4$ | 4th bit of instruction register |

Thable A-3. Current-address and Instruction Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $\omega 5$ | $\begin{aligned} & \{[\omega 6] \cdot[\text { IRS }] \\ & +[\omega 5] \cdot[\overline{\text { IRS }]} \\ & \cdot[\text { STC }]\}_{d} \end{aligned}$ | As generated | $\begin{array}{\|l\|l} \omega 4 \\ \omega 5 \end{array}$ <br> To instru decoder | $\begin{aligned} & 2 \\ & 1 \\ & \text { ction } \end{aligned}$ | $\omega 5$ | 5th bit of instruction register |
| $\omega 6$ | $\begin{aligned} & \{[F 1] \cdot[(\alpha)] \\ & +[\omega 6] \cdot[\overline{\mathrm{IRS}}] \\ & \cdot[\mathrm{STC}]\}_{d} \end{aligned}$ | As generated | $\omega 5$ <br> $\omega 6$ <br> To instru decoder | $\left\lvert\, \begin{aligned} & 2 \\ & 1 \\ & \text { ction } \end{aligned}\right.$ | $\omega 6$ | 6th bit of instruction register |

Table A-4. Control-unit Signals, Channel Selector, Sector Selector (See Fig. 18-15)


Table A-5. Unit-time-interval Counter Signals
(See Fig. 18-16)

| Name of signal | Equation | Time period present | Destination |  | Generation <br> location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| $c p$ | Drum clock-pulse signals | All time | To every package | To every and gate | Drum clock track | Clock-pulse signal |
| DSS | Drum synchronizer signal | See Sec. 18-7 | UTSG | 1 | Drum <br> synchro- <br> nizer <br> track | Drum synchronizer signal |
| UTS | $\begin{aligned} & {[c p] \cdot[\mathrm{DSS}]} \\ & +[c p] \cdot\left[\mathrm{UTS}_{d}\right] \end{aligned}$ | As generated |  | $\begin{aligned} & 2 \\ & 1 \\ & 1, \overline{2} \\ & 1 \\ & 1 \\ & 1 \\ & 1, \overline{1}_{d} \end{aligned}$ | UTSG | Unit time signal; this signal acts as the unit-timecount signal |

Table A-6. Operations Phase-generator Signals
(See Figs. 18-17 and 18-18)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| BSP | [SIU] • [ $\overline{\mathrm{EWI}}]$ <br> $\cdot[\mathrm{FBI}]+[\mathrm{SOU}]$ <br> - [EWO] • [FBO] <br> $+\left[T_{0-18}^{1}\right] \cdot[\mathrm{FOI}]$ <br> $+\left[T_{0-18}^{1}\right] \cdot[\mathrm{FOO}]$ | $T_{0-18}^{1}$ | $\left.\begin{array}{\|l} \text { BU1 } \\ \text { BU2 } \\ \text { through } \\ \text { BU19 } \end{array}\right\}$ | $\left\lvert\, \begin{aligned} & \overline{3} \\ & 1, \overline{2} \end{aligned}\right.$ | BSPG | Buffer shift pulse signal |
| BUF | $\begin{aligned} & {\left[\mathrm{BU} 19_{d}\right] \cdot[\overline{\mathrm{BSP}}]} \\ & +\left[\mathrm{BU} 18_{d}\right] \\ & \cdot[\mathrm{BSP}] \end{aligned}$ | $\begin{array}{\|c} \text { FOI or } \\ \text { FBO } \end{array}$ | GMIB to output unit or to drum | 1 | BU19 | Out of buffer |
| EWI | $\begin{aligned} & {[\mathrm{EWI}] \cdot\left[\tilde{T}_{0}\right]} \\ & \cdot\left[\overline{\mathrm{TF1}}_{d}\right] \\ & +\left[\mathrm{EWI}_{d}\right] \\ & \cdot\left[\overline{\mathrm{FF}}_{d}\right] \end{aligned}$ | $\bar{T}_{0} \cdot \mathrm{FBI}$ | BSPG <br> EWIG <br> FBIG <br> IFIG | $\begin{aligned} & \overline{1} \\ & 2_{d} \\ & \frac{1}{4} \\ & 1 \end{aligned}$ | EWIG | External wordin signal indicating that a complete word has been sent into buffer from input unit |

Table A-6. Operations Phase-generator Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | $\begin{gathered} \text { Gener- } \\ \text { ation } \\ \text { location } \end{gathered}$ | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| EWO | $\begin{aligned} & {\left[\mathrm{EWO}^{\prime}\right] \cdot\left[\overline{\mathrm{T}}_{\mathrm{o}}\right]} \\ & \cdot\left[\overline{\mathrm{FF}}_{d}\right] \\ & +\left[\mathrm{EWO}_{d}\right] \\ & \cdot\left[\overline{\mathrm{EF} 1}{ }_{d}\right] \end{aligned}$ | $\overline{\bar{T}_{0} \cdot \mathrm{FBO}}$ | BSPG <br> EWOG <br> FBOG <br> I'F1G | $\overline{4}$ <br> $2_{d}$ <br> $\overline{3}$ <br> 1 <br>  <br>  | EWOG | External wordout signal indicating that a complete word has been read out of buffer into output unit |
| $F 1$ | $\begin{aligned} & {[\mathrm{COI}] \cdot[\overline{\mathrm{SPB}}]} \\ & \cdot\left[\mathrm{FF} 1_{d}\right] \\ & \\ & \quad+\left[\bar{T}_{0}\right] \cdot\left[F 1_{d}\right] \end{aligned}$ | F1 | 1 CSG <br> F1SG <br> F3SG <br> FBIG <br> GJCS <br> GMO $\alpha$ <br> IFOG <br> IF2G <br> IF3G <br> IRSG <br> ISFG <br> I*F1G <br> JCLG <br> $\left.\begin{array}{l}\alpha^{*} 1 \\ \text { through } \\ \alpha^{*} 12\end{array}\right\}$ <br> $\omega 6$ | $\begin{aligned} & 1 \\ & 2_{d} \\ & 1_{d}, 2_{d} \\ & 1_{d} \\ & \frac{1}{3}, 2 \\ & 1_{d} \\ & 1_{d} \\ & 1_{d}, 2_{d}, \\ & 3_{d}, 4_{d} \\ & 1_{d} \\ & 1 \\ & 2_{d} \\ & 1_{d}, 2_{d} \\ & 1 \\ & 1, \overline{3} \\ & 2 \end{aligned}$ | F1SG | Phase 1 signal |
| F2 | $\begin{aligned} & {[\mathrm{COI}] \cdot\left[\mathrm{IF}_{d}\right]} \\ & \quad+\left[\overline{\mathrm{OEP}}_{d}\right] \cdot\left[F 2_{d}\right] \end{aligned}$ | F'2 | $\begin{aligned} & \text { ASAI } \\ & \\ & \text { ASBI } \\ & \\ & \text { ASCG } \\ & \\ & \text { ASPS } \\ & \text { ASSG } \\ & \text { CIAS } \\ & \text { F2SG } \\ & \text { GOEP } \\ & \text { GMO } \alpha \\ & \text { ISPS } \\ & \\ & \text { ITCF } \\ & \text { I*F1G } \\ & \text { MCCL } \\ & \text { MUSG } \\ & \text { PQSG } \\ & \text { S1AR } \\ & \text { S1ER } \end{aligned}$ | $1,2,3$, 4 $1,3,4$, 5 $1,2,3$, 4,5 1,5 $1,2,3$ 1,2 $2_{d}$ $\frac{1}{3}, 2$ $\frac{1}{3}$ $1,2,3$, 4 2,3 $3_{d}$ $\overline{1}_{d}, 2_{d}$ $1,2,3$ $1,2,3$ 2 $1,2,3$, 4 | F2SG | Phase 2 signal |

Table A-6. Operations Phase-generator Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| F2 | $\begin{gathered} {[\mathrm{SHS}] \cdot\left[T_{0}\right] \cdot\left[F 1_{d}\right]} \\ +[\mathrm{CLS}] \cdot\left[F 1_{d}\right] \\ \cdot\left[T_{0}\right] \\ +[\mathrm{COI}] \cdot\left[\mathrm{IF} 3_{d}\right] \\ +\left[\mathrm{OEPP}_{d}\right] \cdot\left[F 3_{d}\right] \end{gathered}$ | $F 3$ | S18ER | 1, 3, 4 | F3SG | Phase 3 signal |
|  |  |  | S1IR | 1, 2 |  |  |
|  |  |  | SOAH |  |  |  |
|  |  |  | SOBH | 1, 2 |  |  |
|  |  |  | SPDG | 1, 2, 3, |  |  |
|  |  |  |  | 4,5 |  |  |
| F3 |  |  | ASBI |  |  |  |
|  |  |  | ASPS | 2, 3, 4 |  |  |
|  |  |  | F3SG |  |  |  |
|  |  |  | GMIB | 2, 3 |  |  |
|  |  |  | GOEP | 3, 4 |  |  |
|  |  |  | GSCC |  |  |  |
|  |  |  | I*F1G |  |  |  |
|  |  |  | MCCL | $\overline{1}_{d}, 3_{d}$ |  |  |
|  |  |  | SOBH |  |  |  |
|  |  | FBI | S5AR | 1,2 |  |  |
| FBI | $\begin{aligned} & {[00 \mathrm{D}] \cdot\left[T_{0}\right]} \\ & \cdot\left[F 1_{d}\right]+[\mathrm{STB}] \\ & \cdot\left[T_{0}\right] \cdot\left[\mathrm{ISF}_{d}\right] \\ & +\left[\bar{T}_{0}\right] \cdot\left[\mathrm{FBI}_{d}\right] \\ & +\left[\mathrm{EWI}^{2}\right] \\ & \cdot\left[\mathrm{FBI}_{d}\right] \end{aligned}$ |  | BSPG |  | FBIG | Phase FBI |
|  |  |  | BU1 |  |  | signal; during |
|  |  |  | FBIG | $3_{d}, 4_{d}$ |  | this phase one |
|  |  |  | RIBG |  |  | word from |
|  |  |  | STBG |  |  | input unit is |
|  |  |  |  |  |  | read into |
|  |  |  |  |  |  | buffer |
| FBO | $\begin{aligned} & {\left[T_{0}\right] \cdot\left[\mathrm{FOO}_{d}\right]} \\ & +\left[\bar{T}_{0}\right] \cdot\left[\mathrm{FBO}_{d}\right] \\ & +[\overline{\mathrm{EWO}}] \\ & \cdot\left[\mathrm{FBO}_{d}\right] \end{aligned}$ | FBO | BSPG |  | FBOG | Phase FBO |
|  |  |  | FBOG | $2{ }_{d}, 3_{d}$ |  | signal; during |
|  |  |  | ROBG |  |  | this phase one |
|  |  |  |  |  |  | word from |
|  |  |  |  |  |  | buffer is read |
|  |  |  |  |  |  | into output |
| FOI | $\begin{aligned} & {[\mathrm{COI}] \cdot\left[\mathrm{IFI}_{d}\right]} \\ & \quad+\left[\bar{T}_{0}\right] \cdot\left[\mathrm{FOI}_{d}\right] \end{aligned}$ | FOI |  |  | FOIG | Phase FOI |
|  |  |  | FOIG | $2_{\text {d }}$ |  | signal; during |
|  |  |  | GMIB | 1 |  | this phase one |
|  |  |  | I'F1G | $\mathbf{1}_{\text {d }}$ |  | word from |
|  |  |  |  |  |  | buffer is read |
|  |  |  |  |  |  | into drum |
| FOO | $\begin{aligned} & {[\mathrm{COI}] \cdot\left[\mathrm{IFO}_{d}\right]} \\ & +\left[\bar{T}_{0}\right] \cdot\left[\mathrm{FOO}_{d}\right] \end{aligned}$ | FOO | $\begin{aligned} & \text { BSPG } \\ & \text { BU1 } \end{aligned}$ | 3 2 | FOOG | Phase FOO signal; during |
|  |  |  | FBOG | $1_{d}$ |  | this phase one |
|  |  |  | FOOG | $2{ }_{\text {d }}$ |  | word is read |
|  |  |  | GMO $\alpha$ | $\overline{3}$ |  | from drum |
|  |  |  |  |  |  | into buffer |
| IFO | $\begin{aligned} & {[21 D] \cdot\left[T_{0}\right] \cdot\left[F 1_{d}\right]} \\ & \quad+[\overline{\mathrm{COI}}] \cdot\left[\mathrm{IFO}_{d}\right] \end{aligned}$ | IFO |  |  | IFOG | Phase IFO |
|  |  |  | IFOG | $2_{\text {d }}$ |  | signal; this is |
|  |  |  |  |  |  | an idle phase; |
|  |  |  |  |  |  | drum section |
|  |  |  |  |  |  | is being |
|  |  |  |  |  |  | selected |

Table A-6. Operations Piase-generator Signals (Continued)

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Name of signal} \& \multirow{2}{*}{Equation} \& \multirow[t]{2}{*}{Time period present} \& \multicolumn{2}{|l|}{Destination} \& \multirow[t]{2}{*}{Generation location} \& \multirow{2}{*}{Remarks} \\
\hline \& \& \& Package \& Gate \& \& \\
\hline IF1 \& \[
\begin{aligned}
\& {\left[\mathrm{I}^{\prime} \mathrm{F} 1\right]+[\mathrm{I} * \mathrm{~F} 1]} \\
\& +[\overline{\mathrm{COI}}] \cdot\left[\mathrm{IF} 1_{d}\right] \\
\& \cdot[\mathrm{ISF}]
\end{aligned}
\] \& IF1 \& \begin{tabular}{l}
EWOG \\
F1SG \\
IF1G \\
ISFG \\
RUBG \\
\(\left.\begin{array}{l}\alpha^{*} 1 \\ \text { through } \\ \alpha^{* 12}\end{array}\right\}\)
\end{tabular} \& \[
\begin{aligned}
\& \overline{1}_{d}, \overline{2}_{d} \\
\& 1_{d} \\
\& 3_{d} \\
\& 3_{d} \\
\& \overline{2}_{d} \\
\& 2, \overline{3}
\end{aligned}
\] \& IF1G \& Phase IF1 signal; idle phase signal \\
\hline I'F1 \& \[
\begin{aligned}
\& {[\mathrm{EWO}] \cdot\left[T_{0}\right]} \\
\& \quad+\left[\overline{\mathrm{FOF}}_{d}\right] \cdot\left[T_{0}\right]
\end{aligned}
\] \& IF1 \& IF1G \& 2 \& I'F1G \& Phase I'F1 signal; auxiliary idle phase signal \\
\hline I*F1 \& \[
\begin{aligned}
\& {[43 D] \cdot\left[F 1_{d}\right]} \\
\& +[44 D] \cdot\left[F 1_{d}\right] \\
\& +\left[\mathrm{OEP}_{d}\right] \cdot\left[F 2_{d}\right] \\
\& +\left[\mathrm{OEP}_{d}\right] \cdot\left[F 3_{d}\right] \\
\& +\left[\mathrm{RUB}^{2}\right] \cdot\left[T_{0}\right] \\
\& \cdot\left[\mathrm{ISF}_{d}\right]
\end{aligned}
\] \& IF1 \& IF1G \& 1 \& I*F1G \& Phase I*F1 signal; auxiliary idle phase signal \\
\hline IF2 \& \begin{tabular}{l}
[ADD] \(\cdot\left[T_{0}\right]\) \\
\(\left[F 1_{d}\right]+[\mathrm{SUB}]\) \\
\(\left[T_{0}\right] \cdot\left[F 1_{d}\right]\) \\
\(+[\mathrm{LDS}] \cdot\left[T_{0}\right]\) \\
\(\left[F 1_{d}\right]+[\mathrm{PQS}]\) \\
\(\left[T_{0}\right] \cdot\left[F 1_{d}\right]\) \\
\(+[\overline{\mathrm{COI}}] \cdot\left[\mathrm{IF} 2_{d}\right]\)
\end{tabular} \& IF2 \& F2SG IF2G \& \[
\begin{aligned}
\& 1_{d} \\
\& 5_{d}
\end{aligned}
\] \& IF2G

IF3G \& Phase IF2 signal; idle phase signal <br>

\hline IF3 \& $$
\begin{gathered}
{[\mathrm{TRS}] \cdot\left[T_{0}\right] \cdot\left[F 1_{d}\right]} \\
+[\mathrm{COI}] \cdot\left[\mathrm{IF} 3_{d}\right]
\end{gathered}
$$ \& IF3 \& F3SG IF3G \& \[

$$
\begin{aligned}
& 3_{d} \\
& 2_{d}
\end{aligned}
$$
\] \& IF3G \& Phase IF3 signal; idle phase signal <br>

\hline IFI \& $$
\begin{aligned}
& {[\mathrm{EWI}] \cdot\left[T_{0}\right]} \\
& \quad+[\overline{\mathrm{COI}}] \cdot\left[\mathrm{IFI}_{d}\right]
\end{aligned}
$$ \& IFI \& EWIG FOIG IFIG \& \[

$$
\begin{aligned}
& \overline{1}_{d}, \overline{2}_{d} \\
& 1_{d} \\
& 2_{d}
\end{aligned}
$$
\] \& IFIG \& Phase IFI signal; idle phase signal <br>

\hline ISF \& \[
$$
\begin{aligned}
& {[\mathrm{UTS}] \cdot\left[\overline{\mathrm{UTS}}_{d}\right]} \\
& +[60 \mathrm{D}] \cdot\left[T_{0}\right] \\
& \cdot\left[F 1_{d}\right]+[\mathrm{SPB}] \\
& \cdot\left[T_{0}\right] \cdot\left[\mathrm{IF} 1_{d}\right] \\
& +[\bar{T}] \cdot[\mathrm{ISF} \\
& +\left[\overline{\mathrm{STTB}_{d}}\right] \cdot[\overline{\mathrm{RUB}}] \\
& \cdot\left[\mathrm{ISF}_{d}\right]
\end{aligned}
$$

\] \& ISF \& | FBIG ISFG |
| :--- |
| I*FIG |
| RUBG |
| SPBG |
| STBG |
| STCG |
| IF1G | \& \[

$$
\begin{aligned}
& 2_{d} \\
& 4_{d}, 5_{d} \\
& 5_{d} \\
& \frac{1}{1} \\
& \overline{1}_{d}, \overline{2}_{d} \\
& 1 \\
& 1 \\
& 3
\end{aligned}
$$
\] \& ISFG \& Phase ISF signal; this is the stopped idle phase signal <br>

\hline RIB \& $\left[T_{0}\right] \cdot[\mathrm{FBI}]$ \& $T_{0}$ \& Input-unit chroniz \& it syn- \& RIBG \& Signal to in-put-unit synchronizer, allowing input unit to take over control <br>
\hline
\end{tabular}

Table A-6. Operations Phase-generator Signals (Continued)

| Name of signal | Equation | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Package | Gate |  |  |
| ROB | [ $T_{0}$ ] [ [FBO] | $T_{0}$ | Output u chronize | syn- | ROBG | Signal to out-put-unit synchronizer, allowing output unit to take over control |
| RUB | $\begin{aligned} & {\left[\mathrm{RUB}^{\prime}\right] \cdot\left[\bar{T}_{0}\right]} \\ & \cdot[\mathrm{ISF}]+\left[\mathrm{RUB}_{d}\right] \end{aligned}$ $\left[\overline{\operatorname{IF}}_{d}\right]$ | As generated | $\begin{aligned} & \text { ISFG } \\ & \mathrm{I} * \mathrm{FIG} \end{aligned}$ RUBG | $\begin{aligned} & \overline{5} \\ & 5 \\ & 2_{d} \end{aligned}$ | RUBG | Run-button signal |
| SPB | $\begin{aligned} & {\left[\mathrm{SPB}^{\prime}\right] \cdot\left[\bar{T}_{0}\right]} \\ & \cdot\left[\overline{\mathrm{SFF}}_{d}\right] \\ & +\left[\mathrm{SPB}_{d}\right] \cdot\left[\overline{\mathrm{ISF}}_{d}\right] \end{aligned}$ | As generated | F1SG ISFG <br> SPBG | $\begin{aligned} & \bar{z}^{u} \\ & 3 \\ & 2_{d} \end{aligned}$ | SPBG | Stop-button signal |
| STB | $\begin{aligned} & {\left[\mathrm{STB}^{\prime}\right] \cdot\left[\bar{T}_{0}\right]} \\ & \cdot\left[\mathrm{ISFF}^{2}+\left[\overline{\mathrm{FBI}}_{d}\right]\right. \\ & \cdot\left[\mathrm{STB}_{d}\right] \end{aligned}$ | As generated | FBIG <br> ISFG <br> STBG <br> STCG | $\begin{aligned} & 2 \\ & \overline{5} \\ & 2_{d} \\ & 1 \end{aligned}$ | STBG | Start-button signal |

Table A-7. Signals from Line Synchronizers (External Equipment)

| Name of signal | Time period present | Destination |  | Generation location | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Package | Gate |  |  |
| EWO ${ }^{\prime}$ | As generated | EWOG | 1 | Buffer read-out synchronizer | External signal from buffer, indicating a word has been completely read out of buffer |
| EWI' | As generated | EWIG | 1 | Buffer read-in synchronizer | External signal from buffer, indicating a word has been completely read into buffer |
| IEQ | As generated | BU1 | 1 | Input-unit synchronizer | This signal is the word from the input unit being read into buffer |
| RUB ${ }^{\prime}$ | As generated | RUBG | 1 | Run-button synchronizer | External run-button signal |
| SIU | As generated | BSPG | 1 | Input-unit synchronizer | Shift-pulse signal from input unit |
| SOU | As generated | BSPG | 4 | Output-unit synchronizer | Shift-pulse signal from output unit |
| SPB' | As generated | SPBG | 1 | Stop-button synchronizer | External stop-button signal |
| STB' | As generated | STBG | 1 | Start-button synchronizer | External start-button signal |

## NAME INDEX

Abbas, S. A., 721
Abbott, H. W., 721
Abhyankar, S., 366
Abramowitz, M., 210
Ackerman, W., 317
Ainsworth, E. F., 763
Albers-Schoenberg, E., 723
Aldrich, R. W., 687
Alexander, M. A., 757, 758
Alexander, S. N., 542
Allen, L. E., 319
Allen, R. G., 643
Alt, F. L., 23, 129, 213
Anderson, A. E., 685
Anderson, J. R., 720
Andrews, L. J., 720
Arsenault, W. R., 758
Ashby, W. R., 56
Ashenhurst, R. L., 719
Auerbach, I. L., 720

Babbage, C., 56
Baggott, B. A., 214
Bain, M. B., 760
Baker, R. H., 723
Baldwin, J. A., Jr., 721
Bambrough, B., 720
Barker, R. H., 760
Bates, L. F., 719
Bauer, E. W., 719
Beam, W. R., 723
Beckett, F., 760
Bell, D. A., 253
Bellman, R., 643
Bemer, R. W., 172
Bennion, D. R., 721
Berlin, R. D., 483
Bernstein, B. A., 316
Beter, R. H., 685
Bindon, D. G., 758
Birkhoff, G., 92, 253
Bittmann, E. E., 759
Bivans, E. W., 757
Blachman, N. M., 757

Blankenbaker, S. V., 128
Blattner, D. J., 723
Bliss, W. H., 762
Blois, M. S., 759
Blum, E. K., 158
Bobeck, A. H., 721
Bohm, D., 680
Bonn, T. H., 720, 722
Boole, G., 295, 296, 316
Booth, A. D., 23, 757
Booth, G. W., 686
Bothwell, T. P., 686
Bowden, B. V., 23, 56
Boyle, D. R., 658, 662
Bozarth, R. M., 719
Bracken, R. H., 253
Bradley, W. E., 685
Bradspies, S., 758
Bremer, J. W., 722
Bridgers, H. E., 684
Brillouin, L., 56
Brown, A. B., 254
Brown, D. R., 719
Brown, J. H., 760
Brown, R. B., 685
Buck, D. A., 711, 722, 757
Burke, H. E., 760
Burtsev, V. S., 541
Bush, V., 286
Butler, S. A., 688

Caldwell, S. H., 367
Callen, H. B., 759
Canning, R. G., 23
Carey, R. S., 255
Carey, W. M., 720
Carnap, R., 319
Carroll, J. M., 762
Carroll, W. N., 686
Carter, I. P. V., 758
Cayley, A., 786
Chang, K. K. N., 687, 688
Chapin, N., 23
Chaplin, G. B. B., 686

Chen, W. H., 483
Cheng, C.-C., 685
Chow, W. F., 687
Church, A., 317
Clark, E. G., 686
Clark, W. A., 722
Coblenz, A., 685
Cohen, A. A., 757
Cohen, M., 317
Coleman, R. P., 719
Comstock, G. E., 757
Conger, R. L., 757, 759
Cooper, R. A., 686
Craig, L. J., 761
Crane, H. D., 721
Critchlow, D. L., 688, 721
Cronin, F. R., 760
Crosby, R. L., 686
Crowley, T. H., 721
Curtiss, J. H., 213

Dacey, G. C., 687
David, E. E., 762
Davidson, J. T., 762
Davidson, L., 319
Davies, D. W., 253
Davis, M., 129
Davis, P. J., 213
DeBacker, M., 254
DeBlois, R. W., 719
De Latil, P., 56
De Morgan, A., 302, 444
Dennis, B. K., 253
Depian, L., 643
Deuitch, D. E., 685, 686
Devenny, C. F., 720
DeWitt, D., 685
Diamond, T. L., 762
Dickinson, W. E., 758
Dineen, G. P., 762
Donan, J. F., 286
Dorey, P. F., 720
Dreyfus, P., 287
Dreyfus, S., 643
Drucker, P. F., 287
Duda, W. L., 723
Dunlap, C. W., Jr., 684
Dunwell, S. W., 287

Early, J. M., 687
Easely, J. W., 685, 686
Ebers, J. J., 685
Eckert, J. P., Jr., 287, 757
Eckert, W. J., 23
Edmundson, H. P., 23

Edson, W. A., 723
Elbourn, R. D., 336
Eldridge, O., 720
Elias, P., 254
Elliot, W. S., 760
Endres, R. O., 685
Enenstein, N. H., 685
Engelbart, D. C., 721
Engineering Research Associates, Inc., staff, 542
Epstein, H., 762
Esaki, L., 679, 687
Evans, D. S., 760
Evans, W. G., 720
Everett, R. R., 757

Fairthorne, R. A., 254
Farley, B. G., 685, 722
Feller, W., 213
Fogel, L. S., 56
Follingstad, H. G., 760
Forrand, W. A., 760
Forrer, M. P., 723
Forrester, J. W., 757
Fortune, R. L., 762
Foss, E., 757
Foss, F. A., 760
Fowler, C. A., 759
Frank, E., 212
Frank, W. I., 757
Frankel, S. P., 129
Franklin, G. F., 761
Freedman, A. L., 720
Friedman, D. C., 686
Friedman, M. J., 758
Friend, E. H., 253
Fryer, E. M., 759
Fuller, H. W., 757

Gass, S. I., 23
Geller, S. B., 658, 662
Gettings, H., 762
Geyger, W. A., 720
Giacoletti, L. J., 685
Gianola, U. F., 719, 721, 759
Gibbons, J. F., 687
Giguere, W. J., 723
Gilbert, E. N., 483
Gill, S., 129
Gillies, D. B., 542
Gilmore, J. W., 319
Golay, M., 254
Goldstine, H. H., 93, 129
Goode, H. H., 287
Goodenough, J. B., 719, 759

Gotlieb, C. C., 23
Goto, E., 643, 680
Grabbe, E. M., 214
Grea, R. A., 367
Greanias, E. C., 762
Greenwald, S., 542
Grinich, V. H., 687
Grisamore, N. T., 542, 643, 686
Guilleman, E. A., 174
Guterman, S., 720, 757
Gyorgy, E. M., 719

Haas, I., 687
Hagen, G. E., 757
Haibt, L. H., 723
Hall, W. G., 720
Hamilton, D. J., 687
Hamming, R. W., 254
Hannay, N. B., 684
Harrington, J. V., 719
Harris, B., 336, 366
Harris, J. R., 686
Hartley, M. G., 762
Hartree, D. R., 286
Harvard Computing Laboratory staff, 542
Harwood, W. J., 721
Hastings, C., 192, 213, 214
Heasley, C. C., Jr., 763
Hebb, D. O., 722
Helbig, W. A., 757
Henle, R. A., 686
Henn, W., 760
Henrici, P., 180
Hert, A., 254
Heuter, R. O., 542
Highleyman, W. H., 763
Higonnet, R. A., 367
Hilbert, D., 295, 317
Hildebrand, F. B., 214
Ho, Y. C., 9
Hoagland, A. S., 757
Hoffman, G. R., 719
Hogue, E. W., 703, 720
Hoh, A. W., 758
Hohn, F. E., 367, 442
Holland, J. H., 723
Hollander, G. H., 760
Holonyak, N., Jr., 687
Holt, A. W., 686
Hoppel, C. J., 762
Horn, H. S., 760
Hosken, J. E., 253
House, C. B., 759
Householder, A. S., 214
Huffman, D. A., 254, 367
Hume, J. N. P., 23

Humphrey, W. S., Jr., 367
Hunt, M. M., 287
Hunter, L. P., 685, 719
Huntington, E. V., 316
Hushimi, D., 643
Husman, P. A., 757

Isaac, E. J., 253
Isborn, C., 720

Jamison, J. H., 723
Jeenel, J., 23, 129
Jevons, W. S., 316
Johnson, C. L., 24
Johnson, E. C., 9
Johnson, K. C., 721
Johnson, R. B., 763
Jones, R., 23
Jordan, C., 212
Jury, E. I., 760

Kahn, H., 213
Kamentsky, L. A., 763
Karnaugh, G., 363, 366
Karnaugh, M., 720
Kasner, E., 93
Kataoka, K., 643
Katz, H. W., 684, 719
Kaufman, M. M., 721
Kay, A. F., 760
Keister, W., 367
Kelner, R. C., 757
Kilburn, T., 719
Kingston, R. H., 687
Kirsch, R. A., 254, 763
Kittel, C., 759
Kleene, S. C., 156
Klein, M. L., 760
Kloomok, M., 762
Kodis, R. D., 720, 757
Korn, G. A., 24
Korn, T. M., 24
Kornfield, N. R., 721
Kraus, C. J., 722
Krell, A. I., 719
Kruskal, J. B., Jr., 786
Kudela, A. F., 759
Kuder, M. L., 760

Lanczos, C., 214
Ledley, R. S., 23, 129, 171, 254, 319, 366, 408, 413, 540

Lee, C. Y., 483
Lehman, M., 541
Leiner, A. L., 541, 542
Lesk, I. A., 687
Levin, H. S., 129
Levy, C., 214
Lewin, M. H., 687
Li, K., 688
Libaw, W. H., 761
Linvill, W. K., 761
Lippel, B., 761
Livesley, R. K., 23
Lo, A. W., 685, 687, 688, 722
Loberman, H., 773, 786
Locke, W. N., 23
Lockhart, N. F., 721
Loev, D., 720
Lowenschuss, O., 643
Lubkin, S., 542, 758
Luce, R. D., 93, 442
Luce, R. E., 317
Luhn, H. P., 254
Lukoff, H., 758

McAfee, K. B., 684
McCarthy, J., 56, 644
McCluskey, E. J., Jr., 331, 366
McCracken, D. D., 23, 129, 171
McCulloch, W. S., 56, 536, 643
McDonald, H. S., 762
McGuigan, J. H., 758
Machol, R. E., 287
McKay, K. G., 684
McKay, R. W., 542
Mackintosh, I. M., 687
MacLane, S., 92, 253
McLean, J., 643
McMahon, H. O., 722
McMahon, R. E., 686
McNamara, F., 719
McPherson, R. G., 763
Mantek, P. A., 658, 662
Marcovitz, M. W., 685
Marcus, S. M., 687
Marlow, W. H., 271
Mathews, M. V., 762
Matthews, N. F. J., 476
Meagher, R. E., 542
Mealy, G. H., 367
Mee, C. D., 758
Meisling, T. H., 723
Mendelson, M. J., 286
Menyuk, N., 719
Mercer, R. J., 128
Mergler, H. W., 761
Metropolis, N., 213

Meyer, C., 719
Meyer, H. A., 213 •
Meyerhoff, A. J., 720
Mezei, J. E., 643
Michel, P. C., 758
Middlebrook, R. D., 684
Miehle, W., 720
Miller, G. A., 56
Miller, J. C., 688
Miller, P., 687
Miller, S. L., 684
Millman, J., 686
Milne, W. E., 189, 195, 197, 198, 212, 214
Milne-Thomson, L. M., 185
Minnick, R. C., 719
Mitchell, A. L., 761
Mitchell, J. M., 761
Moll, J. L., 685, 687
Mooers, C., 254, 255
Moore, S. F., 643
Morrison, J. J., 761
Moskowitz, F., 643
Muller, D. E., 542
Muroga, S., 643
Murphy, G. J., 761
Murray, F. J., 24
Myers, S. T., 254

Nadler, M., 541
Nagel, E., 317
Nash, J. P., 542
Neff, G. W., 688
Nelson, H., 688
Neumann, J. von, 93, 129, 171; 644
Newhouse, V. L., 720, 721, 758
Newman, J. R., 56, 92, 93
Nicod, J., 318
Nielsen, K. L., 214
Nielson, G., 723
Noll, J. C., 723
Nordyke, H. W., 758
Notz, W. A., 542
Noyes, T., 758

Oakland, L. J., 759
Ogle, J., 763
Olantz, H. T., 128
Olsen, K. H., 686
Olson, C. D., 759
Olson, E. R., 759
Ormsby, R. D., 761
Ortel, W. C. G., 723
Osborne, J. S., 762
Owens, H. L., 685

Page, C. H., 547, 686
Paivinen, J., 720
Palevsky, M., 286
Papian, W. N., 758
Papoulis, A., 721
Partos, P., 761
Partridge, R. S., 757
Patterson, H. J., 687
Perlis, J., 171
Perry, J. W., 254, 255
Peterson, L. C., 685
Peterson, W., 254
Phister, M., Jr., 542
Pieruschka, E., 644
Pike, J. L., 763
Pitts, W., 643
Post, E. L., 482, 483
Potter, J. T., 758
Price, P. J., 688
Pritchard, R. L., 685
Prom, G. J., 686
Prywes, N. S., 720, 722
Putschi, H. N., 761

Quaster, H., 56
Quine, W. van O., 317, 331, 366

Rabinow, J., 749, 753, 763
Rabinowitz, P., 213
Radcliffe, J. M., 688
Raffel, J. I., 758, 759
Ragazzini, J. R., 761
Raiffa, H., 93
Rajchman, J. A., 719, 722, 758
Ramey, R. A., 701, 721
Ramo, S., 214
Raper, J. A., 761
Ray, L. C., 254
Reed, I. S., 254
Reichenbach, H., 296, 317, 319
Reitweisner, G. W., 541
Renwick, W. A., 758
Resnik, I. L., 761
Retzinger, L. P., Jr., 761
Richards, R. K., 542, 722
Rigby, S., 761
Ritchie, A. E., 367
Robbins, R. C., 760
Robertson, J. E., 171, 541, 542
Robinson, A. S., 758, 760.
Rochester, N., 723
Rogers, J. L., 721
Rohm, A. V., 760
Rosenberg, M., 757, 758
Rosenblatt, F., 723

Rosenbloom, P., 483
Rosser, J. B., 317, 483
Rossing, T. D., 719, 759, 760
Rossoff, A. L., 685
Roth, J. P., 366
Rotolo, L. S., 542, 686
Rowe, W. D., 686
Royer, R. G., 686
Rubens, S. M., 719, 759
Rubinoff, M., 685
Ruedy, J. E., 762
Ruhman, S., 720, 757
Rumble, W. G., 722, 757
Rupprecht, E. G., 687
Russell, B., 295, 317
Russell, L. A., 721
Ryder, E. J., 684

Sack, H. S., 721
Sacks, G., 254
Sallo, J. S., 687
Salzberg, B., 684
Salzer, J. M., 761
Samelson, K., 171
Samusenko, A. G., 687
Sanders, R. M., 760
Sands, E. A., 721
Scaff, J. H., 684
Scarborough, J. B., 212, 214
Scarbrough, A. D., 761
Scarrott, G. G., 721
Schiff, L. I., 680
Schissler, L. R., 367, 442
Schmidbauer, O., 758
Schnitzler, P., 688
Schroeder, E., 295, 316, 361, 408
Schwartz, S. J., 687
Scobey, J. E., 684
Seehof, J., 763
Seif, E., 685
Selfridge, O. G., 763
Shannon, C. E., 56, 253, 254, 296, 367, 643, 644
Shapiro, H. S., 255
Shea, R. F., 685
Sheffer, H. M., 318
Shepard, D. H., 763
Shera, J. H., 254
Shive, J. N., 684, 760
Shockley, W., 684, 685, 687
Singleton, R. C., 253
Sisson, R. L., 761
Sittler, R. W., 761
Sklar, B., 688
Slade, A. E., 722
Slaughter, D. W., 762

Slepian, D., 255, 406
Slobodzinski, E. J., 686
Slotnik, D. L., 255
Slutz, R. J., 686
Smith, B. D., 762
Smith, C. V. L., 542, 686
Smith, D. O., 759, 760
Smith, H. M., 763
Smith, J. L., 519, 531, 540-542
Smith, W. R., 441, 476
Snoek, J. L., 719
Sommers, H. S., Jr., 688
Sonderby, I. A., 763
Sparks, M., 684, 685
Spaulding, C. P., 762
Speller, J. B., 762
Sprague, R. E., 286
Staff of Engineering Research Associates, Inc., 542
Staff of Harvard Computing Laboratory, 542
Stegun, I. A., 210
Steinhoff, R., 688
Steizer, F., 723
Stern, J., 254
Stevens, J. R., 759
Storm, H. F., 721
Stratton, J. A., 106
Stringer, J. B., 128
Stuart-Williams, R., 758
Suran, J. J., 721, 761
Susskind, A. K., 761, 762

Takada, S., 643
Takahashi, H., 643
Takashima, K., 643
Taub, A. H., 542
Taub, H., 686
Taylor, N. H., 758
Teal, G. K., 685
Terada, H., 643
Tersoff, A. I., 763
Thompson, L. G., 720
Thorensen, R., 758
Thurston, H. A., 92
Tiemann, J. J., 688
Tillitt, H. A., 253
Title, R. S., 721
Tocker, K. D., 542
Todd, J. A., 213, 406
Tompkins, H. E., 762
Torrey, R. D., 719
Towles, W. B., 762
Turing. A. M., 129
Turquette, A. R., 483

Ulan, S., 213
Ulrich, W., 255
Uyehara, G. U., 542, 686

Van Allen, R. L., 759
Van Nice, R. I., 720, 721
Van Sant, O. J., 719
Veitch, E. W., 363, 366
Venn, J., 361, 364
Villars, C. P., 762
Von Foerster, H., 644
von Neumann, J., 93, 129, 171, 644

Wadel, L. B., 518
Waldhauer, F. D., 685
Waldo, W. H., 254
Wallmark, J. T., 687
Walsh, J. W., 686
Walton, C. A., 762
Wanlass, C. L., 686
Warren, C. S., 722, 757
Warschauer, D. M., 685
Washburn, S. H., 367
Wegstein, J. H., 180
Weik, M. H., 56
Weinberger, A., 519, 531, 540-542, 773, 786
Weiss, E., 286
Welsh, H. F., 758
West, J. C., 759
West, R. E., 763
Wheeler, D. J., 129, 171
White, G. S., 518
White, W. A., 684
Whitehead, A. N., 295, 317
Wiener, N., 56
Wier, J. W., 686, 759
Wigington, R. L., 643, 723
Wilder, R. L., 253, 316
Wildhack, W. A., 254
Wilkes, M. V., 128, 129, 759
Williams, F. C., 759
Williams, J. D., 93
Willis, D. W., 759
Willis, J., 762
Wilson, J. B., 23, 129, 171, 365, 441, 540, 541
Wing, O., 644
Winslow, D. J., 286
Wise, C. S., 255
Wister, A. J., 762
Witt, R. P., 686
Wolstinholme, P., 719
Woo, W. D., 720

Wooldridge, D. E., 214
Wrubel, M. H., 129
Wylen, J., 720

Yaeger, R. E., 760
Yamada, S., 643

Younker, E. L., 759
Yourke, H. S., 686

Zadek, L. A., 761
Zawels, J., 685
Zweizig, J. R., 762

## SUBJECT INDEX

Absolute accuracy, 207
Absolute simplest form, 393
change of variables, 393-396
in circuit design, 400-402
steps in construction, 393
symmetries of Boolean functions, 405
table, 394
transformation to, 396-400
Accelerating convergence of iterative processes, 180-183
flow chart, 182
Acceptor impurities, 647
Access time, in core memories, improving, 726-728
in disk memories, 737
in parallel memories, 486
in serial memories, 564
Accumulator, 31, 84, 86
of digital differential analyzer, 258
as shift register, 488
use of, in serial addition, 503
in serial multiplication, 511
Accuracy, 203-211
absolute, 207
relative, 206
Acoustic mercury-delay-line memory, 5051
Active region, transistor operation, 655
Add instruction, functions assigned to
phases, in four-address system, 544
in one-address system, 545
in three-address system, 544
in two-address system, 544
Adder, 35-37, 491
input control signal, 558
logical operations using, 496
parallel, auxiliary carry functions, 522525
binary, logical design, 519-526
decimal, logical design, 526-528
serial, 35-37
binary, logical design, 491-494
decimal, logical design, 506-510
three-valued logic, 407
(See also Addition)

Adder and subtractor combination, parallel, binary, 525
decimal, 526
of Pedagac, 597
serial, binary, 494
decimal, 508
with input subtractive complementer, 510
with output subtractive complementer, 510
Addition, binary, 69
biquinary, 518
decimal, advantage, 506
biquinary, 518
excess-three, $91,506-508$
rules for, 507
definition, 503
logical (see Logical addition)
octal, 69
sexadecimal, 71
Addition instructions, 112
Addition operation, floating, 538
in serial arithmetic unit, 502
Addition tables, 70
Address, assignment, 151, 153-155
definition, 30
generalized, 274-278
relative, 109
selection, 543-546, 559-561
Addressing, indirect, 128
Airline reservation system, 20-21
Algebra of digital circuits, 308
symbolization, 308
Algebraic compiler, 156-158
flow chart, 158
writing, 156-158
Algebraic decoder, 155-156
Algebraic language, definition, 160
IBM Fortran I and II, 171
internation (see ALGOL)
ALGOL (algorithmic language), 159-171
procedure, 168
subroutines, use, 168-170
syntax, 160
declarations, 166-168

ALGOL (algorithmic language), syntax, expressions, 161-162
statements, 161-166
$\alpha$ of transistor, 652, 653
Alphabetic wiring table, 786
Ampère's law, review, 689-691
Amplification, dynamic gating system, 624, 626
magnetic, diode-gated packages, 698703
static gating systems, 626
transistor, diode-gated package, 669671
Amplifier, transistor, 669
Analog computer applications, bibliography, 24
Analog-to-digital conversion, 739, 742, 744-747
bibliography, 760-762
discrete sampling, 740-742
electronic, 744-747
doubling method, 745-746
feedback method, 745
ramp method, 747
mechanical, 742
recovering a signal, 740
sampling frequency, 742
sampling theorem, 742
Anatomy of language, 160
and gates, 38-40, 309
basic building blocks, 38-40, 576
core, 705
cryotron, 712,713
microwave, phase-script, 715, 716
pulse-script, 717
multiaperture device, 710, 711
and inverter, $540,577,578,669,673,674$
and-not gate, 540, 577, 578, 669, 673, 674
and-or diode-gated packages, 577, 669
Antecedence solution, 424
logical interpretation, 476-479
of type-2 circuit problems, 451
Applications, of analog computers, bibliography, 24
of digital computers and control, 1-24
aids to medical diagnosis, 21-23
airline reservation system, 20-21
bibliography, 23-24
data processing, 18-23
design of lens systems, 6-9
hydrodynamics of blood flow, 5-6
machine-tool control, 9-11
man-machine simulation system, 1618
motion of charged particles (Argus project), 2-5
numerical solutions to equations, 2-9

Applications, of digital computers and control, process control, $9-13$ simulations, $13-18$
Approximation for digital computers, reference, 213
Arguments, definition, 26
selection, 28
Argus project, 2-5
Arithmetic control, 553-559
instruction decoder, 553
internally generated signals, 557-559 adder input control, 558
register shift control, 557
operations signal generators, 554-556
Arithmetic instructions, 110-113
Arithmetic operations, control, 543
(See also Control)
floating, 538-540
number system, 69
parallel, 519-528
rapid, 528-537
significant figures in, 207-211
Arithmetic units, 27
bibliography, 542
block diagram of Pedagac, 585
control, 28
(See also Control)
differencing, 503
parallel, 525-528
Pedagac, 288, 590-606
horizontal description, 595-606
vertical description, 590-594
summing, 503
Array-manipulation computer, 280
(See also Business logistic computer)
Array notation, 274
Associativity of Boolean matrix operations, 442
Automata bibliography, 56
Automatic coding systems in operation, 172
(See also Automatic programming;
Automatic programs)
Automatic programming, 130-172
computing speed, 148-150
memory allocation, 148
purpose, 159
Automatic programs, 139-172
compiler routine, address assigner, 151, 153-155
advantages, 149
algebraic, 155-159
decoder, of algebraic symbols, 151, 155
of loop symbols, 151,158
recursive, 151, 158
translator, 151

Automatic programs, interpretive routines, simulational, 142-148
Automonitor program, 132-133
Auxiliary bits, 109-110
break points, 109
relative addresses, 109-110
uses, 109
Auxiliary carry functions, parallel adder, 522-525
Auxiliary switches, 126
Avalanche breakdown in diode, 650
Axiomatic development of Boolean algebra, 315
bibliography, 316

Base of transistor, 652
(See also Transistors)
Basis, 321
constrained, 369, 505
designation numbers with respect to, 370
determining, 369
logical, 321
positions of columns, 321
standard, 322
and truth table, 323
Best-fit polynomial, approximation, 184, 190-193, 213
$\beta$ of transistor, 653
Bibliography, analog-to-digital conversion, 760
applications, analog-computer, 24
of digital computers and controls, 23
arithmetic units, 542
Boolean algebras, foundation and axiomatic approach, 316
Boolean functions, simplification, 366
Boolean matrices, 442
brain mechanism, 722
cryotron, 722
cybernetics, 56
digital-to-analog conversion, 760
digital differential analyzer, 286
diode digital circuits, 685
error detecting and correcting codes, 254
information retrieval, 253
input-output methods, 762
logical translation of English, 319
magnetic-core circuits, 720
magnetic-element physics, 719
maintenance and program debugging, 171
memory systems, 757-759
microwave components, 723
Monte Carlo method, 213

Bibliography, multiaperture magnetic devices, 721
multiple-component computing system, 287
multivalued logic, 483
numerical analysis, 213-214
parametron, 643
programming, 129
rapid arithmetic operations, 541
reliability, 643
semiconductor devices, 685-688
semiconductor physics, 684
sorting and ordering, 253
switching circuits, 367
symbolic logic, formal theory, 317
system engineering, 287
thin-film techniques, 759
transistor digital circuits, 685
transistor equivalent circuits, 685
tunnel diodes, 687
wiring diagrams, 786
Binary addition table, 70
Binary arithmetic operations, 69-71
Binary-coded decimal (see Decimalcoded binary codes)
Binary codification, 244
Binary-decimal conversion, 67-69
Binary division, rapid, 533-537, 540
in serial arithmetic unit, 513
Binary multiplication, rapid, 528-533
in serial arithmetic unit, 511
table, 70
Binary number system, 63, 64
Binary numbers and bits, 34
Binary-octal conversion, 67
Binary point, 290
Binary-sexadecimal conversion, 67
Binary words, 34
Binomial-coefficient look-up routine, 100
Biquinary addition, 518
Biquinary code, 517
Bit dropping, 136
Bit failure, 639
Bit-handling instructions, 114-115
Bits, auxiliary, 109-110
Block of words, 117
Block diagram, digital computer, 26-33
Pedagac, 580-586
arithmetic unit, 585
Boolean algebra, 295, 302-304, 320
as algebra, of digital circuits, 308-315 symbols for, 311
of sets, 304-306, 361
axiomatic development, 315-316
bibliography, 316
constrained, 372

Boolean algebra, equations, 302
historical background, 295
operations, 298, 317-318
postulates, equivalent, 316
independent, 316
primitive (tautologies), 316-317
sets, 316
representation, as hypercube, 361
as lattice diagram, 362
searching problem in, 407
Sheffer's stroke, 318
substitution rule, 316
use in sentential problems, 408
(See also Logical addition)
Boolean equations, in circuit design, 389-391
of equivalence, solution, 384-386
of implication, solution, 386-388
inverse solution, 468-470
linear, 379-383
method of recording logical design, 576
Pedagac, 787-806
simultaneous, general method of solu" tion, 384-388
linear, 383
solution by Boolean matrices, 466-468
Boolean functions, chart methods for simplification, 362-364
to circuit diagram, 314
constrained basis, 371
definition, 298
designation number, 322
E, 414-419
F, 414-419
$f_{\mathrm{s}}, 414-419$
first canonical form, 324
included and nonincluded elementary elements, 326-329
logical dependence, 374
logical independence, 374
mongrel form, 328-331
relation to Boolean matrices, 419-424
second canonical form, 325
simplest product of sums, 336, 342
simplest sum of products, by HarrisElbourn method, 336-342
by Quine-McCluskey method, 331336
unknown, 379
(See also Boolean equations)
Boolean lattice diagram, 362
Boolean matrices, bibliography, 442
constraints, $E$ matrices, 463
$F$ matrices, 464
$R$ matrices, 464-465
definition, 356
elements, 356

Boolean matrices, multiplication, 356
operations and properties, 441-442
as permutations, 397
symbolism for, 356
transpose, 442
types, $\left(E_{k i}\right)$, 419-420, 442-443
( $F_{k j}$ ), 420-421, 442-443
( $R_{j i}$ ), 421-423, 443-445
use in change of variables, 397
Boolean matrix equations, general, solution, 428-434
solutions, all, 445 many-valued logics, 484
in three-value logic, 479
unitary (see Unitary matrix equations)
Bounds of matrix solutions, greatest lower, 435
least upper, 429
lowest, 432-434
Brain mechanism bibliography, 722
Branch, definition, 777
Break points, 109
Buffer, input-output, 570
logical design, 618
Building blocks, and gate, or gate, not gate, 38-40, 576
Business logistic computer, 271-281
basic operations, 273
example, building-material purchase, 272
keeping bank accounts, 273
spare-parts inventory, 271
illustration of coding, 277
instruction format, 273
Business simulation, 14
Buttons (see Pushbuttons)

Canonical form, first, 324
second, 325
Capacitor memory, 53
Card rack of Pedagac, 777
Cardiac computer, 55, 93
Cards, marginal-punched, 223
Pedagac, 767-771
peek-a-boo, 224
searching, 223-226
sorting, 217, 224, 226
Cascaded counters, 488-490, 606
Cell, 30
(See also Memory)
Change of variables, 395-402
absolute simplest form, 396
Channel, of magnetic drum, 562
synchronizing, 573
unit-time interval, 573

Channel selector, logical design, 610-611
Pedagac, 606
in serial memories, 563, 565
Character-reading machines, 749-752
Characteristic curves, grounded-base transistor, 654
grounded-emitter transistor, 654
transistor, 653
tunnel diode, 681
Characteristic list, searching, 519
Characteristics, definition, 215
Charactron tube, 755, 756
Charge density in $p-n$ junction, 649
Chart, prime implicant, 332, 334-336
Chart methods of simplification of
Boolean functions, 362-364
Karnaugh map, 363
Veitch, 363
Checking program ("debugging’), 62, 131-135
Chemical plant, control, 12-13, 262-267
Circuit design, absolute simplest form in, 400-402
computational methods, 320
constraints in, 376-379
elementary computational methods, 368-413
problems, outline, 321
types (see Types of circuit problems)
simplification by constraints, 376 (See also Simplification)
solution to equations, 389-393, 402404, 408-413, 465-470
in three-valued logic, 406
Circuit diagrams, from Boolean function, 314-315
to Boolean function, 309-312
method of recording logical design, 576
Circuits, cryotron, 711-714
current switching transistors, 675
decoding, 547-552
diode matrices, 547
(See also Selection)
diode-gated, 667-672
magnetic amplifier, 698-704
direct-coupled transistor, 674
dynamic, with regeneration, 624,671
magnetic, 689-711
gating with cores, 704-706
Hogue amplifier, 702
multiaperture device, 706-711
Ramey amplifier, 701
shift register, 699
maintenance problem of general net, 474-476
(See also Maintenance routines)

Circuits, majority, 631, 640-642, 706, 718
microwave, 714-718
number of inputs to decoding, 548-551
parametron, 627-631
Pedagac, 765
reliability, general considerations, 634-635
methods of increasing, 636-642
resistor-coupled transistor, 673
states, 357-360
synthesis problem of general net, 473
transistor flip-flop, 676-679
tunnel diode, 680-684
Clamping voltage, 668
Class, 304
equivalence, 253
Clock (oscillator), 35, 573
Clock phases, 632-634
pulses, 632
sequencing, 632
skipping, 634
system of Pedagac, 765
Clock pulse, 34, 487, 488, 571, 572
drum channel, 572
in dynamic circuit, 625
in flip-flops, 626
generation, 571
in packages, 578
in tunnel diodes, 683
Clocking, drum, 572-573
magnetic-tape, 734-737
parallel, 572
serial, 572
Code, codification, definition, 217
program, definition, 45, 60
Coder, definition, 45
Codes, binary, 72, 517
biquinary, 517
decimal, 90-92, 517-518
excess-three, 90-92, 517
5 -cyclic, 517
5-421, 517
2-421, 517
Codification, binary, 244
irredundant, 247-252
nonsubstantive, 242
redundant, self-correcting, 244-247
substantive, 242
superimposed, irredundant, 247-252
Codifying, decoding, 242
definition, 217
efficiency, 243
encoding, 242
purpose, 242
Coding, 54, 60-172
decimal system (see Codes)
decision, 76-78

Coding, introduction to, 60-62
minimum access, 88
special techniques, 118-123
input-output instructions, 120, 291294
multiway branch, 118
switch sensing, 119
table look-up, 121-123
stages in, 61
(See also Codification; Programming)
Coding manual, 72
Pedagac, 289
Coding sheet, 45
Coercive force in magnetic materials, 694
Coincidence signal in serial memory selection, 563
Collection, empty, 227
Collector of transistor, 652, 654, 657
Column-adding routine, 101, 102
(See also Business logistic computer)
Combined element, definition, 298
designation number, 323
(See also Boolean functions)
Commands, definition, 30
(See also Instructions)
Comparison, dummy, 84
Comparison circuit, 137
Comparison instruction, 76, 85, 87
functions assigned to phases, 544
(See also Decision instructions)
Compiler, recursive, 158
Compiler routines, 139
address assigner, 150, 153-155
advantages, 149
algebraic, 155-171
decoder of algebraic symbols, 155
flow chart, 153
purpose, 150
translator, 150-153
Complement, 114
subtractive, 496, 526
(See also Inversion of bit; Negation; not gate)
Complementation, Boolean matrices, 442
Complementer (see not gate; Subtractive complementer)
Computational-array drum, 279
Computer, analog, 2
applications, 1-24
array-manipulation, 280
block diagrams, 26-29, 266, 269, 280, 284, 288
business logistic, 271-281
components, accumulator, 488
adder-subtractor combination, 494, 495
counters, 488-491

Computer, components, parallel adder, 519-525
parallel subtractor, 525-526
serial adder, 492-493
serial subtractor, 494
shift register, 488, 498
subtractive complementer, 496
synchronous dynamic flip-flop, 487488
decimal, 90
digital, 2
digital differential analyzer, 257-262
evolutionary tree, 57
functional description, 30-33
general-purpose, 2
generalized concept, 485
history, 56
information-retrieval, 268-271, 280
large-scale data processor, 281-285
maintenance, 135-139, 474-476
bibliography, 171
minimum, 129
operating modes, 126, 289
operations performed by, 26
parallel, 37, 485-486
pictures, 58-59
real-time control, 262-267
searching, 268-271, 280
serial, 37, 485
special-purpose (see Special-purpose computers)
speed, $27,34,148-150$
systems control, 262-267
terminology, 30, 56
types, 2
Computer words, 30, 45
Computing unit, 26
of digital-differential analyzer, 260
Condition function table, 307, 346
Conditional jump, 87
(See also Negative jump)
Conditions of existence of solution of unitary matrix equations, 436
Conjunction, 298
Conjunctive normal form, 325
Consequence solution, 424
logical interpretation, 476-479
of type 2 circuit problems, 450
Constrained basis, designation numbers in, 370
determination, 369
Constrained Boolean algebra, 372
Constraints, 368-372
in circuit design, 376-379
in $E$ and $F$ matrices, 463
in matrix equation problems, 462-465
in $R$ matrix, 464

Constraints, simplest sum of products under, 371
in type 2 circuit problems, 450
Continued fractions, 184-186
Control, of computer, 543-574
examples, 553-559
of instruction execution, 568-571
of instruction sequencing, 543-546, 559-561
of memory address selection, 559568
by phases, 543-546
digital, 2
applications, 1-24
chemical plant, 12-13, 262-267
inventory, $18-20$
machine-tool, 9-11
process, 2, 9-13
Control consoles, 128
Control generator, 28, 555
Control panel, 124-127
buttons and switches, 126
lights and signals, 124
Pedagac, 289
purposes, 124
Control pulses, 38, 543-574
gating, 43
Control signals, 38, 543-574
for logical operation, 495
Control units, 27, 38, 543-574
logical design, 608
Conversion, analog-to-digital (see Ana-
log-to-digital conversion)
digital-to-analog (see Digital-to-analog conversion)
number, 62-69
from binary to octal or sexadecimal, 67
of fractional parts, from decimal, 66 to decimal, 68
of integers, from decimal, 65 to decimal, 68
Conversion table, 64
Core flipping (see Cores, magnetic, switching)
Core gates, 705
Core gating, 704-711
majority, 706
mirror notation, 704
multihole, 706-711
Core logic, parallel clock-pulse, 702
series clock-pulse, 700
Core memory, 53, 565-568, 724-728
access wires, 567
core selection matrix for, 725
four-dimensional array, 568
increasing selection ratio, 724

Core memory, multihole, 726-728
read-write cycle for, 725
selection ratio, 725
sensing wires, 567
word selection, 563-566
Core selection matrix for magnetic-core memories, 725
Core shift register, 699
Core switching (see Cores)
Cores, magnetic, 53, 693-698
circuits, bibliography, 720
reading from, 54
shape, 566
square-hysteresis loop materials for, 555-566, 693-694
switching, 694-698 with constant-current source, 696 with constant-voltage source, 697 dot notation, 694-695
time of, 697-698
wiring method, 565
Counters, cascaded, 488-490
as current-address register, 606
in computer control, 571-574
current-address (see Current-address register)
cyclic sequence for, 490
in digital differential analyzers, 258
minor-cycle, 573
parallel, 491
Pedagac, 607, 612-613
as recursive circuits, 606
relative, 109, 561
sector, 563, 573
unit time interval, 573
Counting code, cyclic sequence, 490
Covalent bonds in semiconductor devices, 645
Cryotron, 711-714
and and or gates, 712
bibliography, 722
kilomegagate systems using, 722
Current, majority and minority, 648
Current-address counter (see Currentaddress register)
Current-address register, 31, 32, 82, 545
in instruction sequencing, 559-561
logical design, 559-561
Pedagac, 606, 608-609
Current-switching transistor circuits, 674-676
gating in, 676
Curve fitting, 11
(See also Polynomial approximations)
Cutoff region, transistor, 655
Cybernetics and bibliography, 56
Cyclic code, 490, 517

Cyclic code, in analog-to-digital conversion, 743
conversion to binary, 517

Data, definition, 30
Data-processing application, 18-23
Debugging, 62, 131-135
Decimal, infinite, 92
Decimal arithmetic, 70, 90-92, 518
bibliography, 171
parallel, 526-528
serial, 506-510, 516
Decimal-coded binary codes, 517-518
excess-three, 90-92, 506-510, 526-528
Decimal coding system, 90-92
Decimal conversion, 65-68
Decimal method for determining in-
cluded and nonincluded elementary elements, 364
Decision instructions, 108, 115-116
coding with, 76-78
(See also Comparison instruction)
Decision processes, 93
Decisions, management, 15
Decoder, of algebraic symbols, 151,155
instruction, 37, 28, 31, 553-554
(See also Control)
Pedagac, 606, 608-609
Decoding and encoding, 242
Decoding circuits, mutually exclusive outputs, 547
number of inputs to gates in, 548-552 minimizing, 551
special notation for, 548
Decoding function, role of phases in, 546
Delay, through package, 631, 655, 665
unit, 353,501
use of package as, 767
Delay line, 501
De Morgan's rules, 302
Density distribution of holes in base of transistor, 655
Derivation of fundamental matrix equation and formulas, 439-441
Design of circuits that compute functions, 346-351
condition function table, 346
(See also Circuit design)
Designation numbers, 321-324
basis, 321
to Boolean function, 324-343, 362-366
of Boolean functions, 322
Boolean matrices and, 419-423
of combined elements, 322
under constrained basis, 370-372
of elementary elements, 321

Diagonal matrix, 467
Difference, definition, 503
Differencing, 503
(See also Addition; Subtraction)
Differential equations, 200-203
Differentiation, 196-198, 199
by definition, 196
by polynomial approximation, 197
by undetermined coefficients, 199
Diffusion, in semiconductors, 647
in transistors, 651-652
Digital-to-analog conversion, 739, 742744
bibliography, 760-762
electronic, 742
mechanical, 742
(See also Analog-to-digital conversion)
Digital computer applications (see Applications)
Digital computer block diagram, 25-26
Digital control (see Applications; Control)
Digital differential analyzer, 257-262
advantages, 262
bibliography, 286
computing units, 258
concept, 257, 259
programming, 260
purpose, 257
Digital switching circuits (see Gates; Gating)
Digital transducers, 747
(See also Input-output methods)
Digitalization (see Designation numbers)
Diode decoding matrices, diode jumpers, 547-548
Diode digital circuits, bibliography, 685
Diode-gated circuits, 667-671, 698-703
magnetic amplifier, 698-703
negative logic, 668
positive logic, 668
transistor amplifier, 667-671
Diode gates, 310
Diode jumpers, 548
Diode matrices as decoding circuits, 547
Diode memory, 53
Diodes, semiconductor, 647-650
avalanche breakdown in, 650
majority-carrier current, 648
minority-carrier current, 648
state of equilibrium, 648
Zener effect, 650
symbol for, 667
tunnel (see Tunnel diode)
Direct-coupled transistor circuits, 673, 674
Direct switched input transducers, 748

Discrete sampling in analog-to-digital conversion, 740-742
Disjunction, 298
Disjunctive normal form, 324
Disks, magnetic, 737
Division, binary, 513-516
decimal, 516-517
floating-point operation, 538
rapid, 533-537
in computers, 534
flow chart, 535
method, 533
rationale, 535-537
Division algorithm, 92
Division instructions, 113
Domains in magnetic materials, 694
Donor impurities, 647
Doped semiconductors, 647, 680
Doubling method of analog-to-digital conversion, 745, 746
Dropping a bit, 136
Drum, magnetic, 52, 737
nonreturn-to-zero writing methods, 734
reading and writing head, 562
return-to-zero writing, 732-734
Drum memory, array of numbers stored, 274, 563
channels, 562
clocking with, 572
computational-array, 279
parallel read-out, 564
searching, 279
sectors, 562
serial read-out, 562-564
Drum synchronizing channel, 572-573
Dummy comparisons, 84
Dummy instruction, 74
Duty cycle of Pedagac, 766
Dynamic behavior of transistor, 660667
Dynamic circuitry, 624-626
Dynamic flip-flop, 487, 488
initial clearing, 556
Dynamic gating systems, 624-626
Dynamic program debugging, 131-134
automonitor, 132
break-point, 132
$E$ function, 419
$E$ matrix, 420
generation, 420, 442
under constraints, 463
(See also Fundamental matrix equations)
Efficiency of codifying, 243

Electron conduction in semiconductors, 546
Electronic aspects of computer, 38
Electronic design of computer circuitry, 55
Electronic design of Pedagac, 764-786 (See also Pedagac)
Electronic functions of packages, 624
Elementary computational methods in circuit design, 368-413
Elementary elements, 298
designation numbers, 321
included, 326-329
determining, 328-329, 364
independent, 368
nonincluded, 328
Elementary product, 325
Elementary sum, 325
Elements of Boolean matrix, 356
Elimination pairs of positions, 326-329
Emitter of transistor, 652
grounded, 653-654, 656
equivalent circuit for, 658-667
Encoding, 242
Encoding circuits, 553
Energy-band diagram of tunnel diode, 680, 681
English, logical translation, 318
Equality of Boolean matrices, 441
(See also Equivalence)
Equalizer circuit, 41, 42, 137, 312, 314
comparison, 137
Equations, algebraic, 178-183
Boolean algebraic, proving, 302-304
(See also Boolean algebra)
linear, simultaneous, 174-177
numerical solutions as computer applications, 2-9
transcendental, 178-183
Equilibrium in junctions (diodes), 648
Equivalence, Boolean, 299
Boolean equations of, 379-391
simultaneous, 385
(See also Boolean algebra)
Equivalence class, 253
Equivalence relation, 253
Equivalent circuit (see Transistor)
Error, curves for, in function evaluation, 187, 188, 191, 192
experimental, 204
formulas for, in differentiation and integration, 212
pitfalls from, 209-211
relative, 207
sources, 203-204
truncated, 203
(See also Accuracy)

Error detecting and correcting codes, 244-247
bibliography, 254
Essential prime implicants, 335
finding, 337-343
Evolutionary tree of computer development, 57
Excess-three adder-subtractor, 508-510, 526-528
Excess-three addition, 507, 526
Excess-three code, 90, 506-510, 517, 526-528
(See also Decimal-coded binary codes)
Excess-three subtraction, 507-508, 527
Excess-three subtractive complementer. 509-510
Execution of an instruction, 26
control of, 568-571
Expansion of function (see Functions)
Experimental errors, 204
Exponent, floating-point, 110, 538
Exponent unit, 539
Expressions in ALGOL, 161-162
Extract instruction, 114-115
use, 26,5
$F$ function, 420
$F$ matrix, 421
generation, 421, 442
under constraints, 463
(See also Fundamental matrix equations)
Fall phase in transistor equivalent circuit, 666
Fall time in transistor, 655
False drop, probability, 249-252
Faraday's law, review, 691-693
Feedback method of analog-to-digital conversion, 745, 746
Ferrite cores, 694
(See also Cores)
Ferromagnetism, 692
File instruction, 116
Film (see Magnetic-film memory)
Finite differences for polynomials, 211
5 -cyclic code, 517
5-421 code, 517
Fixed memory, large, 753
Flip-flop, 40, 404, 405
synchronous dynamic, 487
initial clearing, 556
transistor, 676-679
Flipping cores (see Cores, magnetic, switching)
Floating point, 110
Floating-point operations, 538-539

Flow charting, 78-79
symbols for, 78, 95
Flow charts, accelerating convergence of iterative processes, 182
algebraic-compiler, 158
computation, of radiation intensity, 107

$$
\text { of } \sqrt{N}, 98
$$

computer routine, 153
evaluation of single function, 159
generalized loop, 97
initial read-in routine, 293
instruction modification, 101
interpretive routine, 143
sequencing, 145
loops within loops, 103
merging of ordered lists, 237
minimum wiring algorithm, 779, 781
missile trajectory, 96
ordering by merging, 239
Pedagac phase sequencing, 581
rapid division, 535
ray tracing, 8
read-in routine, 291
real-time operating program, 265
record common numbers on two ordered lists, 222
serial division, 514
setting up of subroutines, 105
solution, of simultaneous linear equations, 177
of $\sin x=2-2 x, 180$
split-tree method of table look-up, 122
table look-up routine, 100
Flux density, 691
Flux switching (see Multiaperture devices)
Folding theorem, 741-742
for statements in ALGOL, 164
Format, word, 71-77, 82, 84, 86-88
Foundations of Boolean algebra, bibliography, 316
Four-address format, 71-77
Four-address instruction system, func-
tions assigned to phases, 544
Free elections in semiconductors, 646
Function declarations in ALGOL, 167
Function expressions in ALGOL, 162
Function table, definition, 307, 346
Functional calculus of symbolic logic, 296
Functional description of computer, 30-33
Functional failure, probability, 636-640
Functions, evaluation, 183-193, 198-200, 213
best-fit polynomial approximations, 190-193, 213

Functions, evaluation, expansion, continued fraction approximation, 184-186
series approximations, 183
flow chart, 159
interpolation, 186-190
Aitken's method, 189
Monte Carlo method, 213
polynomial approximations, 190-193, 213
undetermined coefficients, 198-199
Fundamental formulas, 425, 439
derivation, 439-441
Fundamental matrix equations, derivation, 440
in $m$-valued Post logic, 483
in three-valued logic, 480

Gates, 35, 38-40, 309-312
and (see and gates)
and-not, 540, 577, 578, 669, 673, 674
cryotron, 711-714
current-switching, 676
decoding, 548-551
digital-differential analyzer, 258260
inverter, 311
or (see or gate)
or-not, 540, 577, 578, 669, 673, 674, 701-702
symbols for, 311, 578
Gating, control pulse, 41-43
(See also Control)
core, 704-711
dynamic, 624-626
flip-flop, 626
flux, 706-711
magnetic, 704-711
majority, 631, 640-642, 706, 718
microwave, 714-718
numerical quantity, 40
parametric, 627-631
phase, 627-631
regeneration, 624-626
static, 626
types, 624-631
(See also Packages)
General net problem, 470-476
General-purpose computer, 2
Generalized address, 274-278
go to statements in ALGOL, 164
Graph, definition, 777
Greatest lower bound of matrix solutions, 435
Grounded-base transistor, 653-654

Grounded-emitter transistor, 653-654, 656
equivalent circuit for, 658-667

Half-adder, 44 (Ex. g)
(See also Logical inequality)
Head, reading and writing, 562, 572, 733
Health computing system, 22
Hexadecimal (see Sexadecimal)
High-speed printer, 49, 754-755
History, computer, 56
Hogue magnetic amplifier, 703
Holes in semiconductor, 646
Hybrid ring, 715-718
Hydrodynamics of blood flow, 5
Hypercube representation of Boolean algebra, 361
Hysteresis loop of magnetic core, 566, 694, 708

Icand register, 511-513, 515-516
Idling mode, 289
Idling phases, 569
Ier register, 511-513, 515-516
if statements in ALGOL, 164
Implicant, definition, 332
(See also Prime implicant)
Implications, 299
Boolean matrices, 441
solution to equations of, 386-388, 402-404
Impurities in semiconductors, 647
In-out selector, 28
Included and nonincluded elementary
elements, determining, 328-329, 364
elimination pairs of positions for, 326-328
Included zero, 529
(See also Isolated units and zeros)
Increasing circuit reliability, 634-642
Index register, 109, 561
Indexing (see Tabledex)
Indirect addressing, 128
Infinite decimals, 92
Information retrieval, 2, 22
bibliography, 253
(See also Business logistic computer)
in-out selector, 28
Input-output buffer, 570
Input-output instruction execution, phases, 570
Input-output methods, 28, 732-763
analog-to-digital conversion, 739, 742, 744-747
bibliography, 762

Input-output methods, character-reading machines, 749-752
direct switched, 748
high-speed printer, 754
magnetic tapes and drums, 732-739
manual write-in, 748
picture displays, 755
picture-reading machine, 752
speeds, 49
Input-output problems, large-scale data processor, 282
Input-output units, Pedagac, synchronization, 619
Input-state diagram of circuit, 358
Input subtractive complementer, 510
Inscriber, 47
Instruction decoder, 28, 31, 37, 553-554
Pedagac, 606, 608-609
Instruction execution, 26
control, 568-571
Instruction format, business logistic computer, 273-277
four-address, 71-77
one-address, 86-89
Pedagac, 290
three-address, 81-84
two-address, 84-86
Instruction modification, 99-102
Instruction register, 31, 559-561
Pedagac, 606, 608-609
Instruction sequencing (see Control)
Instruction types, 108-118
arithmetic, 110-113
bit-handling, 114-115
comparison of words, 115
decision, 115-116
input-output, 117
logical, 114
read and write, 117
recursion-aiding, 116-117
register-modifying, 116-117
shift, 115
switch-sensing, 116
Integration, by definition, 193
by polynomial approximations, 195
by Simpson's rule, 195
by trapezoid rule, 194
by undetermined coefficients, 198-200
Intercedence, 482
International Algebraic Language (see ALGOL)
Interpolation, 186-190
Interpretation of word, 30
Interpretive routines, 139-148
complications, 148
mathematical, 139-142
simulational, 142-148

Intersection of sets, 305
Intrinsic semiconductors, 647
Invariance of implication under multiplication of Boolean matrices, 442
Inventory control, 18-20
(See also Business logistic computer)
Inversion of bit, 323
Inverter gate, 311
(See also and-not gate; not gate; or-not gate)
Isolated units and zeros, 530, 540
Isolation of magnetic core stages, 699
Item, 215
Item list searching, 219
Iteration, 95
and recursion codes, 95-99
Iterative process, accelerating, 180-183

Jump, negative, 115
Jump instruction, conditional (see
Comparison instruction; Decision instructions)
unconditional, 85, 87
Jump table, 118-119, 263
Junctions, semiconductors, 647-650
(See also Diodes)

Karnaugh map, 363
Kilomegagate systems, 722

Labeling of words, 222
Language, 159
anatomy of, 160
International Algebraic (see ALGOL)
Least upper bound of matrix solution, 429
Levels of diode gating in transistors, 670-671
Library of subroutines, 108
Limitations, of packages, 577-578
in parallel carry generation, 520
Linear Boolean equations (see Boolean equations)
Linear ordering, 253
Lines of induction, 691
List, characteristic, 215
item, 215
ordering, 218, 230-241
population-based, 221
searching, 219
substantive-based, 221
Logic, core, parallel clock-pulse, 702-703 series clock-pulse, 701-702
current-switching, 674-676

Logic, majority, 640-642
negative, 668
probabilistic, 636-640
(See also Boolean algebra; Symbolic logic)
Logical addition, 114, 298, 322
Boolean matrix, 442
Logical building blocks, 38-43
Logical-control computer, 262-267
Logical design, adder-subtractor, parallel, 519-525
serial, 491-496
complementer, 496-497
decimal, 509-510
of computer circuitry (see Types of circuit problems)
control (see Control)
counter, 488-491
flip-flop, dynamic, 687-688
methods of recording, 576
Pedagac, 586-621
Logical inequality, 114, 495
Logical instructions, 114-115
Logical multiplication, 114, 297, 322
Boolean matrix, 441
Logical operations, 297-298, 317-318
derived from adder, 494-496
Logical translation of English, 318
bibliography, 319
Logical unit, 494-496
Logistic computer (see Business logistic computer)
Look-up routine, binomial-coefficient, 100
Loops (see Recursion codes; Recursive compiler)
Loops within loops, 101, 103
Lowest solution, general Boolean matrix equations, 432-434

MAD (see Multiaperture devices)
Magnetic amplifier circuits, 698-703
Hogue, 703
Ramey, 701
Magnetic circuit, 689-693
reluctance, 693
susceptibility, 692
Magnetic cores (see Cores; Multiaperture devices)
Magnetic disks, 737
Magnetic drum (see Drum)
Magnetic elements, physics, bibliography, 719
Magnetic-film memory, 728-732
bibliography, 759
nondestructive read-out, 730-732
simultaneous read-write, 730-732

Magnetic flux, 691
Magnetic gating, 704-711
Magnetic materials, ferrite, 694
properties, 693-698
square hysteresis loop, 693
Magnetic susceptibility, 692
Magnetic tape (see Tape)
Maintenance, 474-476
bibliography, 171
Maintenance routines, 135-139
Major multiplication, 112, 511
inhibit signal, 556
Majority-carrier current in junctions and diodes, 648
Majority circuit, 631, 640-642, 706, 718
Majority gating, 631, 640-642, 706, 718
Majority logic, 640-642
Man-machine simulation, 16-18
Management decisions, 15
Mantissa, floating-point word, 110, 538
Manual searching methods, 223-226
Manual write-in input methods, 748
Many-valued logic (see Multivalued logic)
Marginal-punch cards, 223
Mathematical interpretive routine, 139-142
Matrix, diagonal, 467
permutation, 437
pseudopermutation, 434, 439-441 (See also Unitary matrix equations)
selection, core, 725, 726
diode, 547-552
state, 359
(See also Boolean matrices; Boolean matrix equations)
Matrix equations (see Boolean matrix equations)
Mechanical analog-to-digital conversion, 742
Medical diagnosis, aids to, 21-23
Memory, 26-27
large fixed, 753-754
parallel, 564-568
serial, 562-564
speed, 49
(See also Cores; Disks; Drum; Mag-netic-film memory; Memory sys-
tems; Multiaperture devices; Tape)
Memory access time, definition, 53
in serial memories, 564
Memory address, definition, 30
Memory selection, 562-568
Memory space, sharing, 148
Memory systems, 50-54
bibliography, 757-759
Merging, ordering by, 236-241

Microprogramming, 128
Microwave computer components and gating, 714-718
bibliography, 723
Microwave computers, representation of information, 714-715
Minimizing circuits (see Simplification)
Minimum access coding, 88
Minimum computer, 129
Minimum tree, definition, 778
Minimum-wiring algorithms, 778-782
Minimum-wiring theory, 773-782
definitions of terms, 777
Minor cycle, definition, 498
Minor multiplication, 112, 511
Minority carrier current in junctions and diodes, 648
Mirror notation in core gating, 704
Modern computer techniques, 679-684, 711-718
Mongrel form, 329-330
Monte Carlo method and bibliography, 213
Multiaperture devices, 706-711, 726-728
bibliography, 721
gating with, 706-711
memory, 726-728
shift register, 709
Multihole cores (see Multiaperture devices)
Multiple-component computing system, bibliography, 287
Multiple-unit systems, design, 283
Multiplication, binary, serial, 511-513
Boolean matrix (see Boolean matrices)
decimal, serial, 516-517
and division, 69-71
floating, 113, 538-539
major, 113, 511
minor, 113, 511
rapid, 528-533
in parallel computer, 530-533
in serial computer, 530-531
short cuts, 528, 529, 531
Multiplication instructions, 113
Multiplication tables, 70
Multiply control signals, 555
Multivalued Post logics, bibliography, 483
solution to Boolean matrix equations, 484
Multiway branch, coding, 118
$n$-type impurities, 647
$n-p$ junction (see $p-n$ junction)
$n-p-n$ type transistor, 657
nand circuit, 540, 577, 578, 669, 673, 674
Negation, 298
(See also not gate)
Negation problems in assigning clock phases, 771-772
Negative jump, 115
Negative logic, 668
Net, general, 470-476
Nodes, wiring theory, 777
Nondestructive read-out, 730-732
Nonincluded elementary elements, 328-329
Nonreturn-to-zero writing, 734
nor circuit, $540,577,578,669,670,673$, 674, 701-702
Normalizing, 111, 538
not gate, 40, 311
basic building blocks, 38-40, 576
core, 705
microwave, 718
multiaperture, 710-711
Number expressions in ALGOL, 161
Number systems, 62-71
Numbers, input-output, 1, 44
random, 213
types in computers, 75
Numerical analysis, 173-214
bibliography, 213-214
Numerical approximations, errors, 203-204
Numerical solutions to equations, 2-9

Octal number system, 63
addition tables, 70
conversion, 63-67
multiplication tables, 70
One-address format, 86-88
One-address instruction system, 86-88
functions assigned to phases, 545
One-plus-one address instruction system, 88
Operations (see Instruction format; Instruction types)
Operations phase generator, logical design, 614-615
Operations signal generator, 554-556, 586-590
Pedagac, 586-590
or gate, 38-40, 310
basic building blocks, 40, 576
core, 705
cryotron, 712-713
microwave, 717
or inverter, 540, 577, 578, 669, 673, 674, 701-702
or-inverter package, 670673
or-not gate, 540, 577, 578, 669, 673, 674, 701-702
Ordering, 230-241
bibliography, 253
definition, 218
linear, 253
methods, comparison, 241
maximum in-pass, 231-232
merging, 236-241
minimum in-pass, 231-232
radix coefficients, 232-233
transposition, 232
partial, definition, 253
population-based, 221
substantive-based, 221
Oscillators, clock, 35, 573
Out-scriber, 50
Output devices, 28, 747-756
Output digital transducers, 748
Output subtractive complementer, 505 , 510
Overflow, 112, 505
Overlap time, 632-633
$p$-type impurities, 647
$p-n$ junction, recombination current, 649
thermal current, 649
$p-n-p$ transistor, 651,652
(See also Transistors)
Packages, 576
and-or, 577
electronic design of Pedagac type, 765-771
electronic functions, 624
function, 576
limitations, 577-578
or-and-or, 577
or-inverter, 670, 673
Pedagac, 578
output waveform, 765
representation, 579
timing diagram, 632
transistor flip-flop, 677
transistor type, 577-578
use of clock pulse, 578
Parallel adder, auxiliary carry functions for, 522-525
binary carry generation, 519-522
logical design, 519-525
Parallel adder-subtractor combination, 525-526
Parallel arithmetic unit, 525-528
Parallel clock-pulse core logic, 702-703
Parallel clocking, 572

Parallel computers, 485-486
arithmetic operations, 530-533
Parallel counters, 491
of Pedagac, 607, 613, 614
Parallel decimal addition and subtraction, 526-528
Parallel memories, 564-568
(See also Core memory; Magnetic-film memory; Multiaperture devices)
Parametric amplification, 627-631
Parametric amplifier, gating, 630, 715
Parametron, 630-631
analogy with tunnel diode, 683
bibliography, 643
Parity bit, 635, 737
(See also Redundant codifying)
Partial ordering, definition, 253
Path, wiring theory, definition, 777
Pedagac, 288-294, 575-621, 764-806
alphabetic wiring table, 786
arithmetic unit, 288, 585, 590-606
block diagram, 288, 583 arithmetic unit, 585
card rack, 777
cards, 768-771
clock-phase assignment, 771-773
clock-phase system, 765-766
coding manual, 289
electronic design, 764-786
problems in, 765-771
initial read-in subroutine, 291
logical design, 575-619
of arithmetic unit, 596-600
equations for, 790-794
of buffer, 617-619
equations for, 802-804
of control unit, 608-613 equations for, 794-802
of in-out phase generator, 619
equations for, $802-806$
of operations phase generator, 614 equations for, 802-806
of operations signal generator, 588-589
equations for, 787-790
of push-button signal generators, 619 equations for, 805-806
packages, 578, 764-766, 768
phases, 580-583
read-in routine, initial, 291-292
schematic wiring table, 786
systems design, 288-294
wiring problem, 776
wiring table, 782-786
word format, 288, 290
Peek-a-boo cards, 224
Peirce arrow function (see and-not gate)

Permanent conditions in searching, definition, 227
Permeability, 692
Permutation matrices, 397, 434, 437
Phase-to-pulse script conversion, 718
Phase pulses, 498
Phase-script method of information representation, 715
Phase-selector switch, 126
Phase sequencing, in instruction execution, 568-571
of Pedagac, 581
Phase signal representation, 627
Phases, functions assigned to, four-, three-, two-, one-address systems, 544-545
of Pedagac, 580-583
role of, 543-546
Picture displays, 755
Picture-reading machine, 11, 752
Polynomial approximations, 190
best fit, 191-193, 213
differentiation by, 197
integration by, 195
series, 183-184
solution to differential equation by, 201
Polynomial interpolation, 186
Population-based ordering, 221
Positive logic, 667
Post logics, many-valued, 482-484
Post-mortem program debugging, 131, 134
Power positions, definition, 337
Power-series approximation, 184
Precession in shift register, 499, 500
Prime implicant, 331, 332
charts, 332, 334
essential, 335
obtaining directly, 336-342
generating, 332
Primitive rules, of inference, 317
of substitution, 317
Primitive tautologies, 317
Probabilistic logic, 636-640
Probabilistic matrix, 636
Product, elementary, 325
logical (see Logical multiplication)
transposition of Boolean matrix, 442
Program, 94
automonitor, 133
debugging, 62, 131-134
bibliography, 171
Programmer, definition, 45
Programming, bibliography; 129
business logistic computer, 277-278
digital-differential analyzer, 260

Programming, real-time control computer, 264
for Tabledex, 225
Proper pattern, wiring theory, 777
Propositional calculus, 297
(See also Symbolic logic)
Propositional operations, 297-298
Pseudopermutation transformation, 434, 439-441
(See also Unitary matrix equations)
Pulse-to-phase-script conversion, 718
Pulse-script method of information representation, 715
Pulses, 34
amplification, 576, 625-627
attenuation, 35
clock (see Clock pulse)
clock-phase, 632
overlap tinue, 632-633
repetition time, 631
reshaping, 576, 625-627, 630, 671
synchronizing, 576, 625-627
transfer time, 631
width, 633
Punched cards, as input and output method, 28, 46, 223
reader, 47
Punched paper tape, 28, 45
Pushbuttons, functions, 126, 289-290, 581
signal generator, logical design, 616-619
synchronization, 618

Quotient, rapid division, 534, 541
serial division, 513

R matrix, 397, 421
generation, 421-423 under constraints, 464-465
(See also Fundamental equation)
$\mathbf{R}^{-1}$ permutation matrix, 398
Radix, 62
ordering by, 232-233
Ramey magnetic amplifier, 701
Ramp method of analog-to-digital conversion, 746-747
Random numbers, generation, 213
Rapid arithmetic operations, 528-541 bibliography, 541
Rapid division, 533-537, 540-541 flow chart, 535
Rapid multiplication, 528-533
effectiveness, 531
parallel computer, 530

Read-in routine, flow chart, 291
initial, 120, 291
Pedagac, 292
Read and write, simultaneous, 730-732
Read-write cycle for magnetic-core memories, 725-726
Read and write instructions, 108, 117, 120
Reading, from magnetic core, 54, 725
into magnetic-film memories, 729
Reading heads, 562, 572, 733
Real numbers, 92
Real-time control computer, 262-267
external-control instruction, 266 programming, 264
Recombination current in $p$ - $n$ junction, 649
Recursion-aiding instructions, 108, 116-117
Recursion codes, 95-99
Recursive circuits, 351-355, 404
Recursive compiler, 158
Redundancy, majority logic, 640 probabilistic logic, 636
Redundant codifying, 243-247
Redundant information, parity-bit, 635
Regeneration gating, 624-626
Registers, accumulator (see Accumulator)
current-address (see Current-address register)
delay line (continuously shifting), 498-501
icand, 511-513, 515-516
ier, 511-513, 515-516
index, 109, 561
shift, 488
shift control, 557
temporary storage, 485
Relative address, 109
Relative counters, 109, 561
Relative error, 207
Relaxed conditions of searching, 226-229
Relay gates, 39-40
Reliability, bibliography, 643
general considerations, 634-635
majority logic, 640-642
methods of increasing, 634-643
probabilistic logic, 636-640
Reluctance of magnetic circuits, 693
Repeater packages of Pedagac, 768
Repetition time, 631
Representation, of Boolean algebra, hypercube, 361
lattice diagram, 362
Venn diagram, 361
of package, 578-579

Reservation system, airline, 20-21
Reshaping of pulses, 576, 625-627, 630, 671
Resistance-coupled transistor circuits, 672
Response time of transistor, 655, 662-667
Result array, 384, 423, 446
Result matrix, 403
Retentivity in magnetic materials, 693
Retiming in transistor diode-gated package, 671
Retrieval of information, 22
(See also Searching)
Retrieval computer, 269
Return jump instruction, 116, 140
Return-to-zero writing on tapes and drums, 732
Right-hand rule, 689
Rise phase, 662
Rise time in transistor, 655
Role of phases, 543-546
Round numbers, 204, 205
Round-off errors, 204
Rounding, 205
Routine (see Subroutine)
Rules, primitive logical, 317
of thumb, minimizing number of inputs to gates of decoding circuits, 551 significant figure loss, 208-209
Run button (see Pushbuttons)
Runge-Kutta method of solution of differential equation, 212

Sampling, discrete, effects of, 740-742
Sampling theorem (folding theorem), 742
Saturation, in magnetic materials, 693
in transistors, 655, 663-665
Scaling, 78, 110, 260
Schematic wiring table of Pedagac, 786
Searching, definition, 215
drum, 279
methods, 218-230
with computers, 218
manual, 223
Tabledex, 220-222, 408
with permanent conditions, 227
with preferential conditions, 228
problems of, in terms of Boolean algebra, 407
programming for, 222-223
for $r$ out of $n$ characteristics, 227
with relaxed conditions, 226, 228-229
(See also Codifying; Sorting)
Searching computer, 257, 268-270
Sector, definition, 562

Sector counter, 563, 573
Pedagac, 607, 612-613
Sector selector, 563, 564
Pedagac, 606, 610-611
Selection, address, 543-546, 559-561
argument, 28
Selection ratio in magnetic-core memories, 724-725
Selector, in-out, 28, 618
Self-clocking on magnetic tape, 737
Self-correcting redundant codification, 244-247
Semiconductor devices, bibliography, 685-688
Semiconductor physics, bibliography, 684
Semiconductors, 645-647
doped, 647
electrical conductivity in, 645
free electrons in, 646
holes in, 646
impurities in, 647
junctions and diodes, 647-650
pure (intrinsic), 647
Sensing of core memory, 567, 694-698, 704, 724-726
Sentential examples, 408-413, 476-479
Separation of magnetic-core inputs and outputs, 698
Sequencing of clock phases, 568-571, 632-634
Serial adders (see Adder)
Serial clocking, 572
Serial computers, 37,485
Serial division, 513-516
binary, 513
decimal, 516
flow chart for, 514
sign generator for, 516
Serial memories, 562-564
(See also Disks; Drum memory; Tape)
Serial multiplication, 511-513
binary, 511
decimal, 516
sign generator for, 516
use in, of accumulator, 511, 512
of icand register, 511,512
of ier register, 511,512
Serial subtractor (see Adder and subtractor combination)
Series approximation, 183-184
(See also Polynomial approximations)
Series clock-pulse core logic, 701-702
Sets, definition, 304
elements, 304
Sexadecimal, 63, 64
conversion, 63-67

Sharing high-speed memory, 148
Sheffer stroke, 318
(See also or-not gate)
Shift instructions, 115
Shift registers, 488
continuously shifting, 498-501
formula for, 501
control, 557
core, 699
multiaperture device, 709
precession in, 499-501
Sign bit, 77, 503
Sign conditions for sum and difference, 504, 505
Sign generator, multiplication and division, 516
Signal amplification (see Amplification)
Signal isolation in magnetic-core circuits, 699
Significant figures, 204-211
Simplest form (see Absolute simplest form)
Simplest product of sums, 342
Simplest sum of products, 344-345
constrained basis, 371-372
decimal method for, 365
Harris-Elbourn method, 336-343
Quine-McCluskey method, 331-336
Simplification, of Boolean functions, bibliography, 366
chart methods, 362-364
of circuit design by constraints, 376
Simpson's rule, integration by, 195
Simulation, 2
industrial dynamics, 13-16
man-machine, 16-18
Simulational routine, 140, 142-148
Simultaneous Boolean equations, 379-388, 402, 404
Simultaneous changes of logical variables, 398-400
Simultaneous linear equations, 174-178
Simultaneous read-write, 730-732
Skipping of clock phases, 634,766
Small-signal equivalent circuit of transistor, 660-662
Solid-state devices, semiconductors, 645
tunnel diodes, 679
Solutions of Boolean matrix equations (see Boolean matrix equations)
Sort, simple, 226
Sorting, bibliography, 253
definition, 218
of marginal-punched cards, 224
(See also Ordering)
Space, memory, sharing, 148
Special coding techniques (see Coding)

Special-purpose computers, 2, 256-281
business logistics, 271-281
digital differential analyzer, 257-262
information retrieval, 268-271
real-time logical control, 262-267
Speed, of computer, 27, 34, 148-150
of information conversion from one
medium to another, table, 47, 49
Split tree, 118
Square-hysteresis loop, 693
Standard address for return jump, 141
Standard basis, 322
Start button (see Pushbuttons)
State diagram, 358
State matrix, 359
Statements, 162
States of circuit, 357-360
Static (flip-flop) gating systems, 626
Stop button (see Pushbuttons)
Stop instruction, 74, 289, 581, 583
stop statements in ALGOL, 164
Storage location, definition, 30
Storage time in transistor, 655, 663-665
String of units in rapid multiplication, 529, 530
Strip lines, 714
Stroke, Sheffer, 318
Subroutine, binomial-coefficient look-up, 100
column-adding, 102
definition, 104
flow chart for setting up, 105
library, 108
Pedagac read-in, 291
$\sin x, 102$
square root, 98
table look-up, 122
Substantive-based ordering, 221
Subtraction, binary and octal, 69
binary parallel, 526
binary serial, 491-497
decimal, in excess three, 506-508 parallel, 526
definition, 503
Subtraction instruction, 112
Subtractive complementer, 496-497
excess-three, 509-510
input, 510
output, 505, 510
parallel arithmetic unit, 526
Subtree, definitions, 778
Successive approximations, 178-183
Sum, and difference, condition table, 503 sign conditions, 504
elementary, 325
definition, 503
Superconductivity in cryotron, 711-712

Superimposed irredundant codification, 247-252
Susceptibility, 692
Switch, one-shot and on-off, 119
Switch declarations in ALGOL, 166
Switching circuits, 366-367
bibliography, 367
transmission functions, 366
Switching core (see Cores)
Symbolic address, 151
Symbolic code, 80
Symbolic coding, 79, 84
Symbolic language, 61
Symbolic logic, 296-301
axiomatic development, 315
bibliography, 316
combined elements, equivalence, 299 implications, 299 tautology, 299
elementary elements, 298
formal theory, bibliography, 317
propositional operations, 297-298
propositions, 297
truth tables, 300-301
Symbols, core mirror notation, 704
diode, 667
flow chart, 78, 95
gate, 311, 578
logical operation, 114, 298, 299
matrix operation, 356, 441-442, 444, 480, 484
package, 579
transistor, 652, 657
tunnel diode, 681
Synchronization, 34, 624
of input-output units of Pedagac, 618
Synchronizers, 571, 619
pushbuttons, 619
Synchronous dynamic flip-flop, 487
Synchronous operation, 498
Synchronous recursive function circuits, 351-356
timing diagram, 354
Syntax (see ALGOL)
System engineering and bibliography, 287
Systems design, digital computers, specifications, 282
large-scale data processor, 281-286
multiple-unit, 283, 284
Pedagac, 288-294
purpose, 256
special-purpose computers (see Special-purpose computers)

Table look-up, 121-123
differentiation by, 197

Tabledex; 220-221
advantages, 408
computer generation of manual, 225
Tally, 96
Tape, magnetic, 48, 737
clocking, 734
input devices, 46, 48
nonreturn-to-zero writing, 734
odd parity bit, 737
output devices, 28,46
return-to-zero writing, 732-734
self-clocking scheme, 737
Tautology, 299-300
Taylor series, 190, 192
Thermal current in $p-n$ junctions, 649
Theta product of Boolean matrices, 444-447
in multivalued logic, 483, 484
Thin films (see Magnetic-film memory)
Three-address format, 82
Three-address instruction system, 81-84
functions assigned to phases, 544
Three-valued logic, 406-407
Boolean matrix equation, 479-482
(See also Multivalued logic)
Timing, and counters, 571-573
problems in, 766-768
synchronous circuits, 353
Timing diagram, four-clock phase
system, 633
package, 632
synchronous circuit, 354
Transducers, 13, 747
Transfer instruction, 84, 85, 87
functions assigned to phases; 544, 545
Transfer time of pulse, 631, 632
Transfluxor, 706
Transformation to absolute simplest form, 396-400
Transistors, 650-679
$\alpha$ ratio, 653
as amplifier, 669-671
base, 652
$\beta$ ratio, 653
bibliographies, 685-687
characteristic curves, 653-655
circuits using, current-switching, 674-676
diode-gated, 669-672
direct-coupled, 673-674
flip-flops, 676-679
shift register, 679
resistance-coupled, 672-673
collector, 652
conventional current directions in, 652, 657
emitter, 652

Transistors, equivalent circuit for, 658667
bibliography, 685
large-signal, fall phase, 664, 666
rise phase, 662-663, 664
saturation and storage in, 663-665
large-signal d-c, 659
small-signal, 660-662
variational, 660-662
fall time, 655
grounded-emitter, as switches, 656
$n-p-n$ type, 656
operating range (cutoff, active, saturation), 655
response time, 655
rise time, 655
storage time, 655
symbolism for, 652, 657
Transitive property of equivalence relation, 253
Translating computing unit, 282-283
Translation of English, logical, 318
bibliography, 319
Translator compiler, 151-153
Transmission functions, 366
Transpose of Boolean matrix, 426, 442
Transposition, ordering by, 232
Trapezoid rule for integration, 194
Tree, definition, 778 split, 118
Truncated errors, 203
Truth tables, 300-301, 323
Tunnel diode, 679-684
bibliography, 687
characteristics, 681
digital circuit, 682
energy-band diagram, 681
parametron analogy, 683
symbol for, 681
Tunneling, 680
Turing machine, 129
Two-address instruction format, 84
Two-address system, 84-86
functions assigned to phases, add instruction, 544
2-421 Code, 517
Types, of circuit problems, 415-418
with constraints, 462-465
examples, general net, 470-476 ordinary equations of equivalence, 465-468
inverse solution to, 468-469
type 1, 448-449
type $2,450-452$
type 3, 453-462
fundamental formulas for, 426
of unitary matrix equations, 435-436

Undetermined coefficients, function evaluation by, 198-200
Union of sets, 305
Unit delay, 353, 501
Unit time interval, 486, 498, 632-634
Unit-time-interval counter, 573, 607, 612-613
Unitary matrix equations, 434-438, 442-447
conditions for existence of solution, 436-438
in multivalued logic, 479-483
solution to types 1,2 , and $3,435-439$, 480-483
Unknown Boolean function (see Boolean equations)
Unnormalized, definition, 111
Unnormalized result, floating-point operation, 538

Venn diagram, 361
Verbally described problems, 347-351
Voltage clamping, 668

Waveform of Pedagac packages, 765
Wiring diagrams, bibliography, 786
Wiring problem in computers, 773-782
Wiring tables, 782-786
Word block definition, 117
Word format, 71-77, 82, 84, 86-88
Pedagac, 288, 290
Words, computer, definition, 30
form, 34
interpretation, 30
labeling, 222
Write, 725-726, 730-732
Write instructions, 108, 117, 120
Writing of code, steps in, 80
Writing head, 562, 572, 733

Xerography, 756

Zener effect, 650

$$
\because \because
$$


[^0]:    $\dagger$ Also less correctly called hexadecimal.

[^1]:    $\dagger$ See S. C. Kleene, "Introduction to Metamathematics," p. 24, D. Van Nostrand Company, Inc., Princeton, N.J., 1952.

[^2]:    
    Procedure-declaration heading
    Declarations and statements of subroutine proper

[^3]:    $\dagger$ See, for example, Milne, op. cit., pp. 116, 120.

[^4]:    $\dagger$ Irene A. Stegun and Milton Abramowitz, Pitfalls in Computation, J. Soc. Ind. Appl. Math., vol. 4, no. 4, December, 1956.

[^5]:    student need not dwell on gaining such facility, for in the next chapter a systematic and straightforward method will be given for doing such problems.

[^6]:    $\dagger$ Consideration of "flip-flops" will be deferred until a later chapter.

[^7]:    $\dagger$ The method of this section is an adaptation of McCluskey's variation of Quine's method of simplification. (See E. J. McCluskey, Jr., Minimization of Boolean Functions, Bell System Tech. J., vol. 35, p. 1417, November, 1956. See also W. V. Quine, The Problem of Simplifying Truth Functions, Am. Math. Monthly, vol. 59, no. 8, pp. 521-531, October, 1952.)

[^8]:    $\dagger$ See Sec. 13-7, Additional Topic $a$.

[^9]:    $\dagger$ The material of Additional Topics $b$, $c$, and $d$ was developed by Neely F. J. Matthews and that of Additional Topics $e$ and $f$ by William Ruthven Smith when they were graduate students of the author's at The George Washington University (see W. R. Smith, Master's thesis, June, 1959, and N. F. J. Matthews, Master's thesis, June, 1959).

[^10]:    $\dagger$ Note that a write control signal must be fed to the write amplifiers to turn them on; absence of this signal will prevent writing onto the drum.

[^11]:    $\dagger$ See, for example, L. I. Schiff, "Quantum Mechanics," chap. 5, pp. 92-95, McGrawHill Book Company, Inc., New York, 1949; or D. Bohm, "Quantum Theory," chap. 11, pp. 238-242, Prentice-Hall, Inc., Englewood Cliffs, N.J., 1951.

[^12]:    $\dagger$ Based on private communication with J. Rabinow, Rabinow Engineering Co., Takoma Park, Md.

