## PATENT SPECIFICATION

DRAWINGS ATTACHED

Inventors: TOM KILBURN and DAVID BEVERLEY GEORGE EDWARDS

976,504



Date of filing Complete Specification March 14, 1961.
Application Date March 16, 1960.
Complete Specification Published Nov. 25, 1964.
(c) Crown Copyright 1964.

No. 9301/60.

Index at acceptance: -G4 C(1D, 2H, 2K, 3E, 4A)

International Classification : --- G 06 f

## COMPLETE SPECIFICATION

## Improvements in or relating to Data Storage Arrangements

We, NATIONAL RESEARCH DEVELOPMENT CORPORATION, of 1, Tilney Street, London, W.1., a British Corporation established by Statute, do hereby declare the invention, for

5 which we pray that a patent may be granted to us, and the method by which it is to be performed, to be particularly described in and by the following statement:— This invention relates to data storage

This invention relates to data storage arrangements suitable for use in an electronic
digital computing machine and is more particularly concerned with storage arrangements providing a large number of separate word storage locations or addresses which are immediately accessible on demand by an appro-

- 15 priate address signal and which include as storage means devices which become immobilised for a predetermined period of time after, being subjected to a reading or writing operation. The invention is particu-
- 20 larly, although not exclusively, concerned with data storage arrangements comprising a large number of magnetic storage cores or similar remanent induction type devices arranged in matrix form.
- 25 It is well known that a magnetic core type storage device comprising a large number of separate storage cores arranged in matrix form for the registering of a plurality of multidigit data words in an electronic digital com-
- 30 puting machine is subject to a limitation of the speed of successive usage for either reading therefrom or writing thereinto. For example, although an actual reading or writing operation involving a particular group of
- analysis, annotain an actual reading of writing operation involving a particular group of cores of the matrix block which form the storage location for one data word may be effected in, say, 0.5 microsecond, the whole of such matrix block including all of the remaining cores forming the storage locations for a 40 large number of other data words becomes
- 40 large number of other data words becomes effectively immobilised for a considerably

longer period, say, 2 microseconds. In the case of high speed machines which are capable of effecting arithmetic operations in, say, 1 microsecond, this delay or immobilisation period can result in considerable and unnecessary operational delay particularly when, as is frequently the case in practice, successive order words of the order programme are located in sequentially numbered addresses and/or the data or number words called for by successive orders are likewise located in sequentially numbered addresses.

An object of the present invention is to provide an improved arrangement by which 55 the effect of such delay or immobilisation time may be largely avoided.

In accordance with the invention, the data storage device comprises a plurality of physically separate blocks or matrices of storage 60 elements, e.g. magnetic storage cores, each capable of registering a plurality of data words and the address selection control means are so arranged that the groups of storage elements constituting storage locations having 65 successive address numbers are located in different ones of said blocks or matrices. Thus, for example, in a data storage arrangement providing 8192 separate word storage locations, eight separate blocks or matrices each 70 accommodating 1024 words may be employed and the group of storage elements constituting address 0 arranged in the first block, those of address 1 in the second block, those of address 2 in the third block, those of address 75 3 in the forth block, those of address 4 in the fifth block, those of address 5 in the sixth block, those of address 6 in the seventh block, those of address 7 in the eighth block, those of address 8 in the first block again and 80 so on. In an alternative and operationally preferable arrangement providing the same 8192 word storage capacity in eight blocks or

matrices each accommodating 1024 words, the groups of storage elements constituting the even numbered addresses 0, 2 . . . 2046 are arranged in the first block, those of the odd

numbered addresses 1, 3 . . . 2047 are arranged in the second block, those of even numbered addresses 2048 . . . . 4094 in the third block, those of odd numbered addresses 2049 . . . 4095 in the fourth block and so

10 on, alternate blocks containing even and odd numbered addresses respectively.

In order that the nature of the invention may be more readily understood, two very simple examples will now be described by way of illustrative example and with reference to the

15 accompanying drawings, in which:

Figure 1 is a block schematic diagram of a first data word storage arrangement in accordance with the invention, while

20 Figure 2 is a block schematic diagram, similar to Figure 1, of an alternative data word storage arrangement also in accordance with the invention.

Each of the examples illustrated and about

25 to be described has purposely been simplified so as to deal wit honly sixteen separate data word storage locations or addresses distributed among four separate blocks or matrices of storage elements but the manner of extension 30 of the arrangement to accommodate the usual, much larger, numbers of storage locations will be obvious to those skilled in the art. The described examples utilise, as individual digit storage elements, magnetic storage cores of any 35 convenient and now well known form, for example, rings of ferrite material having a hysteresis characteristic of so-colled "square

loop" form, but it will be understood that the basic features of the invention are more widely applicable and are of utility and advantage with many other forms of storage element which require a recovery period following use which is greater than the minimum period existing between two possible and sequential demands for access thereto.

In the arrangement shown in Fig. 1, A, B, C and D each represent a block or matrix arrangement of magnetic storage cores with their associated windings. Each matrix block is assumed to provide for the registration of four data words, e.g. each of 40 digits length and the word signal input to or output from each matrix block is indicated as being by way of busbars 19. The particular form of 55 each matrix block is immaterial to an understanding of the invention. It may be arranged for either serial or parallel mode operation and may be of any suitable known form of construction. The method of controlling selection 60 of the group of cores constituting a required word storage address is likewise irrelevant to the invention as is also the particular method of effecting reading or writing. For simplicity it will be assumed that energisation of any one address lead 18 by a control signal r will effect

a required reading or writing operation with the particular group of storage cores related to such address lead.

The particular storage location address numbers allotted to the respective word loca-70 tions of each matrix block are shown against each address lead 13. Thus address 0 is in block A, address 1 is in block B, address 2 is in block C, address 3 is in block D, address 4 is in block A again and so on sequentially 75 and in the same regular order.

With the simple 16 separate addresses of the embodiment shown, only four binary digits will be required to define uniquely any parti-80 cular one of the available word storage locations and these four address digits, present in each order for defining the particular required storage address, are assumed for the purpose of easy explanation to be staticised 85 by a four-stage staticitor 10, the inputs being shown as of parallel form on leads  $11^{\circ}$ ,  $11^{\circ}$ ,  $11^{\circ}$ ,  $11^{\circ}$ and 11<sup>3</sup> to each staticisor stage 10<sup>0</sup>, 10<sup>1</sup>, 10<sup>2</sup> and 10<sup>3</sup> but clearly serial form operation is equally possible. The staticisor 10 may comprise, in well known manner, a group of two-90 stable-state trigger circuits which can be set either into a first or '0' state or into a second or '1' state, each trigger circuit providing two alternative '0' and '1' state outputs in accordance with the state into which it is set. Thus 95 when any trigger circuit is in its '0' state, its '0' output may provide a chosen potential or current while the '1' output thereof provides either zero potential or current or some other value different from that provided by the '0' 100 output. With the trigger circuit reversed to its '1' state, the '1' output thereof now provides said chosen potential or current while the '0' output provides zero potential or current or said other and different value poten-105 tial or current. In many instances of parallel mode operation, the address digit signals are available as sustained voltages or currents and in such cases the trigger circuits or other form of staticisor may not be needed, the said 110 address digit signals themselves providing the requisite '1' state version and the anti-phase '0' state version being derived therefrom through inverter means.

Each address lead 18 of matrix block A in-115 cludes a coincidence or AND gate 14<sup>a</sup>, 15<sup>a</sup>; 16<sup>a</sup>, 17<sup>a</sup> having three controlling inputs, one of which is supplied with a control signal r, another is derived from the signal output of a further coincidence gate 12<sup>a</sup> and the third 120 is supplied from one of a series of four further coincidence gates 13<sup>a</sup>, 13<sup>b</sup>, and 13<sup>c</sup> and 13<sup>d</sup> respectively. The address leads 18 of blocks B, C and D similarly include coincidence gates 14<sup>4</sup>---17<sup>b</sup>, 14<sup>c</sup>---17<sup>o</sup> and 14<sup>d</sup>---17<sup>d</sup> respectively, 125 each having the aforesaid control signal r as one input. The control signal r may comprise a single pulse or a series of pulses of a duration suited to the required reading or writing operation and time controlled with respect to the 130

40

45

65

associated computing or like machine to coincide with the required instants of reading from or writing into the store in well known manner. Coincidence or AND gates 14<sup>b</sup>, 14<sup>o</sup> and 14<sup>a</sup>

- are also controlled, in parallel with gate 14<sup>a</sup>, 5 by the output of gate 13<sup>a</sup> and, in similar manner, the groups of further gates 15<sup>b</sup>-15<sup>d</sup>, 16b-16d and 17b-17d are controlled by the outputs of gates 13<sup>b</sup>, 13<sup>o</sup> and 13<sup>d</sup> respectively.
- The group of gates 14<sup>b</sup>, 15<sup>b</sup>, 16<sup>b</sup> and 17<sup>b</sup> 10 have their remaining control input supplied from gate 12<sup>b</sup>, the group of gates 14<sup>c</sup>, 15<sup>c</sup>, 16<sup>c</sup> and 17° from gate 12° and the group of gates 14<sup>d</sup>, 15<sup>d</sup>, 16<sup>d</sup> and 17<sup>d</sup> from gate 12<sup>d</sup>.
- Gates 12<sup>a</sup>, 12<sup>b</sup>, 12<sup>o</sup> and 12<sup>d</sup> are controlled 15 by the two least significant address digits staticised in staticisor stages 10°, 10<sup>1</sup> whereby gate 12<sup>a</sup> provides an output for the digit values 00 of the two least significant address digits
- 20 whereas gate 12<sup>b</sup> provides an output only for the values 01 of the same digits and gate 12° an output only for the digit values 10 while gate  $12^d$  provides an output only for the digit values 11.
- 25 Gates 13<sup>a</sup>, 13<sup>b</sup>, 13<sup>e</sup> and 13<sup>d</sup> are controlled in similar manner by the two most significant address digits staticised in staticisor stages  $10^2$ ,  $10^3$  whereby gate  $13^a$  provides an output only for the most significant digit values 00,
- 30 gate 13<sup>b</sup> an output for the digit values 01, gate 13° an output for the digit values 10 and gate 13<sup>d</sup> an output for the digit values 11.

Thus, in operation, if a series of applied address signals define a series of sequential

- 35 address numbers, the related groups of storage cores selected for successive use will be located in different successive matrix blocks. For example, a first address signal 0100 (address 4) will stimulate gates  $12^{a}$  and  $13^{b}$  and will
- 40 therefore open gate  $15^{n}$  to admit the control signal r to block A. The next sequential address signal 0101 (address 5) will stimulate gates 12<sup>b</sup> and 13<sup>b</sup> and will therefore open gate 15<sup>b</sup> to admit the control signal r to block B.
- 45 Similarly, further sequential address signals 0110 (address 6) and 0111 (address 7) will provide access to matrix blocks C and D respectively. Each matrix block is accordingly used only once in each group of four successive
- 50 address number signals and the resultant minimum permissible access time to the store as a whole is reduced by a factor of 4, e.g. to 0.5 microsecond if each matrix block has an immobilisation time of 2 microseconds.
- 55 Under operational conditions, a regular sequence of successive address signals such as 0, 1, 2, 3 . . . . may well not be encountered except perhaps in connection with the successive order signals of a computing
- 60 programme and even then certain orders, such as those of the conditional transfer type, will break the routine at frequent intervals. In order to provide for a possible need to obtain access successively to two storage locations
- 65 which are each in the same matrix block,

means are provided for generating a "busy" signal associated with each storage block lasting for the aforesaid immobilisation period of, say, 2 microseconds following each in-70 stant of use of an address in such matrix block. This busy signal is arranged to be used as an inhibiting signal in the control system of the machine to prevent the next address selection operation taking place if it is in the same storage block until an appropriate recovery 75 time has elapsed, the machine operation then having a corresponding delay imposed thereon.

One arrangement for providing such "busy" or inhibit signal is illustrated for the matrix 80 block A in Fig. 1 and comprises a flip-flop or mono-stable trigger circuit 20 having its triggering input supplied by way of a buffer or OR gate 21 from each of the address leads 18 of the matrix block A. The output lead of the flip-flop 20 is connected by way of a delay circuit 22 to the controlling input of a coincidence gate circuit 23 whose other signal input is supplied also from the buffer 21.

The flip-flop 20 is triggered on whenever 90 any one of the address leads 18 for matrix block A becomes energised consequent upon the use of a storage location therein. The resultant output from the flip-flop 22 then conditions the gate 23 to become open but only after a delay time period imposed by the delay circuit 22. The latter is chosen to be of 95 such value that the gate 23 is not opened until after the active period of the control signal r has terminated so that, with each single use of the block A, no inhibit signal can appear on lead 24. The relaxation period of 100 the flip-flop 20 is chosen so that, in combination with the delay circuit 22, the controlling input to gate 23 ceases at the end of the parti-105 cular immobilisation time. Further use of the matrix block A after the end of such period merely causes a repetition of the operation so far described. If, however, a further address signal appears on any one of the leads 18 of matrix block A before the controlling input 110 supplied by the flip-flop 20 to the gate 23 has ceased, then such further signal passes through the opened gate 23 and appears on lead 24 as an inhibit signal which is used to hold up the normal cycle of operations in the control 115 system. It will be understood that each of the other matrix blocks B, C and D is provided with similar arrangements, the various output leads 24 being taken to a common in-120 hibit circuit of the control system.

Fig. 2 illustrates in a simple form equivalent to Fig. 1 the rearrangement according to a second and preferred form of the invention in which a first group of sequential even-numbered addresses 0, 2, 4 and 6 are disposed 125 in block A, a first group of sequential oddnumbered addresses 1, 3, 5 and 7 are disposed in block B, a second group of sequential even-numbered addresses 8, 10, 12 and 14 are disposed in block C and a second group 130

85

of sequential odd-numbered addresses 9, 11, 13 and 15 are located in block D. Corresponding elements have been given similar reference characters to those of Fig. 1 and

- the manner of operation will be self-evident. A "busy" signal is provided in this embodiment as in the previous arrangement of Fig. 1. This modified arrangement has the advantage, particularly when more than four matrix
- 10 block are employed, that orders or instructions of a computing programme can be concentrated in two of the blocks, for instance, in blocks A and B, and the remaining matrix blocks used exclusively or almost exclusively
- 15 for number word storage. This not only reduces the likelihood of successively required addresses being located within the same block but also facilitates the change of the contents of the different blocks by means of block
- 20 transfers to and from a subsidiary or backing store.

It will be apparent that many different ways of arranging for the required successional use of different matrix blocks are possible, the

- 25 choice being governed to a large extent by the type and arrangement of the blocks themselves. By increasing the number of blocks available, the effective access time may obviously be further reduced. For example, if six-
- teen matrix blocks are provided and arranged 30 in the manner described, then if the immobilisation time for each block is 2 microseconds, the minimum reading or writing time could be reduced to 0.125 microseconds.

35 WHAT WE CLAIM IS:-

1. A data storage arrangement, suitable for use in an electronic digital computing machine, which comprises a plurality of separate blocks or matrices of data word storage elements, each

- 40 capable of registering a plurality of separate data words, and address selection control means for rendering any one of the data word storage locations accessible for reading or writing by application to said address selection
- 45 control means of an address number signal in which said address selection control means are so arranged that address signals defining successive address numbers cause selection of word storage locations which are in different 50 ones of said blocks or matrices.

2. A data storage arrangement according to claim 1 which includes N separate blocks or matrices of data word storage elements, N denoting a number of 2 or more, and in which

55 said address selection control means are so arranged that the respective address signals defining any group of N sequential address numbers cause selection of a single word storage location in each one of said blocks or 60 matrices in turn.

3. A data storage arrangement according to claim 1 which includes N separate blocks or matrices of data word storage elements, N denoting any even number of 4 or more, and

in which said address selection control means 65 are so arranged that the respective address signals defining all odd address numbers in a first sequential group of numbers equal to the total number of word storage locations in a first pair of said blocks or matrices cause selec-70 tion of a related unique word storage location in one of said first pair of blocks or matrices whereas address signals defining all even address numbers of said first group cause selec-75 tion of a related unique word storage location in the other one of said first pair of blocks or matrices while the respective address signals defining all odd address numbers of a second sequential group of further numbers equal to 80 the total number of word storage locations in a second pair of said blocks or matrices cause similar selection of a related unique word storage location in one of said second pair of blocks or matrices whereas address signals defining all even address numbers of said 85 second group cause selection of a related unique word storage location in the other one of said second pair of blocks or matrices.

4. A data storage arrangement according to any one of the preceding claims which includes means for generating a "busy" signal for a 90 predetermined interval of time following each selection of a word storage location in any one of said blocks or matrices.

5. A data storage arrangement according to 95 any one of the preceding claims which includes means for generating a signal usable to inhibit continued operation of the machine or like means associated with said storage arrangement in the event that a second selec-100 tion of a word storage location in any one of said blocks or matrices occurs within a predetermined interval of time following a previous selection of a word storage location in 105 the same block or matrix.

6. A data storage arrangement according to claim 4 or 5 in which said signal generating means comprises an electric pulse generating device adapted to provide an output pulse of predetermined time duration following appli-110 cation of a control input signal thereto, said pulse generating device having its control input connected so as to be energised by the selection of any one of the word storage locations 115 in the related block or matrix.

7. A data storage arrangement according to any of the preceding claims in which said storage elements are of the magnetic core storage type.

8. A data storage arrangement substantially 120 as described and as illustrated in Fig. 1 or Fig 2 of the accompanying drawings.

> POLLAK, MERCER & TENCH, Chartered Patent Agents, Audrey House, Ely Place, London, E.C.1. Agents for the Applicants.

Learnington Spa: Printed for Her Majesty's Stationery Office by the Courier Press.-1964. Published at The Patent Office, 25, Southampton Buildings, London, W.C.2, from which copies may be obtained









-

## 975504 COMPLETE SPECIFICATION 2 SHEETS This drawing is a reproduction of the Original on a reduced scale Sheets 1 & 2



