Digital_Computers_Advanced_Coding_Techniques_Summer_1954 Digital Computers Advanced Coding Techniques Summer 1954

Digital_Computers_Advanced_Coding_Techniques_Summer_1954 Digital_Computers_Advanced_Coding_Techniques_Summer_1954

User Manual: Digital_Computers_Advanced_Coding_Techniques_Summer_1954

Open the PDF directly: View PDF PDF.
Page Count: 91

DownloadDigital_Computers_Advanced_Coding_Techniques_Summer_1954 Digital Computers Advanced Coding Techniques Summer 1954
Open PDF In BrowserView PDF
Massachusetts Institute of Technology
Summer Session 1954

DIGITAL COMPUTERS

ADVANCED CODING TECHNIQUES

HaSS8chusatts Institute of Technology
Summar Session 1954
Notes

~am

9\tt!rt!2oel"

a special

progrmn in .

I.[ 'J~..

[·····1

r.l p" nu T rC. R-\ ~~:~
U

J'!..

I

U t"
"',"r .i
\i. ~.~. ~_ ~.J
1·. . ~~., ...u!1
1.~· ~"'1).'

Pl":'JP!l:t"~d und<.·n" thfJ
Cu~JQ

\;i

th

~

~ i ~"'1!r.

fU' A
~~,

dtr.EH:tlO:l of'

JvllJ.\'Jnl9 S" Gill~ ~1nd Du Gt)..~·b81.tc

th·~~ t~OCifri:trntlnn

Digit.al

o·r

tha

Gonput(~r !~thv:ratC)ry

Dopnrtm·')nt. of F;lot!1:.rlcnl.

or

the

E:n~~ tn~er:h1g

Dlgi t.al

COl11pute:cr~ g

l\dvanced CodJng

1'e'~hniques

Table of Contents

:ri tl(3

§ef!.~i£n [~

10

.I,egt\~t=)_r.

Ideas of Advancod Coding3

Adams

')
,~

Outline of Courf;e
History of Al.ri:.omat.ic Codingi;
Aims and Difficul t:les

Coding

Proce~1ses

Occuring Boror'ISI

the Execution of'a Routine
Coding Processes Oecuring Dlu"ing

'the Execution of a Routine

Grill

Combalic
Gill

I
;-

,
COlllbelic •
.~,

Operation of a Computing Center

Porter

6

A..-2 Compiler and A:3sociated Routines
for Use "lith Unlva(~

Hopper

J

701 Speedcoding System

Backus

I~B~MQ

Choice of NUl'l1erlcal r.fe"thod

Nillel"

Effectiveness of AutomatIc·Coding

Gill

Systems CU1"'rcntly :In Use
e~

l .... 0

120
13:)

Dis(mssion of' r..r8anings of Horda
Used in Automatic GodIng
Discuss ion of' r~'9anin.gs (cont. inll(-~d)
Algebraic Coding
Automatization of Processes of

Adams
J\dams

Combellc!

Hiller

l1athematical Anel ysis
1"
1::'>0

.rfhs IJlbrary of Subroutines D
Contents:1 FOl"mp and Or-ganiz8.t1on

Gill

Effect of Automs.tin Cod:i ng on
Design

Combeli(!

F'utuI'e Developm~rnt of
Universal Codn

Adams

l~a(:hine

IH"
19 .

Coding~

Discussion
Business Requ.irements v Auton\o'C:l.c

Adams

Editing of Business Dnt-:,a
Bu~iness

RequlY',smerrts f, Aut.omatic
Maintonallce 9 Searehl11g

Prepal~at1.01l ~

of Business Files

Adams

9

·10 Introduction

the tiJile of 'this week-long session has been listed sometimes as
Advanced Coding Tec~iques~ sometimes as Automatic Coding Techniqueso It
seems obvious that any automatic technique is, in a general sense, advancedo
rhe converse is -not true •. Consequently, "advanced" is more general than
"automatic", and these notes are .described as Advanced Coding Techniques;
but th~y wIll nonetheless in large part describe 'automatic coding te'chniques
Automatic coding t according to the ACMg~ossary I fs '~any technique in which
a computer i.s )uscd to help bridge the gap between aome ,leasiest t : form"
intelleotually and manually, or describing the steps to be followed in solving
H g,i~en problem and Dome 'most er~iclent" final coding or the same problem
for II given computer~.
The proce saas t.Jhich are required in preparing a program f'or a computer
involve
1. analyzing problem
0

I

2. plarming

3. coding

4. typing (or keypunching)
5. trying
6. debugging
70 running
80 analyzing results.
or these, items 3, 4 and 6 involve essentially routine operations, capable
a priori of mechanization on a eomputero Not only may these clerical
operations be made easier to d0 9 but they may be made easier to learn as wello
Furthermore, the running may be made more erficient b.1 careful coding9 (in
aome machines this is especially so because of the opportunity for minimal
latency coding). Thus reducing the computer time as well as simplitying the
learning and the doing or codinge typing, and debugging. are various aspects
of automatic codingo Simplit,ying or mechanizing the planning isp on the
other hand p an aspect of automatic
programmingo
\
.T~a interest in automatic coding evidenced by the number of applicants
for this session at M.loTo has grown rapidly in the past year or SOo Ostensibly
this enthusiasm is due to the need for simplification of coding to accomodate
the nev and,the non-professional programmers =- tpe amateurs who regard
programming Dlarely as a neoessary evilo The proresBio~als of course benefit
from any reduetion of routine efforto The origin of automatic coding stems

trom work done by the early professionals ..... the first £'01· ",hem the novelty
of computer coding wore ofro Tiring of the tedium of everyday coding9
looking in their spare time for new fields to conquero they solved both
problems at once by undertaking truly herculaan coding projects \lhose aim
was the simrlification or codingo
The general plan of attack for these sessions is td apend most of the
first two days in establishing a common language and a common frame of
referenoe
The terms we will need \-Ie will dev'elop gradually as we go
along but a few basic terms are needed at the onse~. MOst important
to us are coding9 programming~ rout1nsg and their derivatives ~ terms which
have been tentativelY defined in the ACM First Glossary of Programming
Terminology which is included in these notaso
By description of existing systems - M.loT.us hypothetical Summer Session
computer9 Remington Rand Os ACQ2 Compilerp and IBf.tos Speedcode = we hope to
establish a common frame of reference. The lectures and discussions which
occupy the last three days will touch on many other aspects and will permit9
if not the reaching or a~v conclusions9 at least the dissemination and·
perhaps the codification of the ideas or many of those most familiar \lith the
fieldo
0

Q

20 Hisi;o?y of Au-tomatic Codingg 1.ts aims and di:fficulties
Lo~ical

Development

or a

~outina

Coding methods have" all~eady, come a long way since the first electronic.
digital computers \-lere built., The first sophistication 1:1as the 1:1riting of
addresses in decimal :lom for binary machines, thus making the witten form"
of an instruction appreciably different from its form inside the machine.
Research ~ent in two directions: towards s.ystema~izing the w~y a'
routine operates l'lithin the machine, and tOt-lards g'ceater au"Gomatic processing
of, the routine before its' e:!et:u·liion. DoJ. 14haeler (E?J) Dl) inje~·ted into
an'early input scheme for 'the Edsac some basic ideas (eogorelative addressJa)
for p~e-execution processes. HOb~var9 for ,some years the greatest effort
.
..
wen-PG into studying the behaviour of a routine during its execution.
Slowly it uss realised that many-logi~a1 changes ~ou1d be made at v~ioua
stages in the life history of a routine. O~etypical l~gical'change i~ the
"unwinding" of'a 'cycle; this may be performed while the machine is executing
the program, or before the program is executed. In the latter case it may be
performed by the coder, b.r the typist~ or b,y the ,machine itselfo T~e choice
must be made on the basis of over all efficienoy; in general ~hia ~ean~
mechanizing a8 much of the uorkas .posa,ible, in one way or another.
The logical changes may be roughly classified as fol1owa:
,(1) Replacing human terms by terns suitable 'tor a machine.;,.'
(2) Replacing general statements by particular statements.,
(3) EAjpansion of detailo
Th~ first may be subdivided thus:
(la) Replacing terms \.,hich are intelligibie only "GO a h1JJ.nBll, by terms which
can be handled by a

machine~'

(lb) Forming terms ,that are especially convenient for the machine from '
terms that, although meaningful to the machine, are more convenient

for the human coder.
The only type of ~ha.nge that cannot be mechanized is la Type 3 involves a
great increase in th~ ~ount of information to be stored and handled o but it
is &lo·t usually an involved process" Types 1 and 2 involve considerably more
computing ~ with li'ttle change in the amount of inf'ol"ma"\iion. Hence p t-lherever
possibla p changes of types 1, and 2 should precede those of type 3. However»
changes are often of mixed types, and also some changes must necessarily
follol91 cer't.~in others, so that the general pat·tel~ is not simple
0

0

Kinds of Techniguea Available

The following are typical of the' ways in which logical changes can
.
be made by a machine 0 ,
",
Mnemonic coding: it is. convenient for humans ,to u~~ suggestive
letter pairs or triples to denote 'the operation sections of instructionsp
or to identif.y subroutineso Machines usually ultimately require a digital
rep:resen~tatl.ono This is a simple change of type lbo' l-lhirlwind I haa
always performed this change on the operationsectiona of instruetionsQ
Identification of wo?ds: the control uni~ of a machine can operate
on words only if it is given the~ absolute addrssseso Humans find it
more convenient when coding to use relative or symbolic addltesaeso The
necessary change is of type 2 and can be performed by the machine t) usually
before execution of the routinso
Representation of numbers: these may originate asp say, o023i 47010-5
or 7/45~ The conversion to the standard machine form can be performed b.1
the machinep though the routine required to do this is oftep lengthyo
Type 1bo
Interpr~tive routines:
these form an extremely powerful techniq~e
for carl~ing out all kinds of logical ohange during the execution of a
routine; how~vero their use is inefficient unless accompan~ed by considerable
expansion of information (type 3)0
Librar,r of Subroutines: the incorporation of a library subroutine 1s
largely a type 3 changeo hence it is best left until a late stageo However p
it can only be made fully automatic if the machine has a large store3 many
users of small machines have had to include subro~t~es'in'the input tapeo
Furthermore there are often several type 2 changes to' be made to the subroutine aftar it has been copied~ so ~bat usually at· least one copy of the
subroutine is' incorporated in the routine before exacut1on~ This is also
more economical·: ill,. machine, time if' the atmiliary store is of' slow access
The Programming Research Sect~on of Remington Rand, !nco p lad by nro Grace
Hopperp has done a great deal of york on the automat1c'inser'~ion of Bubroutines~
this is one of the chief functions of the Univac "compiler" routines (F2 {) F3lo
'

0

§Eoutin§.~

Basically a subroutiD,e is just a list, of instructions to be obeyed by

the machineo

the librar.y form of the subroutine rrequant~ undergoes some development before it is execu't,ed p so tha"c one must distinguish
Ho~verp

the initial and final forms of the subroutine. - The first step in this
direction was ~~eeleros introduction of relative addresses and preset·
parameters (E7 p Dl)o Lat6~ it was found that maDY sUbroutines required
special changes that could only be .made by spacial bits ~i'. coding ('interludes ,)
attached to the libr~ CO~ (D1)0 These interludes appear in
the initial
. '
.
but not in the final form of the subroutine
Finally, Dro Graca Hopper!) e group have developed subroutines 1r1hose
initial forms are entiraly nintsrluda n ; these
called fJgene;ratorsoo
~

0

are

Language Aspecj?

-:

The fact that changes are made to a routine attar it is written ':and
before it isexecutad means that .:Lrticularization
of general statements.
t~~t

AN EXAMPLE OF All AUTClfATIC C(J)ING SISTEK
•

. '7"

"

~

,'

:·a'l'

•

....

•

Slrm SESSIOR COO'OfER

The NIT Summer Session Computer, hereafter referred to as the
88 Computer, does not exist ··as an assembly of electronic appar~tus;
rather its realization.is achieved by appropriate conversion, assembly,
interpretive routines operating in the Whirlwind I Computer.
In order to allow students. to write.' and operate programs within
only a felv days after their introducti~n to the basic concepts of digital
computers, programming had to be.easy to learn and teach. In addition,
it was necessary to provide m~ans for finding mistakes in programs,
means which were simple. to use and.the.results of which were easy to
interpret, .so that, within. the very short time available, students
would write one or more .programs and.run them successfully o~ the computer.
The 88 Computer, the development. of which required about 12 man-months
of work by experienced progra~ners, is an attempt to achieve these goals.
Description of the 8S Computer
The 88 Computer is.a. single-address, medium-speed (about 600
operations per second) digital computer with a basic word length of
28 binary digits and a 4-binary-digit tag. Each word is stored in
two consecutive l6-binary-digit Whirlqind I registers. There are three
kinds of words: (1) fixed-point integers, (2) floating-point numbers,
and (3) instructions. Input to.thecomputer is by means of punched
Flexowriter paperfupe; output equipment includes a direct printer, a
"delayed" printer for later printing of information recorded at high
speed on magnetic tape, and an oscilloscope, on which individual points
may be plotted by the, computer and the result observed and/or simultaneously automatically photographed.
Integers and Numbers
Fixed-point integers· are represented by 28'bits, the first being

the sign, the last 27 bits representing the magnitude of the integer.*
Since 227=134,217,728 is.approximately equal to 108 , integers may be
thought of as roughly equivalent to 8 decimal digits.
An integer is written in an SS program with a + sign (may be
omitted) or - sign, follo,,,ed by 1 to 8 decimal digits, and is terminated by either a tab or carriage-return.
Floating-point numbers are numbers in the form A • 2B, where B

tt

is an integer and A is a fraction with
'A'~l..
In the SS Computer
the mantissa A is represented by, a sign and 20 bits, the exponent Bby
20
a sign and 6 bits. Since 2 =1,048,576 is approximately equal to 106 ,
numbers in the SS Computer . have 6 decimal digits of precision. The
6 binary digits available for the magnitude'of the exponents allow nonzero numbers to range in.magnitude from 2- 64to 263 or approximately from
10-19 to 10+19 • Zero has the special representation 0 x 2-63 , i.e., a
zero mantissa, and a negative exponent of the largest permissible magnitude. A number written with a decimal point is treated as a floatingpoint number. Alternatively, or in addition to the decimal point, a
number intended as a floating-point number may be followed by the letter
x and 10 to some po,,,er; thus any of the follovring are treated as floatingpoint numbers:
-12.73
Arithmetic Element
The Arithmetic Element consists of principally an Accumulator (AC),
which deals with either integers or floating-point numbers as the. situation
demands.
When integers are involved, the AC contains a sign and 54 bits, ioe.,
is double-length v Another register, known as the Remainder Register (RR)

* The

remaining 4 bits of the 32 available comprise a so-called logical
information tag. This tag contains information about the kind of word,
iee., integer, number, instruction,or undefined, and also whether the
word has been altered.from its original form during the operation of a
program.

J~.'

4·'·
',_

S,·:-.·.~­
.;;1.

may be thought of as a kind of, .right-hand extension of the AC --' the
RR holds the remainder after unrounded division of one integer by another.
Sums, differences, products, or quotients may be as large as
23 2767 without exceeding the capacity of AC, but only numbe~s less than
26~1019 in magnitude may. be copied from AC into storage. Numbers
which . become .smaller than 10-19 are automati~ally set to zero when copied
into storage.
To discourage little tricks and to help isolate real mistakes, one
special restriction is that integers and numbers may not be mixed in the
AC; e.g., it is not permitted to add an integer to a number. If such
mixed operation is attempted the computer stops and prints out information likely to be useful to the programmer in diagnosing the mistake.
This automatic print-out'when a programming mistake is made is called a
"computation post-mortem", and more will be said of it later.
Words in the SS Computer
Instructions are represented in the SS Computer by an operation
section, an address section, and an additional "counter letter" to
select one of. 7 counters, or no counter at. ali.' The counters are used
for .cycle-coUIlting and address' modification (like the }1anchester B-box),
as will be explained.
There are 35 operations,including: arithmetic operations (most of
which apply equally vIell to 9.i ther numbers or integers), operations which
copy words from one place to another, "jump" operations for interrupting
the normally consecutive carrying out of instructions, operations for
changing the co~tents of the counters,' and operation~ for controlling
the in-out eqUipment •. Operations are specified by' the programmer as a
mnemonic combination of three 10\-ler case letters, a tabulation of which
is given on the. last two.' page S \oJi th the meanings of the three letters,
the definition of each associated instruction, and information about
what may cause a post-mortem when performing each instruction.

Addresses may be w~itten in absolute or floating form. An absolute address is any positive integer a through 299. (This limitation thus restricts SSprograrns to ,maximum length of 300 words.) A
floating address is a ,single lower.case letter (except 0 or 1) followed
by not more than 3 digitso
Floating addresses are used as part of an instruction by Writing,
for example:
ccf b3
The word referred to by the instruction ccf b3 must have the
floating address b3 assigned to, it. This is done by using
comma; thus

a

b3, 750
will tag the registercontining the integer 750 with the floating address
b3 so that all instructions in the program with b3 as their address
sections will refer to this same register.
For corrections purposes only, words may be assigned to registers
by vTriting, for example,
b31-750
Following the floating address by the vertical bar instead of a
con~a results in the previou~ contents of the register b3 being replaced,
in this case, by the integer ~750.*
A coUnter letter (a,b, c, d, e, f, or g) may be appended to the
address section. of an instruction, and ,the·· contents of·· the specified index will be' added to the address section of ,any such instruction before '
the instruction is executed without changing the original form of the
instruction· in storage. Each of the 7 counters consists of an index and
i a and na , ib and nb , etc., respectively.
In an ordinary
a criterion,
.
,
cyclic process i b , for example, is set to 0 and the criterion is set to
some value nb • Then, for each step ,in the cycle, ib is increased by 1
until ib='~' at which time the cycle is comple,te. The counters are
designed primarily for counting and for modifying addresses, although
.

.

.

* Words to which no floating address' h~s -been afrsigned may also be modified. For example, if instead of "the' word' in·'b3, the fifth word after
the one in.b3 were to be changed to +625, the word assignment would be
b3+51 +625

other applications are possible.
Programmed Output
There are three output devices: (1) a scope on vlhich discrete
points may be plotted. A camera is. attached to the scope so that a
display may be photographed. if a· permanent record·.' is desired. The
operation pat and frc are used in controlling the scope. (2) A
"direct" typewriter on which integers and arbitrary characters may be
recorded at the rate of 10 'per second. (3) A "delayed" typewriter' on
which the same sort of characters. may be re.corded in F1exowri tercoded form on magnetic tape at a rate of 125 per second and later typed
out at 10 per second while the computer is doing something else. The
instruction tyc m will type the Flexo character' whose octal equivalent
is equal to the address sectionm. The instruction ~ will type
out the contents of AC as a series of decimal digits, the particular
form of the prin~ and the number of digits to be printed being specified by the address section m. Details of these very useful instructions are given in the tabulation of the operation code.
Programmed Input
,Once a program has·been read into the.computer more data can be
supplied to it only by using the operations ric or rin. Both these
operations'control the Hechanical Tape Reader (MI'R) into which is inserted a punched Flexo tape. The operation ric is used to read in individual characters punched in the tape; !in is used to read in an
entire integer or number, the termination of which is indicated by a
tab or carriage return character punched on the tape.
Program Preparation
Programs are prepared for input to the computer by typing them

on a Flexowritertape perforator.

~he

sequence is as follows.

I. The first line of the typed program consists of at least
one lower case letter ~:followed by an identifying program title
followed by a carriage return.
2. 25 or more equal signs followed by a 'carriage return.
3. The program itself, .. consisting of integers and/or numbers,
and instructions; each such word must be terminated by one or more
tabs or carriage returns.
4. Any word assignments (e.g., b31 -750) which are nece~sary,
each terminated as in 3~ above.
5. The address at which the program is to start operating followed by a vertical bar, followed by the word start in the 10vler case.
Examples are:
a7\ start.
g6+3tstart
1271 start
Post-Mortems
When an error has been made by the programmer, and that error
is detected either during input or GperatlGn of the program, the
computer stops and prints out information about that error. Such a
print-out is called a post-mGrtem. There are two types of postmortems in the SS computer.
Conversion Post-Hortem
The punched program tape is read into the computer through the
photoelectric tape reader., After the -tape has been re,ad in and the
binary equivalents of the characters stored, the SS conversion program
processes the stored data and'eventually produces a sequence of words in
binary form which will be correctly interpreted as a program by the SS
computer interpretive routine. If , "however, certain logical or typographical errors have been made which are detectable during the conversion process, the computer will stop the conversion and print on the )
direct typev~iter the title of ~he program tape fOIl, owed by a description,
of the mistake and its location in floating address form.

The mistakes detected by the conversion program are:
1.
2.
3.
4.

5.
. 6.
7.
8.

unassigned f1oating.address
undefined instruction
floating address assigned to two or more registers
absolute address too large
program longer than· 300 words
integer or number too large
numerical part of floating address too large
no counter letter specified in rst, jii, jic, inc, dec, or
cii instruction.

',Computation Post-Mortem
If, during. the operation of a correctly converted program, a
situation arises which is defined as a programming mistake (see list
page 9), the computer automatically records on magnetic tape certain
information and then stops. The.recorded information is known as
Computation Post-Mortem, and is subsequently typed out on the. delayed
typewriter. A typical Computation Post-Mortem. might appear as follows:
ss program 27, John Smith, Sept. 23, 1953
rdeh-h.f!c.c....+'·on
STOPPED AT dl+6 dl+6fpata17
a17'~981
,,\,.k.\,(l,r
,
nC(.~AcI1034
RR 5
'I
•
.
,,_ _ _ _ Rc\\\Ct \\;ct".... Rc~ \,stc.2i
h4,.oJ8 d2 •• d1+8
(dl.odl+8.)
dl •• a8. z7 •• p97+3 q6 •• q9
, p97+4 •• a5-1
h6 •• h7+4 r4.or6-2
t8 •• Y37-l d2 •• d1+6 stop
J~COUNTERS a12,5 'bI6,6 c '23,23 d t12,12 e1o,0 f,O,O gIO,O
~)~~jilI19 1. II- 1..Jl
-601 a171-981 p902' ccfp920d q9' jmpp97+4 etc.
The information given is as follows:
Line 1: the program title for identification purposes.
Line 2: the
computer stopped
while performing the pata17 instruction
.
.
. in d1+6. a17 co~tainedthe integer -981.
Line 3: The AC contained 1034, which is why the cOD:lputer stopped on
the patal? instruction. (S'ee prograITlT1ing mistake 6A in the
operation code.) The Remainder Register (RR) contained 5 -had the RR not been used, no information about it would have
been printed.
I

)., 4,It "S:~'"
8
"
,',
Lines 4 and 5: traces the path the computer followed over the ten
most recent jump instructions--only those jumps which
actually were effective are included. The example given
sho,vs that the computer performed each instruction f'rom
h4 to j8; then some kind of a jump instruction in j8 took
it to d2. Each',instruction.f'rom d2 to, dl+8 was carried
out; then the sequence dl to 'd1+8 'vas repeated 21 times.
The next time through this sequence it we~t right on "
through to 28, whence some kind of' jump took it to z7,
etc. Each address is given in terms of the nearest floating
address.
Line 6:
gives the index ~nd criterion, in that order, f'or each of
the 7 counters--had no counters been used this item would
not appear.
Line 7, etc.: lists the address, in terms of the nearest floating
address, and the contents of every register wnose contents
have been altered during the program. If the contents of
several cqnsecu,tive registers have been changed, an address
is given for the first and for each one to which a floating
a~dre~s has been assigned.

~ESS ION

INSTRUCTION ,CODE' OF THID MI'f Slj'MMER
INSTRUCTION

IvlEA~TIliG

COMPUTER
POST-MOR~~f*i~

DE:&'INITIOl!

ccf al b

copy contents from

C(al+~ )---)AC .

L14

cci~ al b

copy contents into

C(AC)~al+ib

A4. A5, U9

cn£: al b

copy negative from

- C(al+ib)~AC

cmf al b

copy magnitude from

'C(al+ib)I~AC

L14. LIS
L14, L15

cri- al b

copy rema.inder into

C(3R}-.,al+~

xch a1 b

exchange

C(AC)-7 al+i • C(al +i }--JAC

add al b

add

C(AC) +C(a1+~ )4AC

sub al

sub·tract

C(AC) -C(al+ib)~AC

A4.A5.L14.U9
AI. 112. UJ
AI, L12. UJ

cby-al b

multiply by

C(AC)XC(al+~)--'~C

Al, 112,

dby al b

divide by

divide CeAC) by C(al+i )
b
rounded quotient--+~C

.ttl 1 t L12. UJ

dhr al b

divide holding
remainder

divide C(AC) by G(al+i )
.
b
quot ient~AC. remainder~RI{

txi al b

transfer excess into.

divide C(AC) by 227
qUo'tient~~I:i~ • remainder ~AC

jmp al b

jump

take next

jip al b

jump if positive

di tto. if C(AC)

jin al b

jump if negative.

ditto. ifC(AC)

j~z.

jump if zero

,:jir~

al b
al b

jump if remainder

ditto. if C(RR) 10

Ll'l

,ji~

al b

jump if exces.a .

di tt6. if f C(Ac)I~22?

L17

:'

b

:

.

nra; al b

set return

b

b

.

U10

..
,. .
1n~.tr. ··fro.m·al+~·
~.

'

..

Ll?

>0

L8. L17. U9

<0 .

L8, 1.,17. U9
L8. L17,· U9

,. ditto, if" 9.(AC) =0 .

address~*

UJ

replace ,address: sectIon of
..;C(al +~l,~,i.th)~.~;~p.~. :;add~~ss,·:: .
. . ,-of the.'reg,lst.el";; containing the" .

L16

·most:re¢en~~·.lm:Q:,6r:;c6ticiit.1onal
jump ·which::.,·t,?Ok·:~ffect·;~·
.... ,.

caf al b

copy address from**

address' s~c'ti~~b'n1y{a~an
integer) of. C(al+~)~AC

L16

c?.i al b

c.opy address into·*

C(AC) becomes the new
address section of C(al+~)

A'l. L16

rat m b

reset (counter b)

set ib=O.

jii al. b

jump if incomplete

increase ib by 1, then jump
to al if
~

U2, U19

~=::n

A7. L3,A18,Ul9

1b<

.

,

.

jic al b

'jump if· complete

increase·ib.b;y l~ t~e.njUm:p:.
to al.if. ;ib~"~..,:..';'

A18. U19

inc m b

increase (counter b)

increci:se'both iba.~d·~ by iii

Al8, U19

decrease (counter b)'

decrease both

by m

Al8. U19

•

I

cif al·b
~: '

c~v_:al.

.. copy index into
"

b ..

;

~ ~nd·~

ib as aninteger--+ al. ;
,: '.. C(AC): af3 .;:an int~ger-+ Ad,
. .C(AC}asa numb.e:r;~ al+~

conve~t

.
l

stp 0

;

.

.

.

•

.'

<

stop the oomputation

stop

-

.. " .

.

*.Theprogramming,mistakes which re.Gult in a post-mortem.a.re 11sted on the next.page.•
Appst-mortem resulta,whUe performing an instruction if any ofth?· programming mistakes.listed wi th·that instruction are made.· :Apost-mortam will always occur also if
(a1+~)~JOO or if (a1+~) o.
.
" ,

<

*. When

of

executing this instruction. a counter' letter, if any,' 18 not considered part.
the address section of the instruction inregisteral~~ •.

3, lI- 5 -!J
t

•INsTRUtJ1rION
pat a1 b

?OST-MORTEM*if

DEFINITION
plot a point on the scope
at x == C(al + ib)and y=C(AC)

MEpJ'HNG

plot at

A6

LR, T.l14-

I

L15,U9

frc 0

frame (scope)camera

mO,ve the next film frame into
pl~ce and open the camera
shutter if it was closed

ric 0

read in character

read the next char. via the MTR
into AC as a pos. integer~77

(Comp.stops if
no ta.-oe in. MTR)

rin 0

read in numerically

read the next complete integer
or nureber via the MTR into .-\.O

AI t A2. (also
see ric abo'Tle)

tyc m
tyc m+lOO

type character

record 'on 'c!elayed printer (m),
or on direct printer (m+lOO),
the Flexo.char. specified by m

L20

typ'~ numerical

record on dela.yed printer (m),
or on direct nrinter (m+100).
C(AG) as s~cified by m
(See table below)

.~4.

tyn m
tyn m+lOO

value

AS. L8

U9t U21

Tabulation of m values for use with tyn

:m.

o

1-9·
11-19
21-29
Examples
m=O
m:::103
m~5

ni~116
1~

"23

initial zeros
ignored
printed
spaced over
ignored

no. of digits
nrlnted ~ d

total space
neg.
1~d~9
d
d+1
d=m
m
m+l
1 ~ d ~ (m-10) m-10
m-9
d=n-20
" m-ll
m-ll

prints as

~

o
m

01S

see examples

o

C(AC) =1234

CC1.C) ~ -789·

C(AC);; .004786 C(.AC) =13.57

1234
Post-Mortem
0123 /1«,'1'1234
~1 .. ·23xl03

-739

0

14

-789
-00789
**-789
2
-7. 89xl0 ***

000
00000
*****0
*4. f9x~10-3*~

014
00014
*~**14

*1436xlO

Direct!:Je1ayed
Delayed
Direct
Delayed
Direct
Delayed

*represent;.s a space on· ·the printed cO'Oy

?ROGR8J.U·!I;·IG l.fISTAKES which' cause' a. POST-MORTBlvf

:,,1- Result is .·an.;· integer of .ma.gnitUde~'2r4-·

~i~,': :?(lqj-~nd c(al+ib )are not. bothinteg;ers
,.....
... ..·6
A 2 - Res1l1 t is a nUmber of m~~l tude ~ 2 3· . L14-C(al+i ) fs undefined
b
u :3 - Hesult is a number. of magnitude~ 23 27 6 7 L15- C(al+~)iE an instruction
......

11 4 - C(AO) is an integer of magni tude~ 227
A 5 -·'ceAC). 'is a. number' of magni tUde~263
A 6- ,c(Ac)l~1024 or 'C(al+ib>l~:,lO~4 .:. ,

7- C(AC) is not a positive integer<300
L 8 - C(AC) is an instruction
U 9- C(AC) is undefined
'UlO - O(AC) is not an integer
A11- C(a."1+i ) = 0
b
L12'- C(AC) and O(al+ib)are not ei ther
both integers or both numbers
A

A- Arithmetic overflow

L16- C(~l+ib) is not an instruction.
L17 - If C{al+~) is not an instructionandthe
.
jumptakes effect.the Post-Mortem will
occur after the jUIIp is eyqcuted
Ala - He suI t ing magni tude of ~~ 512
lJ19- m~S12
L20 .. m 77 or m corresponds to an
,
. illegal Iflexo character
U21" m=lO or.m=20 or m~)O

L- Logical mistake

>

U - Unlikely mista.ke

DEFIUrrIONS OF Sy!{t30LS
~

becomes the new contents of
Accumulator
Contents of regis tera1 •. a1 represents any floating address, i.e., any
letter except 0 or 1, followed by any positive decimal integer < 1000
C(a:l+i ) Contents of theregis.ter whose address is obtained by adding 1;;0 al the
b
value .of ~.

AC
C(al)

ib . .
~

RR
MTR

I]he index associated with counter b. ,where .b represents any of the 7
counters a. b, c. d, etf or g. ,Except fo!" the 6 instructions rstt jii t
jic. inc, dec. cii. a. co'unterletter need.!!Q! be specified at all.
'lhe criterion associated with counter b.
Remainder Register, which holds the remainder after dhr and is not
changed by-any other instruction.
.Mechanica.l Tape ~ader into which is inserted a punched Flexo- tape to be read
in under the control of the computer.
..-"

3!'

If.!

5 - lO

giscussion

passion .J
In repiy to questionspDonn Combe1ic stated that the number of

Wh,irlwind I instructions required to execute one Summer, Sesaion instruccoo
tion verieG from 30 to 900 0 and the average tima required to exeoute
ona Summar Sesoion instruction is about 100 times the time taken by one
Whirlvind instructiono Hovevert) it must be borne in mind that a S'UIIIIDer
8ession instruction performs much more 'Worrk than a \fuirlvind instructiono
Mro Go Clotar asked vhy the input conversion routine could not be
nmde to accept9 tor exrumple g ~ as baing equivalent to ~g instead of
reporting this as a mistakeo ~orQ Adams said this was an important
pointo It vas thought better not to allow freedom where there waD nothing
to be gained by itD and it was felt desirable to detect as many as possible
of the mistalces that might commonly be madeo Mro Charles Go Lincoln p \lho
had used the Summer Session computer9 agreed with this viewo
Stanley Gill described a technique used on the 1111ao which makes it
unnecessar,yto list constants separatelyarld refer to them in the program3
instaad 9 the constants may be wit'ten direotly in the instru6tion3 uhich
use them& thus~ instead of writing
cef a1

819 '~123

and

one might write simply

cor

~)-123Q

'

Donn Combeli,c gave I) as an example of mnemonic coding{) the \lay in

uhich input and output editing is requested in the MQIoTo Comprehensive
Systemo Three letters specify respectively the mediumg whether input O~
output e and the n~tational fomB thia may be folloW'ed by a sample numbero
Thus MOA ~lo2345 calls for output to the magnetic tape in alphanumeric
torme numbers consisting of 5 decimal digits yi't.h a decimal point aft.er
the first digit and preceded b,y a signo DIB calls for input to the highspeed store from the drum in binary formo
In answer to a further questiong Donn Combelic stated that no official
means for reverting from Summer Session instructions to \-lh1rlu1nd instzauc=
tiona during the run of a problem had been pro~idAdo The Summer Session
computer ~as designed for the one-shot programmer rather than for the cne=
shot prog'.falng and was designed, to be easy to laallng

tIm hardca

ue have increased 'the number or computers availabla ro~ 'the solution
of problems from one to f·owoe Ea.ch oi' these cO'J1lputer9 hUi!: ito Ot,;t1 advantages and disadvantageo. The faotors involved in choosing a:mong th.e.m

ware~

lncluc1e:

ease of coding

(08

measured by the time ~.ttakf~S a

pl"ogral!1nl!.el·£1

'Who may be untrainedI' 'to code his problem) 9 81'cilablc storage Qt computin,g

speed" computer reliability (fall." a aim\1l!'Md oO'Anputorg this vIII depend
upon the degree or testing)g easa or erl~or detection and tape correction~
oY6ilable preniaionp Lmd a~nl1~blo Bubroutine I1brnr,y~
'l'he

~ll!g

of the problobl cau be greatly simplified by the

U9t:'!

of

ouch techniques as floating=point representation" s,mbol1c and relativc
addresses" and cOWltlng facilltieBQ

HOreOl"er9 the

UB~

of ml\emonic instruot.,..

ion codesp compiling rOll'tinaslll Dubrout1.ne librilritls" etco nbbrev1.ates

the training period or a nev progrEl!ilmero or COurS8 g the availability
of more than ona computer (real or simulated) does increase the numbar
of conventions that a programmar may have to laarno Also the slowing
dow or the machine by"' interpret!"Ie routines doss place a certain responsibility on the prcgrammar to cake more orricient usa or such routineo. ,

6., 2
Dcbu~p;ilJ~

errors..

is f3cilitated by routinas that detect ond describe coding

It is unually'simplo to find tho source of such errors since the

run is stopped ns soon as the error is detected,.
'Nhile the problem routino is

~till

~~any

errors can be found

being read into tho computer.

Once an

'error has been detected, the use of service routinos po~its the printing
out of pertinont information in a palatable form. It should be mentioned
that the printing out of iJost-nortem informntion does conSU~le machine t:bne.
Consequently a co:apro:,lise r.tust be reached as to .iust hou ;,luch information
should be printed out eachti.';te. Also the inclusion of error detection
in interpretive routinl?S slm'!s the :':achinc da;'1n all tbe moro. This r.lieht
be particular~ objectionable in production runs so that it might be
dosir!lc:!,o to ~aakc Sl;1Ch features optional.
,

Unfortunately thor')

~'1ill

,

nlt,wys be a few cases 't-1here the source of

error is difficlllt to locnte o The use of executive routines introduces in
itself a very troublesome source. However, 'in prClctice, errors arising
from an nctunl :::istt.'kr: in nn exC'cutive routine or from 3 transient mal...
function arc not as difficult to localize as ono might expect.. Of course o
debugging the exocutivp routino itself depends on tho degree of familia:": ty
of staff members l-lith tho routine in question ..
The running of the problem on tho ::lachina
section belot'l on n performanco" ..

~'7ill

be discusned in the

It. should bp mentioned thnt

H~:I~

comput,

ing cen~ers have found it vcr.y convenient (and at times even necessar.y)
to ;.1ake usc of rerun routines. At tho D. C~ L. the na ture of' the problems
v10

have run nnd the relinbility of vItiI have made? ib

to include rerun routine.'3 as a regular

llnn~Cessary'

I'
0.'

":;.\.

for us

fenturo~

,

L
0

-

.

.-

\ "

, Error ana1:v:s l~, can sometim('s be effected by an intcrprctive routine '( \)V
that, carricG

~:mt ~.1.

parnllcl canputation on tho erroJ.' o'.lrrti:':Jatcs..

Such

routines can be used to alter the program if certain bounds are exceeded ..

2" !!.2V'eloumen~ .of :qtil-itv ,,:)ro~r;:)~s. l'~ computiIlG center serves as
a fertile source of: Sum?;estio!~s for ne"1 auto;'lLic routines.. HO~1ever there
are

ITJaru

pitfalls avlaiting tho

introdt~ction

o!"any net-l routines.

At the

D.C.L. a revised version of the comprehensive s.ystemof service routines
was recently introduced in the following 't~ay.

described and criticized at group conferences.

}4~irst

the revisions were

\'fhen the cban,ges 'Here

finally aeroed upon p they wore cooed and debugged as s cparata problems.

\J'

') ..

..l

6- J
J~

ncrt1 cOi?Y of the

co:~prahensivc

system (culled

as II)

Has then

prepared

,~

incorpora tine the changes ~ CS II Has thon tested by tho me:nbers of the
staff l;1ho Here reStJonsiblc for the, changes., ~;hcn thoy£elt that the
system l,tas suffici~ntly debu~cod, they supervised its use by a few of,
the more experionced student prorrrammarso In the m.eantime separate
detailed mnnos Here prepared describing, hotv CS n 't-!ould, affect tape
roan procedures p comput~r operation, and the programmers themselves ..
Finally the nen system t-las adopted tor every day usc, but special core
t-las taken so that all existing routine's could still be handled properlyo

30 Clerigal. Since eaoh executive routine that rrw.y be used by a
proercll11Tlcr 1'11U have certain conventions of its ot~n, the usc or such
routines 'Hill complicato the ru~os for preparing tapes (or punched earos)
tor reading routines into the computer. Hot-1ever errors can be minimized
by Bu!table supervisionS) dissemination of information, and ta~ preparation reques,t forms,. .Primarily it is the responsibility
of the programmer
.
,

to comply lath the conventions of the automatic 'system he is usingo
Inconsistencies are often detectedby' a staff consultant, tho tape roan
suporvisor. or tho tytJist. other checks can be' incorporated in the roadin routine.
It should be noted that in r:muy 1>1ays the typing of road';"in tapos
can be simplified ~and even made elegant) by the use of executive routines.
T~ uso of pseudo-codes and library subroutines reduce the time of tape
preparation Correction ot tho tapes is simplified i f the read-in routine
can be made to ignore certain characters'~
0

'!he processing of results can be facilitated by codinG tec~queso
All co:nputer output, t-1hcther it be tYtA3d out directly 0 recorded on magnetic
tape,or on film, ,can be automaticallY tapged with such pertinent 1nfo~tion

'.

ns ~e problem nunber 0 progra~.l'1ler s nome, date 0 ; ~tc
,

"

0

,

40 Perforr.lanca,. It is possible to automatize the running of problems, on a com: uterso that a chosen sequence of problems can be run t-liih

no manual intervontion boy;~nd the pushing of a starting button. Hsl'\V
elements of suoh a system are already in usc at the D.C .. L. By the use
of special symbols on the :~pe for
given probleMa the rend-in routino
for the Siim.latcci computer, desired v7U1 automatically be s~lected.. In
turn o the read-~ routine lvill,provide the appropriate routines for carrying out tho desired arithmetic, cycle countingo etc. For oach routine'

a

6-4
that is read into tho computer, a log is punched out on paper tape of the

tape nu."ilber, kind or tapao tho timso and whether mor,lory was ernsed. (In
cose oomputer op~ration is interrupted for arv reason this is recorded
directly on to tho log tape by tho operator in attondance.) It a problem
that makes usc of an interpretive routine tails, a·.·)propriato information
't-lm be automatically printed out.. Programncrs 'Hho desire particulnr
post-mortems can request these in advance by having n suitable tape
prepared Thus by splicing together a sequence of "tapas and by making
use ot a special ·'routine to serve as director, ~le expect to have a
large portion or our computing periods run automaticallY.
0

So

Roportso The lop;ging tapes produced during a computing period
can be used 't-Jith suitable routines to ·compile rocords summarizing computer operation over aru desired period.· For example. the roochine t:L"Jo
used by each problem and programmoro the amount of '8~m" time. percentages.
etco cun· all be computed and printed out for direct inclusion in reports.

60 Haintenpncoo Special routines have proved very useful in tho
testing of cm~puters. The extent to ~h1ch such routines can be used
l-1Ul

depend., of course. upon the ingenuity of tho progrmnmors ond the

nature of the computer., At the,D.C.L. two sets of routines have coma
into use •. The first is used l-11th marginal checking tor tho routine
testing· or tho various computer sections. 'The seconi set is used tor
. diognostic purposes to locate.actunl failures ip the auxiliar,y drum

syste:,l and terminal equip-llent. In the future it is planned to combino
s~~o of tho features of both sets of routines •.

~

RESUME OF SFSSION 6
In answer to Ho Browns questi,on p J.o POl:.~ter stated the responsibility

for having proper identi~ing information and properly following conventions rested with the programmer at the l1hirlldnd insta11atio~Q . The
typists are not expected to find errorS9 but are encouraged to report .
any observed to their superv!sorso HQ Brown mentioned that at MIDAC o
"typists had been very useful in this respecto In ans"rer to G. Clotaros
questioni' ..T. Portor commented that under this system there is little
advantage in having typists with a knowledge: of computingo In answer to'
EoAo Voorheas~ questionp it was observed that the Whirlwind installation
does set aside a specified par~od for maintenance and testingo
So Gill questioned the necessity for duplication of labor in having
programs checkad by typist tl programmer and machine
CQUO Adams observed
that as much inexpensive checking as possible seems desirable and that
th~programmarus check is· often not thoroughft
Do Williams asked to what extent mathematical formulation of problems
\laS checked at ~/hj.rll:1ind and J. Porter replied that staff limitation
made such checking very difficulto J OC4PO Hiller mentioned that s't, Cambridge
, ," a priority committee had bean very successful in screening both programs
oil

and programmers and that in many cases a formulation had been changed . .

Ramshal1 inquired as to whether checks or hand solutions are re en
quiI'ed at. Uhirlwind and uss'assured that these vere,usually requiredo
The question 'Was ralsed as to whether MoloTo~s policy of having
programmers do their O~ coding was a matter of preference or due to laek
of personnel o ,JaPorter Teplied that lack of personnel and ~rrTus policy
'of tI'U ining programmers were the primary factol·s
pQ Bremer ~ondered what was done at Whirlwind about machine malfunctions
during computationo Jo Porter and CoWo Adams replied that these ~re rare
as ma.l'ginal chocking generally an't,icipated themo Howverg if a resul"t
t,rss fiot repeatable or could be reasollably attributed to machine malfunctions!)
\10

0

the engineers are given as much information as poss.ible and generally

cor:cec!t the dj.fi'ieulty very quickly
In anmver to a question about el"rox~ estimates p it developed that'
CI

some 'C€:utsTS actu.ally used parallel computation to keep track of error

accumttla'ciono

I~~~ the r.'lou.r~e of
I
I')'i
""d
()Jlfn'a'.;,
'tlg t"lJQQ COU...J.

l"c;l;ault.B 20 ,:..

.t\u"the'r

1..

!J'ij

1,

'\
l)"t°oxen

dl~ous~dmlg
l

(lOU"~l

30% .for. diJ,buggingl) :3

<:::>

,1}0
u

:tt llppnHt"tld thht. ilh1.:rli.d,n;'.:l'/a
J>
t eJ.'] 6:1."
i
~l,··
appro'j(J.!U.U
.I.J = "on',,!
111'''''.1 :rdU"j
l.ng

'5~Ji

rl.slf\lnctJ.ollo

'-<\

SchGduling 1:;, dono

on a dayc.,tt)-::··dr.~ybtlsi3 excopt foX" lnrgo prodtH~tlan ~'1,mj, (\

Sa Gill and I.AI)
py·ogr),~r.illll:~:r

R~)~el1th8.1 d!I3CU9l;'\()d

the f'.equenc-y '.0)1 th whlch

ehould be nlloued on the Ulu.r;hll'lo ~

indiol! te thn·t tva or three

t.imeE~ D.

day

ga~'e

l:i

Tho 'C:Ott':3e'1l8Uf-i ~f.!e~it~d

good reHu.t ts,~

To !illaw for the unpl'13,dictnblli t.y ot' the durllt1,on of d~Ollt~g'l!:G
l""UIlS~, f1 list. of' tJ tB.n.dbyr.l or trading ~~chlne tlnv.; \.I'in·}~ ad'Vo~ated
(>

tlCl.'

THE A-2 COHPILER

The A-2 Compiler is ElIl organic executive rOl'ltine uhich produces a
program i\')r a specific 1l".a.thematical problema

rtllUling

It is organic in the sense tllat

it is an out-grm..rth of cOMpilers A_O and A-I and essentially contains them
~ithin

itself and in

time~

,Jill

itse11~

become a part of

:A-3~

It is a. proto-

type of A-3 as t-lello
Compiler A-2 drat"s on a library of subroutines of two basic typos:

AI,) Static subroutines which need only bs transformed from relative ceding
to specific coding and ente:red in the running pror;rarno
subroutines 1'0,11 :into three

These sto.tic

cla.sses~

,10 Stored subroutines" il'lcludinp, the elementary ari thmeti¢ oper....

atioDSo

These subroutines are st.ored during the entire running

of the problemo

The running proRram indicates only the ar({tlP.:ents (,)

results and jumps necessary to use' them.,
20 Tape-stored subroutiI19So

running

progra~tl

These subroutines are en"tered in the

and thus are rend from the tape as required and

repeated in the prorrram as needed()

30 "Own-Codinp." tape-stored subroutinesCl)

~ubr{jutines

peculiar to

the specific problem!,) either extremely specific or of rare In-

c:iclence and hence not norI!lB.lly included in the subroutine library ..
Eo Dyuamic subroutines are generative rou-cineso

'l'hcse fall into two classt;~ ~

10 Computational - subroutines in which one or more parumeter.9 such
as exponents\, dec:i.ma..l points ll or units are defined b;l" the. input;

informationo

The library then contains a routine which precessos

a skeletonizod relative-coded ·subroutine cont,.;-i.ined \011 thin it to

produce a static routine"

20 Data-handling - all datn-handlinp, subroutines are genera.tive in

nature"

Included in 'the subroutino library are generators which

yield statio subroutines \1hen supplied uith such information as
tj~e

item size,

of transfer 9 contraction or expansion specifica-

tions, atc!;)

The compiler acting on suitable

infol~tion

defining the problem controls

the generation and transiornation of subroutines of all types and their integra. tion into a running

pro.~a.m

for the specific problem under considers tion"

The information defining a problem is
pseudo-code"

s~bmitted

to the compiler in a

Four phases can ba distinf',Uished in the operation of Compiler kl-2v

Phase I - The compiler expands the information defining the problem 'into
more readily digestible form!} "fnformation

AV~!I

and supplies oertain added duta

such as complete call-numbers ~ operation numberso

this "translation phase u will also include

th~

In future compilersp

translat.ion from :tUnctional

notation or EnF1,lish 'Words toO a computer nota.tion and it 'Will be into".-rated into

the compiling process

Q

Phase II - Information A is processed to ttsegmentll the problem...

Since

ample provision is made for t.J'orldng otorap,09 and since the arithmetic and
frGolJently used subroutines are stored for RU reference ~ the running pror,rElDl
\J:111 'Usuully extend bo~rond one st,orap,e loade

divide the running progrrur into sep,!'!lentso

Hence it is necessary to sub-

Each segment is so defined as to

consti tute a stora.r.e load or less and to contain an intepral nwnbar of subroutines",

:t Ll order to a.chieve this segmentation, during Phase IIi!

"cun  the operntion number1/ and the locatIon of its firot line

\,Jhen its segment, is in
11brary~

the

~~

rocord~

use,~

'rhs output of Phase II includes the generated

and InformatioI1 B with the added segmentinp, definitions"

III - The record notJ contains all the c1a ta rSQllirod to define tha

j1.lr!ips ordered by

Inf~I"Inatlon

These may be indicated

BQ

ni tion of the problem or by the SOb'"1Ilentinp, sentinelso
the necessary jump instructionsQ

plately describes the required
~{lse

bf

the origina.l defi-

Thus Phase III creates

Ita Oll\-rut, is "lnfoI'l1'.l9.tion en uhich nrnl com.,n

proer~

IV "'" is the tna:tn compilation"

The subroutines from the nlllln librHry

tapo and genera ted Ii brary tape are rp.ad as called for by

rJ Infornw. tion en

i>'

al'C

transtormed from relative to specific codinp, and 9 toeether wi th the required
jumps ~ read ~ and w-ri t..a ~instructicn3 tI are entcl-ad in the runninq. prO;rro1l1o

ruaninrr. prorrram is a complete and specific cheeked· proPTrun for tho 8pec1fit~

problema

29 Octooor 1953
Revised 19 July 1954

This

7-1

7. A-2 Compiler
I

Syst~

Purpose: conservation of time
1_ Classes of effort contained in elapsed time per problem
8. Analysis
b. Progranmling
c. Coding
d. Debugging
, e. ,Running

t. Re-running
2. nOne-shot" and repetitive problems
30 Minimal latency'coding
II

Logic of, computer as ,determining factor
10 Input-output
20 Auxiliary stora~e
30 Alpha-numeric
40 ,Checki,ng

III

l~ettlod

,10
20

;0

40

IV

of attack
Proof of feasibility
Prototype
Production model
Tests to be applied to any method
a. Feasibility: ia it possible, practical
b. Suitability: doeS it accompli,sh the purpose
c.Acceptability: is it satisfactor.y time-wise, economica1l13
does it tul~ exploit the computer

Development of ,pseudo-coda
1Q A-O code

20 A-2 coda
,30 Translators
40 Basic code
50 Contemplated

v

pBeudo-cqd~s

, (rI\ ~-t-\-. (. 'M. "'+\ 1..." \

,
\ \

1.'1

e- \, ,:,' \' \-

Subroutines
~ ~ t· .... 0...1
J..\ t
1. Static
S" 'r\ e .(... +c... .1
,
I
,
\/ s"",i.- p"'l~;r c.'Ip~\""'~'I':, ~\J/·r.t(..;1·10';'t-'=, ~ •.,ot IYlC,J:;e.
2. Generativa
Cl-"

40 Processing

VI

Allocation of storage
~)....l,,- 4., s S C~r•• r-r-J.. ..:.,.t~ /
Sv 10 f' cl,':) 1. In running tape
8. Program
~-o
bo Stored arithmetic
Co' Working storage
do Input=output .
20 Segmentation
30 Auxiliar.y storage
4. Unwinding
l

VII Compiler A-2
1. Translation
20 Record
30 Segmentation
40 Jumps
80 nNeutral Corner"
ho Extra sweep
50 Generation
60 Compiling
VIII Results
10 Optical Ray
20 Carne Problem
3. Function Evaluation
40 Method of Relaxation
5. Commercial Applications
ao Need of definitions
b o Specification technique

IX

Future Developments
10 Pseudo-codes
2. Translators
30 Operators
40 'Genera tors

11i)./-

(I~'.r ';-0 ..

1\\'.((.«.

7-3
78 l~sum~ of~iacussion
Replying to D. L. She110 Dr. HO'ppar said that applications

of 'the

sorting

generator werachiafly commercial. L. Ro~enthal said it wa~ partioularJ1 useful for sorting long i toms and had been used \,/i th i tams of 63 digi ta.
In answer to questions from J. "~I. Baclrus o Dr. HO'~per sho\oJed hO~I' to code

the evaluation of the ocalaI' product ()f two vectora.

She' sa.id that matrix

operations ~era ooded using a spaoial matrix library.
]}o A. Voorhees a.sked \oJhe ther the compiler \'1aa used because peo-pla were
.dissatisfied l.1ith the machine.

to simplify and shorten coding.

Dr. Hopper replied tlW.t·therea.son \'las solely-

A3-address code was US~~ merely oecause it

fittada Univac word. She' would not advoca.te building a machine on the lines
of. the,:.pseudo--code. In reply to IC •. Jj'l. Powell o she said that the only machine
feature associated with the com9iler technique was a moderately large ~toret
such aamagn~tic ta.pe or a. large drUlllD. She thought the,' A-2 .library could be
storad on most existing drums •
. Replying to w. A. ~~haw, she said that the space allo~atiqnot large
maaoeaof data. inv61ved' storing it in batches on th:e ta'Peo end oould be
handled by the data handling ganerat'or develo-ped, oyth:e· ArmY' Map' Service.
.

,

U:livac coding facili·tles were davalo'pad by

va~ious

installations, partioular..

ly the six government ones. and ware oiroulated frequently 'to the others.
~he

Compiler is thus constantly growing,
validate the former arrang~menta.

b~t

noohanges are made which in-

Answering L. Ros~nthu.l. Dr. Ho"!,)par said that one of the difficulties
of commer9ia1 applications ,{/a.s tha.t of defining the m$aninga of various sub~
routines.

.5oms:(such as income tax and sooial secUrity deductions) \-/era

defined legally. but o-tllers bad. widelY' differe~t ~ea.nings to dif~~rerit
people
In answer to ~o ~o Hurewitz. she thought tha~ the future ~m~B~s
would be on ganer~tive ~ubroutinaa.
0

COMPll.JER A-2

f\ RST

SWEEP

· .SECoND

112c:,Th2, J,:.!blb. C;1£)1
by JoHo

reprinted from Journal of AoCoHo p

S..Ee~oding System

Backus
vol~

11)

nOD

1", (January 1951+)

The IBH 701 Speedcoding System is a set of instructions

l~hich

causes the 701 to behave like a threo-nddress floatine point calculator o
Let us call this the Speedcooing c:Jlculntoro In additj,on to Op(~rClting
in floatine pointp this Spoedcoding cnlcul'.1tor h:Js tn~tremels convenient
means for getting i~ormation into the machine and,for printing results;
it has an cxtensi'tto set of operat.iol1s to make the job of progrnm:ning,3s
eosy as possible o

Speedcoding also provides autorrL..1tic n(drcss modificnt-

ion l1 flexible. tracinG 0 convenient use of nuxiliCJry storare" .':lnd built.... in
checking.

'lhe system uas developed by

m,r t s

Nm-r York Scinntific Comput-

ing Servicoo

Since this floating point Speodcodine c.slculator is slOt.Jcr than tl1e
7011) despite the conveniences ttwt it offers 9 you mir:ht ask: Hhy eo to
a lot of trouble to make an extremely fast cnlculator like the 701 be...
hove like a slo~·)er ono~ There nre tvl0 princ1~1 roasons.. Tbe first
is that some computing eroups arc 110rking acainst time" and the elapsed
time for solving

3

problem muy often be reduced by mirrl..miz:i.ng the time

for progrnr.tlling and chcckinc out the problci:1 avon thoueh tho runninG
tim~

is thoreby increased.
'The second end most im: :ortant reason for havine a Spcedccdine cnl-

culatorl) in Dddition to tho 101 0 is a matter of econornYQ

Often" the

expense of operating a computing installa tion is alt"Uost equally divided
bet~'1ean

::1Clchine costs and pE:!rsonnel cost..

Furthermore

spent checkinc out problelilS is frequently a very
of the totCll machine tirnc o

Q

machine time

apprccta'~le

percentage

It is clcar G therefore g that'programmine and tcstinr cost often
comprise batt-leen 50 and 75~ of the total cost of operating a computing

installation"

bince Speedcoding reduces coding and testinB time consid-

erablyo and is fairly fast in operation" it t-1il1 often be the more econ-

omical way of solving a problem o

Speedcoding is

an interprotiva system.

I have implied that Spced-

coding is 3 three-address s,ystemo ActuallY this is not quite tho case o
In a floating point system daw and instructions have completely difforent
forms and are treated dii'£ercntly Thercfol'e~
to h.!~vc· separate methods
dealing ~dth each
0

of

tion.

i'~ 'HaD,

thought desirable

of t~lesa t't'10 typos or infor11l~­

l'bus o oach Speedcoding instruction has t~:10 opera~ion oodqs
. '

.'

.

.

in it

celled OP and OP20 OP h~sthroe addresseo A, Bg.and Co associ~ted ~ith
1
1
it an~ is al~·,lays· an arith.~etic or an input-outP':lt' qperation. OP2 bas'·
one'address 0 Do associated'

t-li th

it and: is lllHayS a logioal operation.··.

OPl deals t-lith floating point numberso OP2 deals l1ith instructions. 'Ibis
arraneement 't'las also adopted because itnakes cf'f'iciontuseof the space

available for an instrUction and because it ofton spoeds'upoperation,
.qy reducing the number of instructions uhich must be intarprcted.

OP1 operations consist of the usual arithmetic operations plus square
root o sinaparc tangent, exponential, Ilnd logarithm. : .'1hore are also
orders for transtcrrine; arbitrary blocks' of information 'batt-ICen electrostatic storars and topes t drums or printer. These inpu-c;..output orders
hovo built-in automatic checks for correct transi~ssion. ~"cCOnlpaqying ,
tha OPl operation code is a code to spee1f.y that any or all of' the three
addresses o A0 Bo Co should· bo modified during interpretation by the cozrt,ents
of three associated special registers (B tube~)labeled RAt ~Bt Rco This
feature often enables ODO to reduco·the number of instructions in a loop:
by a factor or 1/2.
\'

The OP2 operation ill an instruction is oxecuted after:the OP • By
1
means of this operation one' can ob~~inconditional or unconditional transfer

One caD tnitialize, the contents of arry of the R-registers
or onc cant in ono operation. increment nt\V' or. all of theJ1-rogisters E
transfer control. .u.nother OP2 operation alla-ls ~e to compare the contents
of·· control.

of an H-r.ct;ister ltith the given. D.... addr~ss nnd skip tho next instructiono
. i f they aroequal/. OP2 al~o provides a··sat of operatio~.forusing a .
i'i.."CcCl point aCCu.~ulator tor COil1putations '-lith addresses and for comparing the contents 'of this ticcumulatol't-11th the D

~ddress •. Finally, OP2.:

provides a' convenient; means of inco:rpor~ting checking an.8 problem i t .
desired. This· .feature consists' nw.~ . .C?~ t'Ho opbrDtions, START CHECK,'

Clnd END CHECK;

311 instruc·t.ions .bet't-1een thoso tl.,O orders may be a ute-

CIlntically repo:lted as

II

block and at tho end of the second repetition

t't-l0 separato chock sums ·l11lich have been accumulated during the t't'10

cycles uro cOI!lpnred onU the instruction folloning the BND CI:ECK skipped
if they Beree.

Instructions or data mny be stored anY-Tlhere in electrostatic or
Cluxiliary storacp. as sin~le 5peedcodinz 'Hords 0 f.. vera go execution times
for wrious ';;'vecdcodinr. operations areas follot1s
Add:

402 milliseconds

~'Lultiply:

3.5 milliseconds
14 milliseconds access

Read tape:

Transfer Control:

plus 106 milliseconds per
v10rd
.71 milliseconds

Electostatic storage space
Let us

rOll~l

3Vaila~lo

is about 700 't-lords o

a problem from its coded £or.m on prorramming sheets and

data sheets until it is checked out and rcc::ldy to run.
tions and data arc punched on decimal cards vlhose

First the instruc-

ror~lats

are identiCal

to thoso of the sheets. J.f there are any data· or instructions Hhich
the !.)l"Oaram roquires front tapas or drums, loading control cards are
punched (one for each b19ck or information) l1hich t.,ill cause the loodi~
system to l?ut this infornation in' th~ proper places in au:-:iliory storago o
The dock of binary cards for Speedcoding 1s placed in front of thi~
decinull deck consisting of instruction cards, data cards" and, possibly 0
loading control cards, a nd tho entire dock is put in the 701 card reader
.~hen tho load button is pressed,. tho information v7ill be stored in :
0

electrostatic storago e on tapes or on drums as indicated
on the cards.

b~

locations

"hen the last card in road, execUtion of the program will

begin automaticallYo
In checking out tho program, usa 'Hill be made of a feature of' Speed-

coding 't-1hich has not bean :ncntioned ycto

Each Spcedcoding instruction

includes a list cOOo 'Hhich ::lay bo sssiened one of three possible ~alucso
Associated ~lith each of t.hese values is a s't-1itch on the operator's
panel of the 7010 During execution of a program all instructions 1'1i11
be printed l1hich have list codas corresponding to SHitches l1hich are ono

I f one has properly

CJ

ssit:ned list codes e one may then check out a problom

in tho follotJinc: Hay;

One bogins exocution of the program

sl1itches ono after seeing tho !nost

repetitiv~

~·]ith

thro~

all

portiona of the progrfJTn

printed onco or tt-lice II one of ·the suitohes is turned of!' u aftor tlhich

Fi!'lnll:l ll tbo

only Moderatoly rovotitivo parts of the program are listc!dl)
s:.:cond suitch is turned off

arc seen..

an(~

only --he least repctitivo instructions

If trouble is encountered in the last cycle of a r,nwh

loop., one can npprouch this point rapidly \-lith a

mini;~ur.t

rep'J[.it~.,d

of printing

and just before reaching it. one can turn on 011 three S\-]itches and

all details of the proernmo

UC~l

Ench instruction is printed Hith cllplwb0.tic

Olloraticn codes just as it l1as originally t·:ritten on tho progranr,tinL:
sl~oeto

The flootine: point.nu:':lbers at A~ 3~ and Co the cont.()nts of the']

R-rl~~:'isto}'"s ~HKl

tho

~;ctr1refjS

accumulctor t arc Dlso printod 't/it.h (]3ch

instri.lctiorl o .
NOH t.ha t ue h.3ve hriefly scen hoo .5 pnedccding Horl-:s t you m~lcht bo

intctrestecl to knm' uhi'Jt

I.:ru.t".

Qxp(Jr"ienct.3 has b:::en

I b~~lievl;j that five ,OJ. instnl1at.:'loru.;
possible

I)

thos~

Ui~F1d

uho have

conttH' in NOitT Yor}: Hith a
t.ho

'pr'C)g:rEliU,H~ci

Ho had

Sp-,~;;dcc..ding lilDllU-Cil o

1.-J~

using

Ol"

j~J.t.hough Ulf.lny impr·O'v·GnlOnt.s:~lrd ey.·b)l1sion~::

codirlgo

tl)st 0

ci.t"t::

Hi th

it

rCI:,(".n-t. tlw L

5p('ed('~odi'{;

p:r'oblnr.l

it

i

tie

plan

;,'(:,
I (.)

~::Y.'EJ!;(.Hi'\~1)

nsn ~)p{:a~l".

to ~)p(:;od(!ccl:lnf:~ r';ll"J

1~. i'1L;tua.L~:'(· :~a ::,y to /.1::.;0 ~

.t~ll ~ml!(~t"H~"~'.

;:,,·;<1

~['ec::dr ';:,~)

UlO entire pl'c1bleIn at, 1'1 i.s

CAiIl oLf~.e(· u:;):tn~';

hI) eut~

LrinJ.!d1ldl

his

ri:Jsult~~~

·\.·1ith a

i)l

I~rdy

.ho~~.p ~'.CU;(,

have done pr()blG.".ms llith :,;iP(H3dc~oding Hh:i.ch l'HD fo!" J.Of) hOlH'iJ 9

probl(!fllS Hhich

Experience
lJOCkS (.\~ tlOJ91B

coding in a

tool~

hl"l 5

th:r(12

~)iH:r.\ln

m.:t.nu.I~As

th.:it.

0

P1Sl1Jr p~Oblf;H!L.'3 ~·!ht(~h

filir:ht

1'1~ C:'U:UlSS that ona
701 'installation hus devoloped a fiiochanieal prodedura for translating
their standardCPC routines into Speedcoding
used these programs quite a lot.

progr~:ns

and 'havo alreactY

, To summarize:

Speedcoding is a floating point three-address system't-lhich rreatly
simplifies programming t and ,checl(ing out ,a~:·program. Speodcoding
provides convenient input-'output. ·.c.p~rationso built-in chocking, easy
loading and printing. Therefore, Speedcoding reduces programming and
testing expenses considerably. T1:ese exp".)nses are often a large
part of tho cost of operat~ a computine instclllation. Thus
Speedcoding is econOmical as 'Hell as conveniont to use.

,
RESU1~

8ca6

OF SESSION 8

In anstJar to a series of questions p John Backus stated that one

Speedeo word consists of 72 bitss available Speedeo storage is ,about ,
700 registers (equivalent to 1400 701 registers), provision is not
included for handling symbolic addresses although Un~ted Aircraft has
added such a provision; OP1 is carried out firat~ then OP2 can be
omit,tedl) but something ,must be written for OP - ~ogo NOOP gives no
1
operation. Mr. Ramshat·j: indicated that SpeedCo tlould be about twenty,
times alO1.iSl· than a directly-coded sc~-f'actored routinso
MrQ Backus 'indicated that he 'Would nOli prefer a one-address
code in SpeedCoo ,A three-address codewaa initially adopted since it
seemed to corl~spond to what people ware using at thetimao Howeverp
in practice he has observed that about half of the instructions in
Speedeo programs are effectively one- or tvo-address instructions
Also it is more difficult to unpBckage the three-address pseudoainstructionso WoA. Ramshav pointed out that in a SpeedCo instruction Of is
1
a threemaddress but OP2 is a one-address operationo l~o Ramshav also
pointed out that by providing the option (b,y usa ot a spacial bit) of
.
allouing the result or an arithmetic operation to be added to instead
of replacing the contents of the accum~atoro a 20~ saving in time
could be obtained.
DoL: Shell stated that at GoEo they found it easier to write the
dlnterpreter rt or ttdispa.t~horn in thapseudoacode. On the average it
takas about 205 milliseconds par internratad instruotion - and this
includes instructions for ,square rooto transcendentalso etc.
John BaclOls indicated that a threa~dress code facilitates the
specification of 1nput-outpu~' routinea~ Also the use of R - quantitian
(B=box) can modify all three addresses a.t onceo He sta.ted tbBt in some
cases a oat-up oombining computing 'and subroutines may be slower than
an inter'prater Among other things G this dapen:ds' on having in-putoutput speeds that are much slower than the computer o~erationo This
Bort of s1tue.tion usue.lly results in the, condition that "sa.vi~ space
se.vos timan Goi·!o Hopper stated tb.a.t' at Univac they compile beca.use
they can read in as test as they can executa instruct1onso Mro Backus
then stated in aus\"l«:3ring a question asked by Do Combelic tha.t it \1ould
be d.osirable to design. a machine to do compiling .... but this also depends
0

0

0

,

.'

.'

. :

~

•

,

~

I

I

r

,

upon whether it ~s built-in f1oatingapolnt arithmetic o ~oL. Shell
~~prasaad the opihion t~t this discussi~n ~ointed out w~t he feels
,

'

,

'

f

\

;

to be the chief weakness 'of the 701 and 1103: vizo that the in~ut;
..
. i
;
output opeeds do not match the machine apaedso
,:
I
. .
John Backus thon described the algebraic coding schema being

developed at IoBoMo He also discussada. logical procadure for a.ssigning
storage space to sections· of a large routino o
D.Lo Shell emphasized the point that in an~ algebraic coding
system it io desirable t·o be able to· gat out a record of \'1ha.t was programmed. This would be difficult in the system suggested by Mr. Backus
since many of the characters used do not appear on IoB.Mo equipmento
Mr. Backus indicated that many of these difficulties can be overcomoby
using combinations of available characters or by changing some ot the
kays (eogo $). Itr. Shell remarked that his group had problems with
traditional notation which is not like any of the auto-codes proposed.
GoMo Hopper suggested that suitable labels could be ~laced over the
I)

typawr~ ~ar ~ys.

Jack Jones noted that this would make reading and
checking rather difficult.
Dean Arden suggested that the problom of finding the index i for

1

which a sequence { x assumes its maximUm value ~lou1d be a.s difficult
1
to code in an algebraic coda as in the more commonly used codes o

9~

CHorON OJ!'

um·n~RICAL HE'~HOD

The ooject of this d.iocussion j.s to consider

ho~/

:Jroceases of uutomaoa

coding fit into the genera.l field of calculation by automa.·tic computers II aml

I shall indica·te Gome cases vlhare efficiency. of the coded -program is more
impo:rta.nt than th(; saving of
10

tiD16

opent on codingo

An impol-tant sUbdivision of problems is into t\.,ro categories

(I) !,!uch in-put-output -- Ii ttle computing.

(II) Little imput-output-- much computing

D

'fhis su.bdivision (artificial except as ~~n indication of extremes) has COJlr~

aiderable effect on the design of machines o
20

I am interes'ced in ano ther su~:)(ii vision of similar imnortance (and of

sim:lluI' artificiality) in the design of Jrogramso

(i) 1·1unh coding -- little running-time on the machinso
(ii) Little coding ....- much running-time on the maohineo
30

J!his whole course haG been

ma.i~lly

concerned wi th methods

fOl'

fying coding - by tryi!lg to ma.ke it as a.utomatic as pOGsibleD

simuli-u

There ma.y

thus be a loss of efficiency in the final program, to a greater or lesser

extent 0 since the possibili ties for hUlllc\n ingenui ty al·e reducedo'

The se

methoda are thus primarily a.pplioable to -problems of type (i)p for which
li·ttle machine time is needed..
lema of t.he' tYP9 (1i L) but it is

loops, to

oe

'l!hey may:; of
mOl"S

COUl'se

0

be applied to prob ....

importa.nt g partioula.rly wi th inns I'

used very oftem, to get the utmost E1uohine efficiency!) even at

the expense of consideraole time spent on coding (the w~rda

I

muc h' and -'little'

uX"e II

of course II rEllati ve to total problem time)

1,1. 0

11ha 9rice :fo:r." simplicity in coding is very often grea.ter machine tirre!)

aometiL18S by

<.\

<1

consiuerable fa.ctor!) on the' pro'Jlsr:l

IT'o5.nly of the effeot of choice of methodo

i.a.~

concerIled~

I a.m ti1.inlting

tihethor this ie simple

0111

sophis ticated{l but ·the same applies 0 with less f01·ce 0 to methods of coding
a:fIGer t;he method of

co~putation

has bean choseno

'£he desire to reduce coding effort and to

~roduce ~rograms

rapidly for

machines has· led to the saying thate
nJ.\.~Lltol!1u.tic

maohines orefer simple re-petitive methods o in which cycles

of orders are used many timeso ll
III thiu

\'Ie

should re"9laoe l1a.utomatic machine3 u by "coders 11 and !. t is then
l)

cleat) that this pl"inciple onables a. f'e\1 coders to u:3ul with a larger number
. of proo19D1s D and to make good use of machines which might

id10"

othar\~isa

have been

Y-2
50

:fO\.". many machi:les ure overloaded and it oocomes

cient methous o even though theG9

may

involve much more time spent on codingo

if machines are to play their proper parto
working full

time~

to use effi-

im~)Qrta.nt

A muchine r,"ay easily De kent

on a useful proolem o but taking 10 or 20 times as long as

it might with a better program.
As un example of this we may consider the use of iterative methods of
comoutationo
each~

I hav~ seen cases of iteratio~a taking perhaps 15-30 seconds

repeated over 100 timeBo

which may seem reasonaoleo

This Moans D sayo a half-hour

~achine

runo

.chare ure 'hoy/ever tvlO points.

A slow convergence o apnroaching a limit as

~

saYDwhere n is the
number of iterations. \1il1 'ea.se when the al·teration vanishes -- this
(1)

1 2

alteration varies as accuracy

0f

lP

D

p

normally, and so vaniahing to 10- means an

on1 y l ~-~P
_
in the

result~

Slow iterations can Batt1 e down

very far from the limit pointo
(ii) Standard methods of

extl~a.polating

results froD) :3 or mora successive

iterates (a.gootha tmthod of Aitken) can reduce time substan·tiu.lly~ besides a-voiding tha diffi.culties in (1) o too ~y 10 /.l~+-b:v- 10 A\(}k~", c...1-v(
I'
In.,.;'';..
0.. s() -r>/ C lVt1"" •

.an ilera.tive cycle should be used severa.l times (short ones perhaps u:ore
often than long ones)o Then the last J or 4 !torates should be used to oxtrapolate a. new starto

~hUD

instead of 100 iterates, one might have 100

extl:"hpolate o 10 morao extrapolate - result., saving 75% of the time for a
single se't of data o

60

We may aa.y f)

thefj.o that the choice of method now plays a l!lore important

part in dealing with a problem on an automatic machine than was formerly the
caseo

xhe use of library. subroutines grea.tly

B09hiaticatad

problems~

a.ssi~~o

in the use of morc

and eX9anaion of a library is helpfulo

I cannot

illustr~"tive

ca.talogue 9uggested methods o but shall give one or two

'9roblems

and describe how th:£lY ha.ve been tackled o

7.

I shall first consider ways of dealing with solutions of differential

equations

0

First: 909sible needs
I. A

tabul~,~ted

II., A brief

solution at fairly close intervals

sur~'Gy

0

of a solution as :a. whole D or a. need for end-values

only, \"lithout intermediate resul,hs ..
Soma posaiole methods (there are others) hra:
(a) ~unge-Kutta typn~ involvin~ onl~ values at one argume~tJ:o and the

eva.luation of first .deriva.tives f)nly.
small steps 110

These usually need relatively

(b) Methods in"olving (iifferences o or function values u.t severaJ. nelgh-

uouring pointao

'~hese

can be used "lith sma.ll steps p or \'lith medium

steps h SOm6\iha.t lareer than 'are posaiole ,)y Runge-Kl1.tta methods o
(c),l1ethods involving tlerivativ6So

These can often be unetl \,dth very

large steps depending on the radius of convergence of Taylor expan...
sionso

'.I!he diffi.culty here is in the camnutation of

this is o howeverD clearly

~ossible

deri"a',~iveo;

by suitable r~currence formulae

in Ma.V cuses familiar to tr.p,thematicians

u.~d

nhysicists, and canp

by ingenuity, be made p0ssible in a considerable number of other
cases.

Starting the integration is easy in (a) and (0) but may be
(b).

troualeso~e

in

i,arge steps" as a rule, redu'!e 1)ossible trouble from'rounding errorso
I

d.

It is desiraole, as a ruleD to use all interva.l in the calculittion

which shall be equal top or not much smaller thanp the interval of tabula-

tion desired.
(b}D la)o

'.I!hus, generallyv the order ofpreference of method is (C)9

Howe,ver" if (c) is im?ossible or if a small interval is needed in

the fina.l table as in. case I above and (b) is to De used" then (a) may be
used to give the necessa.ry starti:lg valuaso

'l!hus nethods (a) and (b) should

both be proviti.ad in a. library of subroutines.

If cCJ.se II holdseas large an interval as 00s5io10 is desirable" and (0)
should oe ueed if it can be xr.ade to \'Iork.'

It is m0re difficult to coda un

(0)0 as it is much more ~~yenJent on the particular equation to oe solved.
l~ngla.nd.

ltecently in CamJridge I)

':0

L. Albusiny MS

to deal v/ith EomogeneouB Linear Differential
wi th

~uadra'tic

Coefficients o

£~uationB

~oded

u-:) a program

of the Second

Or~er

This covers a. very large num'oer of the func-

tions arising in mathematics and mathematical, physics - too many to list now.

90

''che method used is to ootain from the dlffp.rential equation

p(x)y" +

g(x)y~

+,r(x)y = 0

by differentiating n times, 'a 5-term~teourrence relation between successive
terms T
n

= h n 7(n)In!

are con:uscted by

1Tn +2

(n+l)(n+2)P

Startln~ from y(x ) and y' (x,:»

O
y(x" +h) =

Tl bco·;'~):lI: ~'(xO+h)-=

= -(n+l)(npD+q)hTn+1

J

-

(!n(n-l)pfl +nql+r)h2Tn
4 '

-(i(n-l)q"+rD)h Tn_f,,,rnh T _
n 2
a.t x= XOD we COI!n:)u'te

y(xO) + Tl + T2 + TJ + ---..--

+---

Tl-:2~3 +JT) +4T4

obtaln~ng y ~~d ~I a~ the ne~t P?int e and reneat ,the 9roce~s for the nexr
s te 00

·rhe c1c1e 'for" qomp}ltiItg Tn i~ carrted on t+~til Tn a~d Tn~l ~oth
1 :

vanisho

r

\

n"/l.

'"

10

0

.

rhe progratl is not in strict floating oinary or floatinF, ciecimal fol"iIlo

but has automatic scale changes coded, ~no both binary for
decimal fo~ ~rintingo It is slow in action on individual

com~uting

sto~so

and

but this is

unimportant in view of the sizG of step that is ?ossiblso It has been used
x2
'
to ta.bulate e a t ' interva.l 005 in XjJ. and retained a.bout seven-figure
a.ccuracy to x= 12:tq;l5jat the end ll the function \'las increasing a. million-

Steps needing 50 derivatives were successfully usedo
I have iuc1~entully used this method successfully on desk machines
(~nd machines in fact) ,to tabull,~ta dessel functions at unit inter'1al in x

fold at each stepo

to 25 decimals g needing 20 to 25 termso The resutla will
course in one of the Royal Society ~~thematica.l Tables o
Programs for Comnut~ng Hesidue Indice~
110 1-1y next examole i:i in Number ~hGoI7'o

ap~aar

in due

It is over 300 years old" and

still of interest., It concerns the pl"oblem of finding uresidue-indicesD n
Consider a prime number P,o and a. small integer a (the bas()

to

It is required

find the least number e such that
€I

,,"

,

a =1 ia a multiple of P

This nUDllJer exists (exce'9t v/hen a is a multiole of P) by Jlermat1s'
theorem, which states that. for such an a
aP-1Ql is divisible by Po
''che eX90nant e is obviously not grea.ter than .P-l and it can, be

e

a -1 is a factor of a

that

-10 and hence that P-l is a multiple of 9 0 say

Then (P-l)/a =)) is the residue-index

120

ShO\in

P-l

\,/0

~,
P-l~veo

seelt.

We can confine attention to the case

a~29

and ,consider methods that have

beenuaedo
A simple rellet1tlv(l) method haa been'

~sed

by:l:.ohmer on

E~IIACo

bY' myself

on EDSAC. on SEAC t on MOSAIC and by C. Stranhey on the Elliott 401
,

'.

com~utero

~

(~ al~o coded it for SWAC, ::~nd suggested it in other cases.)

I~ has b~en

used by Gruan~orger on a C~Co
Originally intended as a test problem for comparing sneads (it is
important to emphasize that one· needs several test ~roblems for fair compari-~
SOIl( ; . this problem and metho~ suito some maahines well- others very badly"",
for yet others it is fairly 'neutral.') and one may mention some times.

9-5
The method is basically as follo\;1s.
SU'9Pose

. r i is ImoW1l p \-lheI'e

(1) 2l'i

(i1) 2ri -P
(iii) Test sign

, 'j'
,

~

~~

of-:="

(iv) r i +1 2~:i"~P
( v) Te a t r,! q i.

'. t,

(,.1) N~

~,,'

, ,

.dack,to

_'~ ~

~1 ~11th

r1+i-2rr

-= 1

Ye~.

i+). re1l1aaing i

'

l+i:= e

Q

atco

(vii) Teat l+i<:P'

.f ~

No

Yeo

..,)>---_ _ _ _- - -

l!i1:11u..ve -due to error

0

iJ?est (vii) ma.y perhaps be omi ttad - fa'1iur& is usually clear oecausa of
~,ack of result in an aptiro",?riate time.

One can out short at i(P"",l)

I)

,since 'this must be ! 10

13. , Time is Gvidently basically proportional to 9.. and hence to E.o
ainee
for

t:!

is most of ton 1 or 28 and rarelY. la-zags.

~e ~-l

}'or P= 9000 0 times

ara anproximataly:
19L~9 ENlAC

5 aoc.

19.50

,20 sec.

sNAC

1949 EDSAO
StJAC

l mino
2 ~ oac.

(eotimated)

,7 fr aaco
1953 r.~OSAIO
, 1953 t:401"
4 aeo o
~ interesting values of P only start a.t 100000 so that it
wac: only when the last ons came along that actual production (thero
~e thousandoof values of P to be tried) ao~med ~orth~h11e and this
~aa B~~ in traino Going to ~(P-l)o,for P uP,to 250 0 000 0 the average
timo wag 80-30 seconds; S0cc80 houro production Wa.S runo
'lhasa pro~ammaa ware allfairly,aa.aily made; the laat and
taGtoct of ' them tried involved ,optimum programming and wao·some
troubleD
140

aim at

There iS g howe'Ver o a. completely differant a'Pproa.ah.

That is to

'2l directly:
(a.)
(b)

~muGt

bQ a

~:'levo17~

(P-l)

,

which is also a factor of (P=l) must

,QtJ ' .

~

faotor of

.,..1 s multiple of Po 4-

...« e..

Q.-/

0-

ala~

nlCt(-I'I;k.

0

givQ

f

P

have therafol"e to fsoi;o;t)iz(J 1101&>1 and uliminatc i:t from'

\~o

thoso fa.ctors which are not factoro of

~

Thin ia done by removing

thom ono at a timc o
Thoro arQ comparatively low factol-e of P=l(ordor log P Ol~ less)"
e
'l'ha trial of ooparata factorc ie tho ba.sic cyclso

(1)

(i i.)

'.l'h13 cY'(,Jl~ 1m very conaldarably lot'ger thfJ.n the previous .one 0
tt,nd 1 totJl! il\el\ld.~)n a. ~\.,bcQcycl('f to~ ea.ch b ina.ry digl t of )l-'.,!I..

(111)

It.

;'

b

T:1.m~ 10 ~f1jy\mal]}Y Ind~;p.:''Il1,di:~nt.,o:.t P In l'ant~otJ (Jt: in't"!rllot lOJtc 10
X1i, 1~: pt'oporl:.i.f..Hjal ~o (log(JP)'~ "l,pp7:c('glma,t~;:tYIiI and log P vtt:t'ilQe

:t':roro 11 6 to a.bout. 1203
0

~j 11':: a t ~ nJ.!'h.) l~ \i i nd~T)'! n(t'~lIl t oJ: fi (~1t'.e:00 pt:; tha. t u.~2
~·:.~tH~~i.al1,y ~(Hl~Jd. d.ti H:i.JO\J"i;~ht,1t:$ tb.~ 3~)<.!'j~,tl to~ a.~

(--.r )

150

IT,''!lI't h·.~d

''i:1:d.!:!.

'I n

(Hlt!,' (It

(~r}d.{~,df O'l' '~)W .~~ LL!O:I~ 1,~Ol

of

d

8

ca.n. 'U\1.f
J)

COlhddf.il'"Hbl"" tH:rph l.r~'i'~ IC!a.1~1.{)U and.

hy Dc 1)0 G1111eJl!."

0

r'U),!)

It tOt;."lk atH:nlt· 150

hlgh~~t.lt .·~li:)ad.~:;j ()pth.~wY!l codtn~~o 'l,~,t;h la*fi~."mingl1n~~~;

hOUl"g

o! OOYf:t)"ltlng and

r:rln t.l!I~;Q
·~hf;l.n 'j.J~~~

ol'igln.n..lly

tu \{\oont 10 7tOll..l.~:a
nO\J ~_:j~f..HL.

!ur~hoI"

I)

GODJ11.d.I."1.l"\1H1 po~~)lbl~

and.

'.rh1.t+ glV'ol.t

;:!-

£I

X'owi~lon of

D:t'a-vloufj

l"unr.

tcd;al pX"o~~t>~~m ~t')'if~:r.i.rlg ]00...,4·00 hou.l"S a.t '~he

YJ.ael.:~l~$

t1tud.y I'athar th£i.7.\ a81

tJ:l'

r.f!H;~:;.~lt~

Ula.t~rin.l

';0 ht'H

t'\~),ga.t'(.l~d. i:'V~

tor' puhlimlt1011o

J" C u.P " H IJ"rJ~li,

da.ta fot'

0

Sinc,c 0 in solving partial differential sCina. t ion.s, a small mesh-size

usually

910\'18 do\-nl

convergence as wall as increasing the computa.tion 'Per

iterution, Do Lo Shell reports that GoEo has experimented with extrapolation through several mesh sizes and \·11 th a. fixed number of i terationso
The final number was generally more satisfactory.

use of very high differences is recoml1leded by Miller as one approacho
He has gone to higher than 20th differences.

l-iachin.es cannot usu~lly use

all the tricks which an experienced human computer can apolyo out the machine

does not usually get into the same kind of messes that a human computer can
get into.
In reply to a question by Arden, Miller admitted that relatively few
large-step problems have been done.

Highly non-linear nroblema ar's of

course espeeially intractable.
A solution at only J points that agreed nicely with a more elaborate
computation

\'JSS

reported by

~hell.

but Arden a.nd Miller felt that thi.s.

WllS

an unusual case, especially since J points cannot yield high-order
differences.
Ii

0

Co C&..rtar made the point tha.t often when a fe\"/ pointo are suffi-

cient, a good analytical a9proximation can also be found.

Miller brought

out the OOB$ibility of polynomial approximations as being frequently
prac t,ical

0

L. Rosenth.o.l commented that compari,aons of solutions obtainod by

several methods may be a practical way of ,getting results, but that no
study seems to have been made of any org- the session adjournedo

file No v ...~ ~3
I""'"c..cc/ IN c...{c.(
Hc.c-.--n ;11

N
_ ()

.

\ '":)"1
.

-

C"~\\V\ cc,\.~

,r;)'r-3""'1\'H"o"'H\

")\~c..~t-~,

-

~Y..~.l

r. . . ~\~\ . . ~

10-1
cUe &....- ~< ''''1107 0Vv
100 The Effectiveness ot Automatic Coding.Systems Currently in Us~
-rTf/;11 <.
.

(-on .....

rc/ r~c..t 'S.. ,L-t® l{} t?~lv CAc\.,..

Q. ,,'

The design ot ari auto~tic coding system itself presents a formidable
task'
programming and codlngp and the completed s.yst~m represents a
, I
considerable capital investmento It is therefore of some importance to
waigh carefully the advantages to be gained from such a s,ystem before
embarking upon its formation. There is little doubt that the majority
of existing systems 'have proved, or at least will prove, to be well worth
the coding effort that went into them. On the other hand this has not
been true of all the systems. ,This sho~t note is intended simply to
stimulate a discussion of the lessons that have so far been learnt from
practical experience, so that we may avoid the pitfalls in future and concentr~te on those features that appear to orrer the greatest rewardo
The design of an automatic coding system differs ftom other programming
tasks in one important respect. The success of most programs may be judged
objectivelyp from such things as the freedom from error and the machine time
requi~edo These factors enter into an automatic coding system alsop but in
this c~se the ultimate test is a subjective one: is the system useful to the
people f'or, whom it is intended? The designer must therefore be .not only
something at a roathemeticlan but also something of a psychologist9 and his
success cam.'ot be judged from a few machine ·t,~sts but only after t.he system
has been used by several people over a period of somo months o
Here are ~ome of the questions that can only be answered on the basis
of experience:
How long doe~ it take a coder to become familiar with the pseudo-code?
How important is the provision of exhaustive mistake diagnostic facilIties?
How easy is it to design a system so that ,future additions may be made
without arfectingth\~ coder 'Who does not wish to use them?
How important is a convenient notation It co,mpared vith the provis ion or
more fundamental things such as symbolic addresses?
How usetul. is a mrl~embnic notation?

of

--

~>:

If

>:'

"")

:J

"",

.\

<"
"

:-''"........
I,

:""
!

.."

I

I

,I~
-'.

-

')

\".

'J

-.-.(

"

-\

()

-;."

~,

",',
")

~"")

~I)

c." '"

~~

'
j

(')

I

t

The LMO Edit Oompiler
Introduction

~e

a routine vihich el.i.i t's raw data. tapa~ 'into a~
form. ,The process oi, editing a unit of raw data is reduced to making uu the
forma.t of the ~ prin~ed. page U~ing' Uniprlnte~ symbois and s?e'cifying bl"
}MO l!idi t Compiler
,

i~

,

.

t

nps eudoinstruct1ons" which digits of the r~w data are to oe transferred to
wh.ich -posi tiona in the page forma.t, called the "matrix."
lrom the pseudoinstructions.
the J.d.l0 Edit Oompiler forms
a set of
..
.
.

instruc,tions which will edit;:as many units of the ,~aw data :as d~,aired.
This set of instructions is ~alled the "rUnning i~~tructione,'tsince it is
read consecutively a block at a tine. It and the matrix are then used for
the actual editing of the raw datao
'l!his. a.rrangement saves 'pro~m1ng time since traking U"9 ps'eudoinstructions
is a relatively sim'Ple process compared to coding '0-10 UniVac inatructio:ns.
..
.
It also minimizes bugshooting time.~lrrors are easily detected.' either 'through
the self-checking features of the routine', or 0,:/ a. quick glanC~ at the ~u''OUt,
.

and it is a simple matter to make the.'needed correotions in the pseudoinstructions.
The

Matri:sa

lIbe tirst step in the use ot the ~dit Compiler is to decide what the
priated page is 'to look likB Bnd to ~ake
the matrix with this in mind.
1~ matrix will consist of 600 or fewer Univac words containing:
1. ~he title and other words to De printed on every pageo

up

20 ,:,'fhe commands to the. Uniprinter,
suoh as carriage returns. tabs,
,
'.

"

shifts. ignores. sJlaces, etc.

(It is usually a good idea to begin
each page with a printer breakpoint followed D7 a carriage return
so that manual a.dj~8tments can be miwe Defore the printing oegius.)

3. Places for the words and digits from the raw data tO'be inserted o
There are a number of oonsideratioDS gov~rQing the choice of these
Dholes in the matrix, two of which are: ".,'
(a)

Since oDC98eudolnstructio~affects Just one mat~ix word, it
1s usually wise to restrict a hole ~n the matrix to a single
matr!X wordo

(b)

.f

If a decimal point is desired, it should be put in the matrix
in the correc~ positiono

10-3
,40

J~he

\'/ord "Pa.ge" followed by a spa.ce and a. f'our-aonsecutive-digit

~lace for t~ number

pages are to

5.

in

the appro 'Jrlata place in the 1!!a.trix if' the

n~~eredo

Own sgecial subroutines which are to be used.

.i.~ese

shoul,l, be made

up at this time in accordance, \'1i th the sa·c'tion J-latrix Subroutines.
Nota:

The matr-l,x should be

t~oroughly

checked before the pseudoinstruc..

tions are ma.de u!>. so that errors discoyered in ~ha ma.trix will
not necessitate changes in the -pseudoinstructions.
~e PBeudoinstruotion~

::After the matrix has :oeen made upo'the next step is' tosOecify i)Y
pseudoinstructions the digits \'lith which the "holes" in the ma.trix are to
be filled.
Writing thepseudoinstructions is simply u::mat,tGr of: transla.ting the
wiohes ot the pragrammer int~ the ,forms described below a.nd 'Putting the.m
down on paper. ~he General Pseudoinstruction speoifies the word and digits
,

\

of the raw data. in the lef.t half I and the word a.nd digit location in the
matrix in the, right' b.a.lf'. :: Certa.in other: types of '9seudoinstructions are
used to permit the routlne'greater flexibility.

'!G2. GeneralPseudoinstruqtion is represented

by XnLLDD Qllldd. which

says, IITake n digits, beginning with digit DD, in word LL ottha block
being edl ted. aot on them with suoroutine Q, and.~ "OUt them in line 111. ot

ane

the matriX. beginning \'I1th dig! t dd. fI
block of raw data' at a. time
is edi ted and. changed by the indica.tor "xn. whioh sa.ys either nRead in

next block of ~w data It • o~ liDo no't redia 0 de·'lending on whether X 18
R or 0 (zero).·'
,.
J ... • "
''ROl
I
1"1:), ':
\
•
" p~ NOI. Arif ,~ t:fL h\O- I · a:t-'-'fe-r ~\AlI.~\\'\~
.!fOnD of Instructions
';.
. ,
:
"

1 \:.,

. The pseudoinstruct1ons can be introduced into the UJIVAO manual17

(Brea.kpoi:lt 6) or by the use of a' control tapa (Servo No. J).' b

instruction

word is of the form

UXYYYi11Cnn
~ is the first word location ot an Itec to be modified or copied
l!! ·ls the last word location 'of an item to be modified or copied
i11 is the location of tho one'word in an item which is to be
modified. ~ote the control letters D and Eo . ,
ll!! 1s the number of ~1mes an 'i tem is to !Je copied or modifi'ed
,j!
,iethe oontrol letter. it ca.n be:
(A) This will copy an item on the" out"put ta-pe un times in
succession. iii is not used in this instruction.
,

,

10-4
(~)

(C)

(D)
(E)

~his

will add ·a oonstant to each ~ord in an item and oOPY
the altereditew nn times on the outnut ta~. ~: The
word following a B, a. D, or E, command must be the oonstant which is to be added or ac~umulated. i1i is not
used in this instruction.
Thi e will t ..r.ansfer an i tam to the output tape un times.
adding aommulated constant to a.ll words eaoh time. 111
is not used in this instruotion.
This will add a constant to iii and copy the item nn
times on output tape.
~his \·,111 transfer an 1 tern to the out~t ta.pe un times,
adding anacoumulated constant to 111 each time.

J n· ,~j

storu~e

necd.ed-·-i s i'G

J:H:l.chine u only l) e ~c?

Ollt~)ut of:~

One aO!1ee·t:

.dei'initionD

S lO~'1

l'()).'

mo.1:; i:er of

p.

l!ul:"ther c:larifJ.ca tion of thG cl.efi.."

of the Affil

~iscussi0n

he

eOi.11:)11er is a. s,~qlle""lf!e of in8l;ru.c:l;:lon~';'1

not numerical resul t.n (by flD ~'t. Hun i;u r).~
nitian deferrci until the

Seem~.l 'liO

g10nsary~

.QQ.IL~5 b~\i ~!~t~li tell .H.ircrc:.\f~~

•

:::;ue~.~c.1.vo

ha.s been used at Uni ted. ,H,ircraft

01 a:)out 100 " ou tsi~)int s ..

.l.lolative aid.ressing Is

C1.ttr:l.(~·~

Admi tte(lly 1;l)is system is not as

uS8cL

ti ve as floa.ting add!."8sssi..ng but in vielt/ of the nmall nmnbcr of words of
storage iJ,vailable to the programmor ~ it

.:J.me:::J.l"S

to be an adeqaa.1:;'3 meH.ns of

avoitiing the qi. tfall s of using ubs("/lute ad.dl'S sse s
'£tle opera.tion cr)lles

peurs to be

\..J.

11')\'1

V'e~\dinf:,

;J.ny

i!hcili ty

sort of
\'/as

f10atin{~

provided for complete tracing of the
(}:':~}Ul{S

lEhe

code c::>mnrisos seven J-address instruGtions: ad.d o subtract;>

inout-output v take

Cl

basiB ..

or regh.:1nal addre~3s1ng or

coded ooerations as they are executed by the machine o

stop~

ca.su~l

inGtrnction

multipl~'t1

d:l'ri(lc~f)

functiollo

'.rho system has worked succesofully for its intended

1)ll.rpOSeo

HOW8VCI"11

peo ~le tl'ied to use it for -oroblcms much largel' thb.·n it wan ,designed for and
naturally found it too r:igid to be convenient;...

It is

nO\1

used for about lO>~

of ou!.' iJrodl1-c t Ion ~ <>

rIo

fu::}~SJ1\1 (Originn.tecl at IJOS l~la,mos)
~his

is a ninele a.d.d.re~s IJ floatint; df~cimal illterpre Live 1":->utine ';/i th t..."

'..J~rd stru~'.ture icientlGal to that of the basic: T'1~chin8 (701)c.
conv(~niont

lnothoJ.. of nwit,ehillt:: (;ontrol buck

"a:)str,tct 'l

ma.chine3~

:i. .,(~:., {~oinG HI and. OU"!"o

i.1.!ld

It p]:ovidon

forth betwQen the. real and.

t:i.

l{elu;~ive

udllressing is use.t in

pra.cti~ally

The pz'c-cxecuti::>n assembly t'echniques
a~)plic~1ble

here"

~eas(J.\", Inter~)re1ie.c

lw.).! of \oJhich are relluireil fot'

1;racin~o

codinr~ ffJl"

:hlG uystemo

for straight r.1,tchine cod~ are also

uSt:"Hi

uses

all the

a~out l~')O

701 h.:t.lf-words(I about

.

l.lrovisions ate made for ai ther continuous or selective tru.cinr; of
ex.ecution o 'dhich 9 tObe thor wi th l)ost-r.ortcm

atora~e ~)rir.~touts

D

')r()~:ram

cons ti tu to the

mujor r.listake tllagnosis proccclureso
~hc

ari tmlet ical

0

ncra tion code is iuentical to straiGht !"achino c')(ie

f)

mukine for easy use by the rtprofeasional" grou,?o
J.'his system is nmt '-1sed for aoout 75'~ of our r)roductiono
~ect

I10wBver wo ex....

that the advent of a ouilt-in floating point machine \'1111 pra~tit~:(J.l1y

obviate the need for this type of systemo
COmmeT\t.9 ox ,l~o ~t) 'ioo..rheesn

Los .Al.aIrtOSg

'I'he fir£;t 701 interuretive systel11 develooed at L'}s A1rlDos was ealled
SlL\.COo

It

\iUS

essentia.lly a simulation of a CP~1 on a 7()lo

"1rirnari ly to m()llify and coddle the
C?~IS at Los Hln.iTios o

6

using t.he

hUl.. d ..... to-hire

'~his

was d:.)ne

physicists who were used to

;)tL~CO Has ')retty ITluch a floil: thH nhy~iclst3

. by... ~a.sm~d it for at l:-~:1.st 90',~ of their coding!) r)referring to use machino {~()(i(;l

even \',ith the attendant

scale~.:>factol"ing

liifficnlties D and no',,,, S!iaCu

i~~

not

used at all"
SH.a,0U

\-I.:..\.8

sloi:ouc~3ach

t:)O

in tor i)t"8 t i w! ins Lruct i :)n

for checking fJUrpoSea --the s)eE.Hi factor

Ano thel'

s~n:) ter'1

l)dirlf~~ db~ut

.uU,iw.,. 0 has aeon :lc!'·udo)od...

mum of 23,; hIl~L hus nO\v lev(~l~Hl off to ab~ut
~J.l."O:Jli:~I\!S

unscala.ble

the

IH-OtF.~
llU.A~

and.

fOl"

\'Ji.i,S d,~ne

I ts use .i ncJ."0. a~3('o;~l to

15:'t

one-shot o liLzy-c:')(le(i

-t(.l,nd(~!1J'

40 to 10

It

iB

UG8d,

rOlltines..

£\ fila,XI~·

for tlift'icIJlt.:o
i)U.ll~ ;]m:)r.lr..l',~~,".t~::i

feature found. so useful in ottwr interTJretivesystemso
co(iing is not

mnelllO~licD

so thnt codin.:'; is not fast; in fact;! nn

exoert scaler seems to co so that i

not 8uitaale atp:l.'2Sent..

directly into

illstru~ti()n

!1'ter~reti ve

techniques are

Instea.d "Ie: '.1.so translation routines which translate

coding ou a 1 to ).

cOI·l·es·oo~ldencc

basis,).ehe coder

uses~

l·[nennnic opel"~.tion sym!Jolr::;
3adcll'e~,s

instructions
bin:ll~Y'

IhhnboI's llre "/ri tten in standardized d.ecimal notation lncluding any

scala

l1um:lers l:!ay be tr, .. nsl.::tt~~d. to equivalent binary or into stanrl.ardized

factor"

floating bini.t.!'Yo

Thel'e is also Pl"ovision for inserting \'/ords in purl3 binaryo

o.'~L~S...;'f.l ~..,.re,:~ m~l.lt~,;,· fl'etl lJ[J.,P4~:~\

.f.\:Jth

~u.pe

via l!'erranti inDut o

The oUtl)ut of

'the' tr' .~lOlator is a:ounched nanar ta'rJe x·ea{ly for insp.rtioTl for normtl.l com!?u.·",

tatir>fA"
·j~:).e

tramilation routil.na iH designed to parmi t nrograrYJmers t~ carie-: using

,rul1~!1i.!cbi!w

(~a~\'~~:Jilitie~lo

;.rhey may .f:l.lso USf.) 11

i,·uui:.;.I.lef) 'v/hich. i~1 not..; ,:l.vaJ,la.ble ().lltollw.tic'al.lyo

fl~x~~'tin{;

'ooin'l; intel'pl'etive

Ij~h:i,s routine f}9l"'mitn IH"".OUT

thost'~

Plans for fublX'e exu:,:.nsion no" L1 for i'l'tegruttnn nf IniVl,i of
t).;':;

ted

~,ntc~Ii'W

'~I""O ,(l/ll.l

:~Oln')llti:d;ion.,

sys t(UJl cnlh;d. l·iil.l1 Ie 9 l.,;iichJ.f.,~('v/! j\"lJ:tomn. 't ic G;:.:neral In'cegru",-,

~1Al~IC

fn:: t(~ ;~3 t vc; aU'(;')T;lOni i;\)!"

fncil:1.··"

in(~l\lde

vrill

faclI i

an extens:lvr: i;ransJ..':d;';)l'

/J..IHt

n:)'mnilezo ll and

til! Go

Ttw;;[\S 1:'0~; eolU patel' h.a.s been tlevr;; 10 lmd for nSE: during the l"ji chigan SU,H\mc:r.

courso on. Digj.'tal GornputGrso
eomnnter

fe;J.t\ll·il'l,~;

i!ASLAC

i~~

a.

com~)l(.!tnly int(~r')!'etive

J

addre~s

floating point o.1"i tmetic!) mnemanic ins tr'!lr.!tion co(ie 0 sym ....

bollc addresses a al'ph:l""decimal inputo

It has 7 base countt-'!l:s avail,able..

take di:l.,':.;nosin fac.ili ties are adequate but not elabora.te

ni80.:>

0

~gr~2f!}~t~3 bi[~!~EQ\tJe~..E~ck and ~l~ lCQx Q.,~:
.it

compiler anci assemble:f similur to one developed for a 701 by Gen.eral

j~leci;.t"iGJ

s Stoar.l 'i'urDine G'roup at Lynn o Hass o

and liil.:'i:)Au

'ilhe ob.ject is to

l't~lieve

0

is bein{: devGlopcd by .i3abcock

all engineers of codingo

nDOX' .it> asked to do is to' fill out one or more of several fonns.

ol1e f:lrm is usc:d for a '''fube ilunk
vii ttl infol'watio!l '.d-:.ich he w}uld
o\'l'9110s
forms) used. by Keller o

'rhis t'-"chnique

1~'\

described in the cOWl of tho Washcg

int:;ton Navy l·leetin.g in Hayo 1954 (see)3ibliography ref n 01)
rlamshaVl
9ynth(~size

p

?~,wall

a nesigno

0

and Shell discussed l'0ssibilities of ha.vine a oomputer

Shell made the point that one difficult as-1ect is finding

out just what t:lOught l)rOCeSn8S go on in the engineer 8 s mInd when he designs
unythint';o

There seemed to be general agreement that o:ttracting this i!lforma an

tion i'r()m th€-; engineer Tr.U.Y oe nearly as ,1 If'fieul t as i t

",/~)uld

be emba.rassing o

13 - 1
I,'

10

iJo

or Laning and··Zierier

The Algebraic Coding System

Introc}uction
'. .' :
.
. The Autonmtic Coding System to be describ~d t'las devalbped in
,i

.

;

.

,

1952

and 1953 by J. H" Laning and H. Zier1er of the H. I. T. Instrumentation
Laboratory

The trnnslation nnd interpretation of the algebraic coding

0

is realized. in the H.I. T. ~aJh1r1t-lind Computer

0

The ceder specifics his problem as a series of r.l3thei1:.:ticu1 equations

ond.othor special

~bols.

From this

~nuscript

l.zhiah constitutes tho input to the computer.

a Flexo tape is punched g

'!he Flexo char3cters are

tran~lf1ted into Hhirlwind instructions v1hich are then carried out.

The

. results requested by the' programmer are presented in typet·1rltten form ..
All arithraotic operations arc carrioci out in floating point using a socalled (240 6) system. Nurabers ~Ilay range up to 1019 Hith a precision·o£
about? 02 dociJml digits o
no

Basic Operations.
All of the ·lolZor case letters may be used as varinbles p and

cqucr~ions
"-

of the roUoHing fom aro used.
a&:So

ye: -6.3a.,
b S Oo0053(a- y)/2ayo

n= n+ 20

xS: a(b+ c(d- e» D
zc r+ 25ft + U o
A comma terminates all equations. Plus and minus signso slashes and
parenthcses p have their usual ::lathe':13tiaal sir,nificl.lnoe o No more than 4
parentheses may be open at n~y one time Plus and minus siens scparnte
terms so tho t the last equation 0 bove is the same as
Z·~ r+ (2s/t) + U v
EXJ)onent§: Upper cnse rm"bcrs on the HIT Flcxo'pritcrs appcnr as exponents; there is also Gn upper case minus sign g but no' upper case plus
0

The
a g: 5 2 0

signo

roll~'ling

. b S ('n co 2)-2 n
.,
C5:(a-J-b)2/ -'3
a o

are interpreted correctly.

ImusJ

b
'\Y\-r"Cr''jc
\ ....··-~
c...

I

I

III.

OutPUt

.

.

.

. . 13 ~,2

.

:.. :
!The current
1,dlue of ~hy
nurnb~~
iettc~ . ~rkbie~
ma~' be ~~co~~
j,
i·
' . ' !'
',',
:
•
in Fiexo bodb on r~gnctic fnpe for loter printing by insorting tho HOrd
PRINT rOlict-lad by the desired letters, folloHed by 0 period. 'The first
i ' .
!"
ond lust chnroctersrccordcd by each PRINT iIlDtruction are carriage returns.

br

,

,

I

j .

IV.

,

j

.

,

I

Jump InstructioD§

Equations are ordinarily earried out in the' 'sequence in which they
are w~itten. This sequen~e may be interrupted qy inserting one of four
ju:np instructions. 'l'te address section of a jU71LJ. i~struction must be an
integer less than 100. 'I'his integer 1s the number of the equation to l'lhich
the jUr:lP is to be r.mde. ··n· equ~l".ion is ml:"lbcredby preceding it by its
number, eog. g 15xt= Jae assigns the numbor 15 to the ~quat1on x ill 3ao .
The instruction SP 150 inserted in a routine 'nill causo equation 15
to be executed ncxt v the normal sequenco continuine from that nevI pOint.
'lhe instruction SR 15 cnuses equ3tion 15 to be executed next 0 but
then control returns to the~ oquationfollotd.ng the SR 1.5.. ~;R evidently
I)

implies that Do closed subroutine is to be e~:ecuted.
The instructions CP ond CR are obeyed only i f tho quuntity r;tost
recently computed was negative; otherlo1ise they are ignoredo
Vo

Function Subroutines

23 Function :.:iubroutincs are n01-1

~:!vnilable

in the Lnninf,-Zicrlcr system.

Eoch is assiened a number (1- 23) and is called for by 'Hriting the proper

nunbcr

tho exponent of on upper case F.
X-= 2(pJ.(y)p2(Z) + pll(Z» e
[IS

For cxor.1ple:

=

sets x 2( -ry -s~ Z + \ z i ) 0 since
Subroutine 1 is the square rooto 2 is the sine, and number 11 is D subroutine 't-1hich produces the magnitude of the indicated argument. Other
subroutines inclt:de inverse trigonometric functions, exponentials and
hyperbolic functions, logs to the base 10,
VI.

20

and

Co

etc o

~'idditionn1

variable and variable Wdicls
Subscripts are not avni1able on the Ii:IT FlexOt·~itorso

x4

Numerical sub-

3 for "). etc. Variable subscripts are

SCrlpts are obtained by ty-"ing
obtained by using letters after the vertical bar, e.g., x/n is typod tor

~8 and

if' n huppens

to equal 30 x/n is equivalent to x/'J

0

13 - 3
Vil o

Auxiliary Storage

ts room ~ the ';fuirl~o1ind h:l..r,hcaspeed storage f or a bout 250

Thora

Additional values p such

var:lables o

\',rhirlt-1ind auxiliarY mar-netic drum o

purpose

tables p rrnist be nssifjned to the

DB

The 'Wo~

ASSIGN 1.s used for this

For examplov the instruction,

0

ASSIGN

0/ 4

3uton13 tically resorves space on the drum for vnrioblcs all through

3/ 4 ~

1~1I

6 v 8, rospectivclyv they may be
asair-ned these values .£!lS! have space reserved br them on the drum by "C-lritIf these variablos have the values 2,

ing only
a/N C 2 o 40 6,j 8
Further, the same t,hing can be accomplished by Hriting
a/N a:: 2(2)8 p

A more complicated example might be
gIN i : l( oS)2( 025)2.5(1)4-.5"
VIII

Differential BguatiQillt

0

Provision has been made for tho automatic solution of ordinary differential equations using Gills' variation of the 4th order Runge-Kutta
Hothod

0

10
20

3q

p'~lrpose

For this

the letter t must be used for the independent variable o

h must be used for the increment in to
D must be used to denote d/dt,

40 Any other variables :J.nd/ or superscript vnriables may be used for
the· dependent and auxiliary variables
0

Suppose

ft

have the

'He

(to Ylo Y2)

I:

t'HO

equations

Y2 + 1

~.(t.Yl· Y2)=-Yl
let t

=2( 0.5)10g

that is, hI: 0.5,

Our program might be:

t= 20

h=Oo5p.
yi1o: 0 0

. yA 2 a:: °

nyJ

0,

'

1 c:yf2+ 10
1
- DyJ2::_y l o

J

k=t-1Qol

CP 1
STOP

13 -

4

t is 31:ltomatically increased by hupon copiplotion of the last equation
~~h':lt st~rtfJ lolith Do ' One i!:1iJOrta~~~ riestrihtio~ is that all relevant nUx-

~liary

IX

conbutation must

b~

done

bat't-1E~en

the first and lost D

ec~uations.

Po~t-Hortem~

0

Automatic POst-Iilorte:l features arc still in the design stageo
no~,:

Features

available include:
1.

If tho program is tJo long the computer stops nnd

atien indicating Hherc nnd hotol storage
2.

If an alarm occuro the,

~c:uation

~'Jas

COi~lputcr

tY~.ies

out infOr:l-

exceeded o

prints, out the number of tho

in l1hich the alarm occurcd and the nUlber of the equation l'lhich

precedod the nlora-l o

(gquutions not assirned nu:nbers by the progro:-Ill:lor

are 3: 1tOftctically assigned nU'1bers from 101 to 200)

'J.he proera:-'uncr:"lny obtain the values of aoy variables he desires

30

aftcr an alarm by Hriting the appropriate f'RDlT instruction as equation lOOp

Xo

Conclusion
The system described is a t·10rk:i.nr, s:·lst.em and has been used by the

Instrumentation Lnbortltory to solva several complex problems.
involved

3

set of sbr simultaneous differential equations.

One problem

'lhe equations

involved extrcncly complicated al' ebroic and trigonail0tric calculationso
Codinr

re~uircd

til]c o

Co. ~putine time

only o· fet'1 hours and the routine ran successfully the first
l13S

about six to eight tines as long as it L'lould have

been using the sincle-address interpretive system ordinarily used at the

Dieital Com>uter Loboratoryo
Huch t'lork remains to be done on the systOr.1 porticulcrly lJith repect

to increasing

tb:~

COrtLJutiilg spoed and irr1l)rovinp. post-'lortem facilities.

Heretofore there has been ver,y little need for elaborate

post-~ortem

facilities, becausc o lo1ith a single exception; .'311 !Jroerams coded in the

Lnni.ne-Zierler system have bcen completed successfully on their first run.

13,·)

KQv'..

Pou~ll

~.l::l).al

in the

t.1H;ri~ i11

usl:cc1 Hhy i'lll.lctlons ouch

for.m

simple

:tn1:ri~j~w.cJ.

ca:.1CH

in some C!aseBc

[1S

cOfJlne

of' 'iJ..siug th.u lot,tc:n:' F u

th:ts uould b8 pOi)si.blc i.1 but

}

Her,::

no"Jj '1:!ritt..2L\

;onn CombGl:1(:! :;::!'l:i.d

tJ:H~ro fl~·1.gh-t

t.:;

Proi\' Adams said that Laning and ZierleT Hare

adding inganulties uhen they reached thls pointe
out that the simple standard notat.ion

u~led

uas

!J2lU[}:l

'~il'~;c1

\)f'

H.,Fu Hunter pointed

mOTEl

roaclj.J.y extended

to include further f\mctioIlSo
vI QA. Harnshaw asked HhethcI' illlpl ici t equations could be handlod

Prof
DQ

Q

Adams said that such equations requiring iteration must bo avo:ldocL

0

COlilb~11c

expla ined that in Laning and Zierler a~l system all Dquatioll

of the form y

N

r(y) caused y to be replaced by the funotion value"

Then ensu.ed a discussion on tha usc of indices :> multiple

inc1ic8~~ 1>
11rn~i:tec1

and indices of' indices (,' Donn Combr:llic aaid that the notation :is
by the

capabilit~es

of tho Flexol..,,-ritel"l) qJlt .that· all

the~e

can bel handled

D.Nl Arden pointed out that the effect of lnultlple
indices Can be achie\)'ed by multiplicatic10 and addi t.iOkl to for-ill a sinele
In some fashion..

indexo

Dro Hiller asked uhather an indox mu.st be an exact irltcgez';

Combelic replied 'that indices are rounded off to tho nearest int,!)ger :.,

and that this is useful lvhen one ha s to inter'polate ()
Hunter, he said that

int,erpo:~ati.ol1

Reply ing

"(,0

H.Ji'

QI

must be progi:'BmrrJ)d by t.he USQ!' '"

J H~ Backus emphasised that the rounding off of itidices 1.5
0

doni~

Cl.uxing

execution, not dUl'il:.g ·iih.e Teading of tho program",

Backus stat.ed that equatiol1s are stored il1di vidually on the drul':1
in CS form.
100~

If post mortem prillt

requir~ll1ents

are \·n:·:ttten as oquation

it is mOl'ely n'8cesssry to call this equElt10n \,;hen the pro.gl'Gla

dies ~

Donn

Combeli(~

said that post

mOl'tal11s V91"Y T ..,:.•rely

hf:ld baGn

He(~""

essaryo
Concerning the system as a Hhole p Combelj.',
( ol~CI,.c.lo~d )

/W1 ~pt)r+a\'\t011

SI"cl/!.

5t:?

,:.~o'J <'~IJ (. G

'u

I"

I'\UI\~ b·c.~ ~

t~ ~~" J, "~1d
0

f' r a.,3 e..

IJ:al:e subsequent modif'icat:ton by

..

:~:.:. E':.S!9:.~ r.lentioned that use

SO!i1£:Jone

of an

of: !\?;quiring the use of.. stand(lrd

o"thoi· tholl the author difficul"ti o

algebl"aic psoudocode had the odvnn"cage

ilot;;:r~iiono

. E" Vool'h€H3S emoho.aized
that
~'-=~~~.n"lll.~

"tho usor should· be allovled to :Lm:pl"ove ·the sub:i:ou'b:tne and ~ll!. m.ontioned

SUbl"'Outinas were c:!.rculated SlllOng

ti!l1:rt IIDSACu s

sJ~afr

In order to en·-

cOllI'age commen"li 0

C Ada.ms ta:vol~d tho development of SUbl'>Otl":;~lnes 011.1y as the
CI

~~M"~'"

l1eod fo']! them occm:.'red as i"li

t'ltlS d:l":rricuJ:~

mcdi:1.cal routines \'JiJJ. be needod

o.€!mand

fOI·

input-output and

G

to Pl"Cl11ci; just \'Iha-t mathe ....

Subroutin~s

0.1":1. -iihrootic

i.'11"i"hten b:t" users of ,:hirl""

routines is usually

predic'~abl0

up to a pOinto .

OW3"'COIru3~~

expense by a sldlled

:i.n u l:lhraryo

IIa'level-~

!>r~crrnm.m.or

in n form stti'i;nble for inolusion

development or a certnin type of subroutine can

also be usod to stir.lU..la'to muc.h:Lne use in that

~ao

\'10 Rr..unshm:l I:'Mti oneit that getting !tid of old subrout"lllos is a

. . . . .l.~QIICI.~II.~

pl'oblemo . :r e,CoP 0 M::tlJ.er sat d ';;hat j.n a forthcoming lj.br'drY dosoription
_.ICIIM~~~:r.:.z.~~

(;t

Ccmbridge 9 the 6ubl"'Outines wouJ.d bo l:tsted as cUlT?nij 011 obsole;:<·cent 0

:ao

also advocated that deficicnc:I.es in a library be l"lenmd:1ed by an

'.i,lho

\~~ould

eA~l.vt

fill ne rna.ny gaps aD poss:!.blc:'l rather 'iihun 'by a p:rogro.m1'J9l'"

D~,
"~'l

,.:.1'

Cornbelie ad.1tIsod
I'.I,."",~,.' ! • •:~,~ ....... .:. ~~ ...

lc~ap:lng tJ. tr.u,:\·i;

"le:r.'s2.on ano. a

s.h('jl"·~

vex'siDn

'il~

....

01' SOnl3

subroutines o

qu:trGll subroutines l) it \'laS found thr.d; Dona :progrom.mel~S used "Ghe com·..

piler

J~(')

i.1rite the

subroutinaf~:

ond tlol:'l"iod very li ttlo abou·t the penal

J 0 Eacl{us advoca·ted letting

_.CbIZ"'~"~

cu

prOgl'aml"l101·

fIll in

SOITl!)

parts of

:SUbIoutij.nes which are subject ""yo considerable vUl:"iation in individual
p"Iaai'erence 0

In response a question about 'hhe
VlI'i ttan

by compilers and genel'Uted o ~o

included

leng~h

descl~iptio.i1S

l.!W.~!: said

autorratically

thut they usuall.y

Wld temporary storage raquirsd but no'!; the operating

,time 0

The notion of tempol'Ury si;orage was clarifj.ed by a short

discussion o
Co Adams advocated that "unso,t'1 values of' parameters by tho

ones most commonly used o

.",

-

.

I

.......-

16,-,],
I
f'
.H.
~o

J)0

•

lSCUSS~on

l-1ro J o ,H.., Belford opened the discussion by giving some facts about t~he
Iil~f

70 l1-0

s~eed m~~mory

Tr.: ..nsi'ers bp.t\'/sen the drum flnd the high

will "be a.t

10\)000 It/ords per second as against ·100 in the Ilil-I 7010' l!'lonting point ul-'ith...
metic will be built in D and there will be a means of uutoI!latically e.nd ranidly
searohing a table in the st()re to find

<.l.

given

arg~~nt

Answeri~g Donn ComJelic o John

index registereo

nackUs

It

'.l!hcre will. oe three

stated thut the reason

for not having mQre ·than three was tha. t no room could .)e fllund for more; a.

point of diminishing returns 'Nas .reached o
o~inion

l-1r. \1/ .. 1\. .. Hamshalll t'lx!ll"9ssed the

that three was much too few ..

. S·lro '.f ..

M.. Hurewitz said th:1.t in the· ciovelopmont of the .dISI-1AC at HOA,

the need for feedback of informa'l;ion from the urogrammers to the engineors
J.JOll~

appeal' '''10

0om;)elic asked how many

the eneineers; Hurewitz renlied
ence bet\'wen
. date

pro~rammers

tt~t

i~'3as

I

I/Jere rejected by

no idean were rejected without confer-

c\nd engineers.

to d.iscuss the actual designG

~rogrammers

Unfortunatoly he

~'as

unable at this

There ensued a heated . ·~iscussion on the

ethics 01' industrial secrecyo
Grace Hopper raised the )ossibili ty of using seV'era.l small com,?uters

j)ro

in

~)(j,ru.llalo

'.ehe greatest demand \'/as for small rr.achines I and she hoped that

eelch university would. eventually h.:.i.ve one,.

'~he

size of u. big muchine was d.ue

to the numoer' of operations it qerfornedi this could be provided by a.utomatio

coding.

She foresaw a mass produced small machine, deliveretl. with a comuiler

and library 111")Qro,?riate to the customer's needso
Mro J. 'do ilaokus disagreed with th:ts philosonhy on the gounds of
'in~reased

ting s,!>eed; since

com:>u....

sueed costs little more e a. large comouter ie

oheaper to use than ri. sma.ll oneo

Suoh things as floatln~ noint roquire ra.-pid

ilro Hopper ex,?lained th:.l.t nho '.>las thinking mainly of 'business

comnutingo

rather than scientific ap91icationsll ami of machine's costing less than $50DOOOo
Nro Go I!

0

.

~ieynoltls

o'Jinted out thu·t the use of floating 1)()int could

a1voided ::Jy hc1.ving long registers with the .~oint :in

of~en

'be

the Middle..

lira HO~1ar

agreed that the costs of facilities would have to be b~lanced.

Nro llackus

sa.id thil. t i t

\'Ill.S

not the extra facili ties that r.m.de a 'oig machine choe.per to

run 0 out merely the

highe~

times us fast as the CPC
!-iro Go Go

o~

soeedo

Nven using Snaedcode" the IBM 701 wa.s 10

one jobo

:I!'ostel· describecrations are

I!1~de

of u number of small

uni ts; the.secan each be made to corres (lond' to CJJ.,miaro-lnstruction'l> and
bigge; instructions can result from'the execution' of a 'microprogram

°

0

Such

a schemeD using a microprogram Of256'~lcl~-instructions, will be used in the
new'machin~ at Oumbridg~ University.
One might ~lrrange to Je able to change
the micropr~gram for different aU9lications. and even to ~rogram this change.
J)onn Combelic remarked that the latter idea hacl also bean put 1'oX'\vard by Dro

¥erlis at Purdue University.

Prof.· Adams

~ointed

out that the plugboard of

the :OPGcould be regarded::as a changeable mioro::!~gramo

sa.id that a mchine wi th a. ,drum-stored

micro"pro~;ratn

Hr. It~ D~ Smith

ha.d been buil·t for'mili-

tary applicationso
, Mr. P .. lI'o
to use •. ~hey

W~llia.ma

"i1 .nt

sa.id that his firm is trying to decide on a com:outer

something intemodiate between an IdH 650 and 7Ql.:·o

704 seems too large: they 'would not be able to keep it busy.

The

Jobn Backus

said that by· time' shal'ing o a. big cOID'9uter ~ould be used as several' small
ones; there \,/ould::.need to 'be a reading station for each user.

l·iro Ho ]'reaman

remarked that down time \oJould be wo~se for ~ne large machine tml.t. for aeveral
small oneso

Stanley Gill said thH.t the ideA. qf a centra.lised com-puting

bureau seemed a g'ood aIle 0 exce?t that if each subscriber viera to ha.ve his own

16- 3
inl.lut-out:>ut e4,ui:nnent he would no t be able to ufford allch flexible aqui'O-

ment.

trot'

0

""dams Iloin teu out that the idea. wa.s aif'li hLr to that of

tr.:.&.liseLi. stenot,;ra}hic bureau o which \l8.S not always successful..

sa.id that Jell Laboratories had in fact used

ill.mt-out:1ut very snoceasfully·.
I·~:.l.eh1.·nc

i~

rout,:hly

.:..1.1 ~"'O thr,:; wJrl,: load
.~J.;! :h·~<,·d

tj.!!jf~·

tnn.l"O ,:~, ·;,.:j."Y
'l:';: t.}.ll1 I)

l}r():l~,rtionu.l

11'.'\I~·l.:rvei\:'",

to the

th:~t

Bqlla.r~~

incrp:~GQn eX~),)!l(,!ltial1.:1

L; v:U;:.i.J.

1-

He sLl')d

],rl GD.:;(:'I

10

cenShell

contral computer \t/ith remote

0.

the eOGt :.:}3r '.")r')eration of a
r()·)t of

~'Vl ttl

t~!(':

th~

tir.:a

0

tjl~e ~er
~{e

i,.j} t

o·lera.tion;
th:.~ t

whert~

,')f orcn.kd6'i/llo u. l..rgr:- nOJIJl)uter is stilJ. orefcr·,.,

!Db. ,iJf:t.:u:eo.(';8 In thE. "'J·r.1.i·'!~: C':~::'J\cir;~~·f:' i~~r.l.(;f1

stl.ll irel)fj

Do

(l

,~rw..r.'o

m.'~:d.l r:!::~.c~h.i~J.':I::;.

f('jJ:'

~~X"lmL,

'I;h.oy

I.;i l'la"i',j,·. :l-::- 1:ntJ{)l"t.··1i.t Jo:n;"

Resume of ~I8ssion

1'7'

T.he usc of flat'1 d:ta era m::, in coding Has the main subj

In anm'181" to a question" C .. H,,' lLdams stntcd that the

Lan:i.ng~ZieT'ler

s:rsteY:1 has pro-ved very useful for a pal'ticulal" class of problems

\

0

.

,

.l-(.l

ReStUL~3

I•.':".':'

oJ: Session /)la

Af'Ger Vlai tine; n

Boe:lne;1 s experionce vli-l;h 'their '(,01"

yeal~

an.d a half, tho:;!·
.I!l

~aca1·(j"cd

the:tr '701 in Decn ~ 19531)

About 5 months

peo.pIe to i;lorlc c1o:i.n~ t . . 10 impoIW"cnn·t 'thines:

2)

Coo.in~

be1~o!'e

1) :E'indlng ou't ~'lhat othel" people

subrou'hines and assen:bly routines for thei]."

(F.'ill

mOll'lihs of this 'they spent a week on the NevI York 7010

conVinced them 'chay should completely revamp

more

i;h:~0G

'this they put

useo

After sevcn.'l11

Theil" expel-1enco 'lihe:I:'H

:olans by doillE things lllut:!h

theil~

autoruatico11y~
I

They now have an extellSi va Li bl'al~Y of Su'D:I,,'outines 7 most of, rlhich

qre stored on a tape and transferred tel tho dl'U1r:1 dU1 ing assemb1yo
1

Subrou'(jillO

'words whose addresses are not to be crlented or tl"'ea·lied in the norrr..al
dUl~1ng

compilation!)

illl norm..':ll words

p't~ecede

all dxceptions in each

mallll01.a
sub~..

l.'ou·h1ne and are thel!eby iden"t'.1'ied ()

EO.eh subroutine has a call' nuillber

which is specified by' the coder; the

assem~ly

routine then calls the indi,,,.

eatad sub:routine from the tape and in.tcgrates it in'co the suain l"olltines o
The assembly :routine occupi.es about 1/6 of' high·."speed storae;9;
J.~ma1nder

is available for tho cod.ern l'outines and

1'01'

'~h~,

subroutineso

Although B.oe:ing has 'bo·th IBM Speodco and Los Alamos Du.al system
available~l they

arc li't;tlo useo. o

straight machine codeQ

eVG~'I '~he

Dw.:J.

Most of the1:t" 0ngineeI's rtl"e 1.'rilling and able to do

.scole·.. factor'i.ng

:~. S UGcd (l.

About '70% of all ·thej.r coding is done in

01"

the

e.n~i!.I.e!Z)r

bacomes

'~OO

dj.1'1f:i.cu..1t ~ SpeedeD Ol"

...!~

·LO

t.ho '"101 has gEdned accep'j;anco amollg

'~he

enginoers by' wo:rc1 of mou·iih so

W6:Li 'i;hat i'h is leoP'lj very busy •• ·.·· no p:coselyii;!.ng hus beel1 nac(:)ssary

som~mho:t
8EI

d1fferen·t"

He found :Lt l)ss'jj -GO have people at as hiM

a.

I)

10'U"a1

possj.ble be among the til'st to receive 'Grainine :In tile use of 'I;he com.".,

PUi;OI'"

Than~

since "me computor i.s

viso:t's selling its nsc to

dej~ini toly

subo:}dil1a"~CJs

Sl1bol-dil1atos 'try ins to sell tho

...... a s5:'GU:ll;iol1

to

comput~r

. Usually from 2 to 3 hours per 16·..hott::a· day

VJl th

Douglas u for instance

0

:~oplied

ImntOi1eJlc(~

differe11t from

of Boeillg1s

III :r'osponse to a

COIl1J1lell1;

?Ol~

,;/;ha:c

that J,t compared favorably

IIc:mever) o:t Douglas they

0

'VOJ~y

theil~ st1p(:}r~iso!·s 0

Mr:) POI"tel· discussed the seheduled

'th:i.s seemad Wlduly high, Mro POll-tor

\,/o1"1;h\'111110 ~ you have- supe·:<.'"..

.~~d~g.~

tOl" less than 2-3 hOll.1.'"S per da:lli) but their stl.lt:Lsi.;ics show that

mainiiollHllC.O
main'~el18L,ce

L"'dlj.ntenonce should be realistic o
Q,Cl2z~~~~:

l.'ou·~in9?

.AJ.te;wer~

'~b.o cho1c(~

'1100 routine on punched cards and/o!,1 on magnet:tc tape;

1s made IT:9.t1ual1y

~_&Y..1! 0 ~E~~~

Anm,'l0X" by M1'0 Por"tel":

an.d

VlO ull30

,'Hla t 1s the output of ·tho Boeing 1J'.;memhly

0

Have

~rOt1

convel-rted

rio st1lJ. k(:ap ec-tJljlnr,

keep CPO 11 8 on test run. data

alll'

cpe

pro~)lems

rQduc"~ion{t

problems to '''l01?
sui. table for CPC p

fo,;! examplo:) almost on

a s'/iandby basis 0
All oxchant;o be-l,"V1oe:n Ho POX"[;Sl"
and S" G':l.ll concorned subroutines o
....
".~_:AIUII~

"-t.~..

-....~ .... ~ ..........

Tb.EI orig:Lr..ator of a Boeing sub:::·ouij:J.n.o chscks :i:l; Ot1.t o..n.d 't'JI"'ltes. it up S!

c,

~

18 ",', 3

'iioms in

8:[,1'60'1.;

g:i~'UdU(l11:}7

inda:t"':lll:Ltely ()

subroutin~s

now ore

romoved from the 'Gap) li1.n.'~·y and made mora dif'f'iculoj; to use b~J'

'bol:ng available only

lUlU

:,(n fac'h 1\ old·",fashiollod

ill

card d ::scle formo

soltri;ion is

~,_lg_:.>_.

,
Codi.
I_._.~---.,--

Bl')oing~ s

_

___ .L~put I

emphasis therefore is

Computing

Assembly

pr:L~t'"ily

Jj I

Ou'l;put

on decreus5.ne codil1.g und otliipu"Ci

19 .... 1

G.:L~ Charl1:n olltliuzd the needs of the ¥lutual Benefit Life

Dl"o

Inm.ll"anCe
digi'~s

COn1pany~

a:~i"t11ln8tic,

For

fi::;:ed

poin'~

l{orud be usefttl ~ 'olso there 5.s a ne8d to

zlumbers of 20 decimal
;~to!'e

alphabetical ini'orm·"

High spead tape soarching aud pZ'in1iiIlg will be required

,:3.-Gion..

access to any point in s.

is unnted.

:?il(~

Hi't~h

the lIhole file P81"'iodical1y..

Quick

0

rrhe present plan is -to revis"1

regard to a basic libr[u:'y provided

Hith '(',he lJI.achillS p 'there i:3 a difficulty becau.se needs Vt;U\Y Hi'ch 'i:,he' compru.'ly

and uit.h ·the 'bime
for au:comatic

Th.e p:::"oblem of trnnscrlbing the

0

IleCCSSU1."J7

records

iDa pig one r. this pSl"'li of the swii;chovel" may

ope:r~t,:i.Ol1

Variable len~th i"'lelds al"'lse; pl'emiulDs ne.9c1. only 6 'or S digits:>

take yearso

'.rne· compar,y :ts not, considoI'ing. the els(!"c,ronic

som·;) sums of money may n.eocl 120

handling of investment,s; :tt is considGrillg billing, a CCoU11ting , file main·~enance I)

etc.

Heliabili-cy is

:i.mpol.,tarrt~

t,hel"'e is :ilrGerent in the

ni'a~Ll

3ai"e tt type of checko'
N'r

asl~ed

T .Ho Htu:'eu1:'c,z

0

uhether the

Dr. eherlin' replied tlha:t it Hould no1io

he said tha"t, divide:n~1s

lIork Hould be U1achanizec1o

In repljf to a.

ftl!J'~her

qUElstiOll v

bo calcula·G9d indi·'lidually ~ l1ot. h".f reference

Ope1's':"ions 011 dif':L'el"ent files Hould be combined as ·t~h:i.s beculL3

t.o a table.
::~Jo8sible.

H01Ud

ac·tt1J~ial

Hith

'~he

I.Boll·l.) 650, i'c uould be p()ssible to combine first

and then three f:tles.·

I"G lP.a7T eV811t,ual1y be possible

"~O cor:.b:ln~

tHO

;0 files into

one for proc6soingo
Prof.

lldE!J1S. raised

t.he qu.os-c,ion. of the extent to vlhich automatic c}oding

might be used in business..

Hoald it. be usefu1 in .opt.im:Lzing prOC89,UXes?

Gould a ll1',;1nufactul"\3r,' usefully provide pset'l.do ... codes'?
j':,h"

'business
'30tlSJ.y·

C.. G. Lincoln ptrjj fOI'Hard 'the vieupoint, of the

0

0

The alil0ur.rt of

Competition

:rOj~ces

insurance

is v0r:y sm'ull'; it, can be done simu):CBl10:0

,~ompu'~",il1g

How;}ve!'~

Hith input, and ov:Gp1.:r'c.

l1on~\Ol:lfe

a transcription pi"ohlem arisesQ

'c,he iluB.ediu·G0 furnishing of: policies it! the

:ls der:3irable to produce s:llllulai.190usly a meehanical

I'ecord~

field~

it,

A machine is

!

1"eqt'li:red .that. Hill print, policies and also make a "tape or card reco:rdo

In 'cho life .:b.'ls'Urance

hilS :i.11es~1!1

dividend calculat.ion prc b1em
1

t.ho

rrr8ve10l'" U:3 Jj1f.r1.lJ7anCO

~8 :!,";:' ~·rorkf.,

on

£l

Cornpru.'lY has

gUi::ll"aiyteed cost, ·basis 0

110

Instead

'~h8ro is a morG\rl"eq'l.l.elJ:~ and mo:;'o in';:':;;'ica'G0 (~alc1J.la·c,:lon (Jf GlAq,r.9~U"GCerl proud.urns 0
:';'1' (;'0 ·j-he
COillpU~~'l"!'l'
U
:"tc,;.1I 0'"1
L ~'lJ,;1o
... 1.. ·p(··· .....f,::>J.·
'-" ·;·1;~,..:.::I

,1 . . .1

._)~.

(!onf;l·Gr~.l1t.l~f

:JP ';j~d.8

changed.,

comput.a:li:loilo

.J ,.~... ....

1j·<=ll-'(.lIS
.~ 1:::
co ; r:lJ"
';<:1 ·"·I')c.:.
'''';a+os
Col.
t.h",
...
l. .' 'J:':'f'::
. _ ..t. "'1,1';'·
........ .., cU.,
I,
V'
J.
""."H, a,'-;-~'~
_V

It, .in posEd.hl0 that afoJ.':m of" curve ..·f:Lt,tl71guill sps6c1

19 """ :?
J\·of'" AdD'li1S po lntad out that in

14lf_my eUH6S

ng:::'ee to use a i'm:\'L1f;.1 npproxims"C.ion t.o a

IJlI,ney :in eCJlurn-ri:.ing thnn they lost

cu~"ve:)

th~otl.gh

ares full of ,(p:J.t.idy e1wept ions '-I and this is
autmnati~~

eoding

f1.rst!i and 111' ..

It

if'therrLBi'1agemOl1t. uoulc1

they might, naqe morl!:}

el'l"oro in
Olle

~\jhe (!l.u'VElo

of the

Pay!."o11s

dif"i't(~ult1es

in

Dr" Gherlin said that his company vwuld handIe payrol.ls

Hurmri'I~~

said t.hat t.here a:ro very fe,,, basic

t.ype~~

of paYl"'C'Jll

(!omputations .;,
Dl'l;> Graee ilf .. Ik,pp~~l" ment,ioned $.11 exist:tllg machine 'Used for (~ssent.:tnl1:T

bUain€;18S compu:~cat,ions~ th;:} I,~.r:LJ·L, 701 at "the AviucioH Supply Cantero

Lo

Hc:>sent.hal said that the Univac; at the David 'l\aylor Hodel Bar:.J.n also 18
W;H?d 1'01'

some business

t.~

pe (:al·r;;ulations 1l namely tho plannIng of

by t.he c8ntI'['.1 supply office;)

supp]j.(~13

20

g

0

Hoppel~ me:a"c,5.oIlCd

that for

bUE3 inens

en

1

problems it" 'Has often.

(Jon'u\';ll'lieu'(j "GO break a[rca precossing by automatic compu'GC)I's. in:£o'-· fouT.

nlassifica"tions ..-. input'I) dec:Lsions:) calculation%) and ou:cput - and
·cha·i.i in b'1J.siness 1J:'Ell'ution on fh-ec1 data pJ..a,ys a much s;naJ~er roie

tha:a. in mathero.r:d:.:i..ca1 pr·ograunni:..TIg

4)

A quos,tic:'.} C'cl"'OfJ0 concel"'nillg "the dii"flc'lll ty of human access to

:hlfoi."mation st.ored on magne"C,:Lc t.ape
COl1HSY
:t-b~lffi8

I)

replied that, printing out, small files or only changed

in large

file~)

rrhe difficul't,y of eon

1:Tare -t.HO posElibili'l.i:los¢

No

. vlncing some people of' the :o."'elie.b:llit.y of l1lagnst,icslly s"ijored de"lie

Has mentimlsdQ

In hruiking ~ a luu requires checks to' be

sOl~tecl

and

t'Gt'l}:·('!led and' "chis opol'le.:biou :tt~ diff:i.cul·c to' mechruiize ~
G., Hoppe;r emphasized -bhe iInpor-cance of the development,

or

a largG

scale randem access file.
Car·G,8j:" empnasiz3d

as

:UilpOl'~t?.l!.t

COSlt

e~!cep"i:iional

und the ability to hancUs

cases

ospccto of data·..processing Bystems.

C Qlklams men't:iio:ned that, the abilit:;'" of eleci':ll'onic comptrc,e):s "GO make
:tt possible to ~al1dle Inany exceptions in a rev.tine fashion ll alld in
ca~les

:301lle

l.{US a strong :point. in favor· 0:(' elec'lirouic equipment,..

The

pos8:i.bj.li t-:ihf selling some incon":.rm1ience in re-C,U.l"'ll for fOS"tier processing
might

'bfJ con.s~.del.'ed

and has

~.,een ·t~it?d

persol1al.checks¢
HY'.rell1.t.z li!el1tioned that neu
to be developed

't~O

'in some cases, i. e '" pWlched. card

~udi'Ging

procedu:res probably tlould hcrve

handle automatic data .... pl..ocessil1g.

The posfdbi1i'c;r of an engineering qual"antee of, propel"' 'mac~e
op~ration

bein.g eouaidered a suf.i:icientj audi'c Has

conjec'~ured

by S. Gill.

Htu'0t-!:!:tZ added t.hat a cC>l1tinuous audi.r~ t-lolud probably be mOl"e

prac"cicablo 1Tlth :1.niJ:....eased conrpu'tiing capacit.y.
Rosel'ltha~ inquired as to uhe-ijher peJ."al1el cP..ec1cs and individual

chGcks ~ e g. ove~!."ly large changes 01~ item sizes:1 could be mafnt,ainedo
D

Chel'lo11.11 obse.rvecl that 'in adc1itic!l tiQ ·Ghis type of check£! engineel'ls
could o:E't.en m.i.ggost checks 11.0-(, obvir.>ml -i:;o prog~'smn.ers
0

c. H

0

I~dams

chec!d.ng "lihE:

cll1}.,hasized that caL'efnJ. at,t.o:i.1t:lon s11m.lid be paid "CO

mos'~

ll;:iJ:>el:i.able pa'J:ts of th::: aq'l1ipme:(l"Gfi

CC?rtej. ~ nO)j8d t11at a eareful probabll:l.st,ic f)"cudy of t.he economics of

checking h.ns been rna.de and may be

aita:11abl~)

on z·equ0s·c,ct

21-1

Automatic Coding Techniques
List of Reference Material
compilQd largely from lists prepared by Grace M. Hopper, ,Remington Rand Inc.,
and Frank E. ,Heart, M'.I. T.
Conference Proceedings:
A.

,Proceedings of the Association for Computing ~1achinery, at the Mellon
Institute, Pittsburgh, ~E:\.',~ May 1952. ,Obt~inable,at $4~OO from the
, A. C.M., 2 East 63rd street, ,New York 21, ,New York.
Al.

p.99

"Small Problems on Large Computers"
C. W. Adams

A2.

p.l?3

"Construction and Use of Subroutines for the Seac"
c:roseph H. ;Levin

A3.

p.23l

liThe Use of Subroutines on SWACl1
Roselyn Lipkis

A4.

,p.235

liThe Use of Subroutines in Programmes"
David J. Wheeler

A5.

p.23?

"Progress of the Whirlwind Computer Towards an
, Programming Procedure1f,
John W. Carr
'
't

A6.
B.

p.243

Automatic

'

"The Education of a Computer",
G~ace M.' Hopper
'

Proceedings·d>the Association for Computillg:&6hfnery,' at'the University
of Toronto, Ont., September 1952. Obtainable at $.3.00 from the A.C.M.,
:2 East 63rd Street, New York 21, New Yo~k.
Bl.

p.l
.

B2.

p.l?

"Compiling Routines"
Righard K. Ridgway
"Machine Aids to C.od;ingit
E., J. Isaac

B3. ,p.l9

ItOom~uter

B4.

"Inp,ut Scaling and Output Scaling for a Bin~ry Calculator"
E. F. Codd and H. L. Herri~k

p.2l

Aids t'o C'ode-checking"
, J. O.Diebm

B5. 'p.46 tlLogical. or' Non-mathematical Programmes"
C. S.,Strachey

"

B6.

p.55

"Simple Learning by
A. G. Oettinger

B70

p. 81

II

D.

Digital Computerll

Interpreta tive Subroutines"
J M. Bennett t D. G. Prinz, H. L. lvoods
0

B8.

p .121

"Pure and Applied Progranuning"
M. V. vlilkes

C. , ;proceedings of a Symposium on Automatic Programming for Digital Computers,
sponsored by the Navy 'Mathematical Computing' Advisory Panel, Washington.
D.C., May 1954., "Obtainable after ,October 195~ at abou~ $3.00 from the ,
Office of Technical Services ,'Department o~ .Commerce.
i\

Cl.

I1Defini tions"
Grace Mo Hopper

C2.

," Differentia tors"
, Harry Kahrimanian

CJ.

II

C4.

"Editing Generators"
John Waite

C5.

"New York University Compiler System"
Roy Goldfinger

C6.

~Application

C7.

"The M.I.T. Systems: Comprehensive, Summer Session,:and Algebraic"
C. Ttl. Adams and J. H,. Laning, Jr. '
'

C8.

" Interpretive Routines in the I1liac Library'l
David E. Muller
'

C9.

nPlanning Universal Semi-Automatic Coding"
. Saul Gorn

Compiler Method of Automatic Programming"
Nora l-!oser

of Automatic Coding to Logical Processes"
Betty Holberton

.

ClOG

t'

"Present Status of the Michigan Automati~ General Integrated
Computation(MAGIC)11
J HO. Brown and J. W. Carr III
0

Cll.

"Automatic Programming on the Burroughs Computer"
Hubert Mo Livingston

C12.

,"IBM 701 Speed Coding SystemJohn W• Backus and Harlan Herrick

C13.

nprogranuning for the IBM 701· with Repetitively Used Functions",
, Allen Keller, and R. A. Butterworth

C14. .ItSummary and Forecastn
Grace Mo Hopper
~

DIo

Mo Vo .wilkes, D. J o Wheeler, and S. GU1, liThe PreparatiQn ot.:
Programs for an Electronic Digital CompUte:r .~. .Addison-Wesley:
Press\) Cambridge, Mass." 19.51.

Papers in Periodicals
t
El o J. W. Backus, .tiThe IBM 701 Speedcod.ing System," Journal of ,the
Association for Computirig Machinery, Vol. 1,: No'~ 1, p.4 January
1954. ,.0'
.
. , '
E2.

S. Gill, II The Diagnosis of Mistakes in Progral11l1les on the EDSAC .,n
Proceedings of the R0yal Society (London), ,Section A, Vel. 206,
po ,53 8\) 1951..
. .

E3.

Margaret Ho ,Harper, II Subroutines: Prefabricated' Blocks for Building," Computers and Automation, Vo1~ 3, No.3, p. '14, 'March 1954.
,

, E4:
E50

'

Grace M ~opper, tt Compiling Routines; It Comput~rs and Autorna tion t
Volo ~, 'Noo411 po 1, May 1 9 5 3 . .
,
,
0

Grace Mo Hopper and John W. Mauchly, '"Influence of Programming
Techniques on the Design of, Computers', t1 Proceedings of the' Institute of Radio Engin~ers J Vol. ,41, No,. 10 • p. ,12.50, October 1953 •. "

E60 .N.B.S. Machine Development Staff, '"The Incorporation of Subroutines
'into a Complete Problem on 'the NBS Eastern Automatic Computer,"
Mathematical Tables and Aids' to ComputatiC?n,Vcol.4, p,. 164, '
J~1950.
'
~7o

D.J 0 Wheeler, "Progranune Organization and Init~al Orders fo~ the
EDSAC.II Proceedings of the ,Royal Society (London) Section'A~ 'Vol.
202 11 po 573, 1950 0

E8 o 'M.Vo Wilkes, "The Use of a "Floating Address" System for' Orders i;~
an Aut0matic Digital Compute,r," Proceedjngs of the Cambridge Philosophical Soc1e~y, Vol. 49, pt. 'I, ,:p. 81f, ,1953..
Reports with

Limi~ed'

Circulation
.
or~anizations
'

Request~

for copies should be addressed

~o

the

shown.

Programming Research Section, Remington Rand Inc., 1624 Locust Street,
Philadelphia 311 Penn.. "
.
Flo

"Analytical Differentiation by a Digital Comput,er," by Harry G.
Kahrimanian
.

F2. ,"A-2 Compiler Manuallt

F39 ," A-2 Compiler~
International Business Machine Corporation. 590 Madison Avenue, New YQrk
220 New York .
F4 •. "IBM Speedcoding System for the Type 701 Electronic Data Process. ing Machines. n ,
Digital Computer Laboratory, Massachusetts Institute
Cambridge'39t Massachusetts.
F50

of

Technol~gy,

"M-2539: Comprehensive Systems.·Manual: Part I, . Introduction t.o
. Progranuning?I~' by H.H.-Denman, E•.S. Kopley andJ ~ P •. Porter~
December- -19530
~.
.' .
.
,Part n on. the general principles ··of operatin of ·the Comprehensive
System g and Part 111 containing details ·of·the executive routines
are in preparation.'
.'
.

Instrumentation LabQratory, Massachusetts Instit.ute of Technology,
Cambridge 39, Massaqhusetts
F60

ItE-364: A Program for the rranslation of Mathematical Equations
for Whirlwind I," by J. H. Laning ·~.nd·N .• Zierler, January 1954.

University .of California Radiation Laborator,y, Livermore, California,

F7

0

"U,lO Edit Compiler 0" UCRL-4286 (unclassified) by Merritt. ,Elmore,
February- 1954.
I ..

'A.;EoC o Computing Facility, New York UniversitY,f53 Greene
New York 3, .Now York
F8.

"New York University Compiler Syst~m."
by Roy q.oldf~gero March 1954.
.

University
F9.

Mathemat~cal

~t.reet,

NYU-6478 (unclassified)

Laboratory, Free School Lane, qambridge, England

Programming notes and recent library routines.
preparation)

(1954;

in

Digital Computer Laborator,yp Graduate College, University of Illinois,
Urbana 51 Illinois

FIOo nIlliac Programmingyn April 1954



Source Exif Data:
File Type                       : PDF
File Type Extension             : pdf
MIME Type                       : application/pdf
PDF Version                     : 1.3
Linearized                      : No
XMP Toolkit                     : Adobe XMP Core 4.2.1-c043 52.372728, 2009/01/18-15:56:37
Create Date                     : 2010:06:24 09:48:06-08:00
Modify Date                     : 2010:06:24 10:31:56-07:00
Metadata Date                   : 2010:06:24 10:31:56-07:00
Producer                        : Adobe Acrobat 9.32 Paper Capture Plug-in
Format                          : application/pdf
Document ID                     : uuid:cd301121-f533-476a-a8de-1a070718045b
Instance ID                     : uuid:1a0ac0c3-63aa-4601-b56e-c5b7b1d5ac95
Page Layout                     : SinglePage
Page Mode                       : UseOutlines
Page Count                      : 91
EXIF Metadata provided by EXIF.tools

Navigation menu