## PRACE Instytutu

 © Maszyn MatematycznychPAN
P. 2224 64

Praca A 3 (20)
AUTOMATIC SELECTION CHECK of A MAGMETIC CORE MEMORY
by Jerzy daída

Sußu色th Instytutu Maszyn Matematycznych Butullpolakiej Akademid Nauk

## P. 2224

AUTOMATIC SELECTION CHECK
OF A MAGNETIC CORE MEMORY
by Jerzy DAŃDA

Copyright © 1964 - by Instytut Maszyn Matematycznych, Warszawa Wszelkie prawa zastrzezone

## $0.427 / 64 \quad 5,0023$ <br> Komitet Redakcyjny

Leon छUKASZEWICZ./redaktor/, Ant oni MAZURKIEWICZ, Tomasz PIETRZYKOWSKI /z-ca redaktora/, Dorota PRAWDZIC, Zdzisław WRZESZCZ
Redaktor działows: Andrzej KOJEMSKI.
Sekretarz redakcji: Romana NITKOWSK之.
Adres redakc ji: Marszawa, Koszykowa 79, tel. 28-37-29

# AUTOMATIC SELECTION CHECK OF A MAGNETIC CORE MEMORY by Jerzy dañda 

Received Deoember 3th 1962


#### Abstract

An automatic error detecting system for a linear selection memcry is described. The syatem checks decoding operations of memory addressing circuits. The idea involved is to encode the one-out-of-M code used on core array inputs back to the binary code. The latter and the original binary code fed on address inputs are comparad and discrepancies detected. Reliable components ueed in the encoder, being part of the checking system, ensure the majority of detected errors to be true exrors of the addressing circuits.


The subject of the paper is an automatio oheck of addressing cirouitry of a linear selection memory.

The ad a ressing 01 c cultry is this part of the memory which seleots memory locations transforming signals fed to the address inputs and driving oore array by word ourrentpulses of proper amplitude and timing.

The core arraj of linsar selection memory is a rectangular core matrix with $M$ rows and $N$ columns. Rows correspond to memory looations/words/ and oolumns - to positions/bits/ of words.

In the majority of memories the address of each memory loaation is determined by a binary oode fed to the memory by signals appearing on $K$ address inputs. This enables the selection of one-out-
of-M locations. Usually, for the economy of the decoding elements such a $M$ is chosen that

$$
M=2^{K}
$$

is satisfied by natural K's.
The operation of the addressing circuitry/mostly consisting of address register, decoding matrices, amplifiers, seleotion elements and current drivers should be considered from two points of view ${ }^{\text {* }}$

1. information processing or performed logic operations which may be described adequately in terms of boolean expressions;
2. signal processing where such operations as amplifioation, pulse stretohing, pulse reshaping etc. are involved.

Conoerning point 1, addressing circuits convert the binary code used on address inputs into the one-out-of-M code, used on the core array inputs.

Conoerning point 2, addressing cirouits transform the signals on address inputs from the standard form into that of word-drive cur-rent-pulses with the amplitudes and timing needed to switchover magnetic cores.

In order to increase the reliability of the memory by means of an automatic selection check both information and signal prooessing should be checked.

The reliability of the checking circuitry should be significantIy greater than that of the ohecked cirouitry, in order to obtain a negligible number of checking circuitry errors.

The check of the correctness of code transformation being the main technical problem, may be realized at least by two methods /I,II/. Although they may be reduced to a more general way, they are worth being considered separately.

[^0]Method $I$ consists in converting the one-out-of-M oode used on the array inputs back to the binary code by means of an appropriate encoder, and oomparing it with the original code on address inputs. This is achleved by a parallel comparator inoluded in the oheoking cirouitry/refer to fig.1/.


Fig. 1. Check circuitry /iifethod I/

This method enables us to deteot any error which may appear in the addressing oircuitry, consisting in:

- lack of pulse on whiohever of the outputs $a_{0}, a_{1} \ldots a_{N-1}$,
- simultaneous appearing of pulses on $2,3, \ldots, M$ outputs,
- lack of pulse on the selected output, and appearing of pulses on $1,2,3, \ldots, M-1$ outputs.

This however, requires the following assumptions to be satisfied: 1. The check circuitry built as in fig. 2 is fully errorless.
2. Outputs $a_{1}$ of the addressing circuitry are described as below by $M$ functions of $r_{j}$ inputs:

$$
a_{1}=f_{1}\left(r_{K-1}, r_{K-2}, \ldots r_{j}, r_{1}, r_{0}\right) \quad \text { where } \quad 1=0,1, \ldots M-1
$$

is

$$
\begin{aligned}
& a_{1}=1 \text { for } \quad 1=\sum_{j=0}^{K-1} r_{j} \cdot 2^{j} \\
& a_{1}=0 \quad \text { for } \quad 1 \neq \sum_{j=0}^{K-1} r_{j} \cdot 2^{j}
\end{aligned}
$$

It is easy to satisfy assumption 2. As a matter of fact, the very same functions describe the operation of the majority of addressing circuitry. However, it is praotically impossible to satisfy the first assumption, as a fully rellable oircuitry does not exist. It is even diffioult to satisfy an easier condition postulating a number of oheok circuitry errors, small as compared to the number of those of an addrassing circuitry, because the complexity of the checking oircuitry for wethod I would reach that of the checked circuitry.

The check oircuitry of this type/refer to ifg. $2 /$ consists of $K$ NOT elements /'N'/ whioh supply the variable $\bar{r}_{j}$, 2K EXCLUSIVEOR elements/' $\omega^{\prime} /$, and 2 K OR-GATES /'+'/ eaoh having $\frac{M-1}{2}$ inputs. OR-GATES form the encoder.

The error signal appears on the output of the OR-GATE, the arguments of which are outputs of EXCLUSIVE-OR elements.

According to the logic diagram/fig. $2 /$ the error signal $b_{j}$ for j-th binary position of the address is the following

$$
b_{j}=\left(r_{j} \oplus c_{j}\right)+\left(\bar{r}_{j} \oplus \bar{c}_{j}\right)
$$



Fig. 2. The fragment of check circuitry logic diagram

It is worth while to notioe that use has been made of assumption on errorless operation of checking circuitry, taking out of four possible combinations/refer to table $1 /$ two only complementing combinations of variables $r_{j}, \bar{r}_{j}$.

Table 1

| $r_{j}$ | $\bar{r}_{j}$ | $o_{j}$ | $\bar{c}_{j}$ | $b_{j}$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 0 | 1 | 1 | 1 |

It may be proved that any error which may appear in addressing oirouitry, causes such a state of $c_{j}, \bar{c}_{j}$ that it is signalized as an error, at least on one of the outputs $b_{f}$. As the error signal is a logical sum of the outputs $b_{j}$, every error is signalized.

In spite of the great reliability of the encoder, due to an extensive use of magnetic oores for its construction, the signifioance of the checking circuitry /Method I/ is rather theoretioal, as, besides the encoder, it would contain a great number of other oircuits, the reliability of which would be comparable to that of the addressing circuits.

Therefore, assumption 1 cannot be even approximately satisfied. In this context it is purposeful to seek for another method.

The solution can be found by means of reducing the check circuitry tasks, i.e. to require the detection of only most probable errors. This would permit to use a smaller number of cheoking cirouitry elements and to reach the proper reliability.

As regards the checking of the address circuitry operation this principle can be realized by means of Method II as follows. A redundant code is to be used on the address inputs. The set of all
$2^{K}$ memory locations ought to be divided into subsets in a determined way. While sending an address to the $K$ address inputs, the encoded information determines the subset to which the above mentioned address belongs. This information is fed simultaneously /or with moderate delay/ by the computer on the $D$ redundant positions of the code. Errors caused by the selection of a word from an inappropriate subset which is due to a faulty operation of the address circuits, are those detected by Method II.

The simplest example of such a check is the parity check of the address. The set of memory locations is divided into two subsets. One of them contains all memory locations corresponding to addresses with even numbers of ONE's, the seoond one to those with odd numbers of ONE's. One additional position in the oode ( $D=1$ ) is sufficient to transfer information as to which subset the actual address belongs.

Obviously, this method may be extended, for instance, addresses may be divided into subsets having addresses containing the same amount $/ 1,2,3,4 \ldots$ and so on/ of $0 N E$ 's. $D$ redundant positions permit to divide all memory looations into not more than $2^{D}$ subsets. When choosing $D$, depending upon the need, the circuitry may be adjusted to the required efficiency of checking. It is therefore an elastio method using technical means according to the assumed efficiency. In fig. 3 the blook diagram of the check circuitry /Method II/ is presented.

Conversely to Method $I$, this method permits to detect only a part of the errors.

Method II is efficient if every subset contains only addresses with small probability of their mutual transition or in other words if a faulty operation of the address circuits most probably cause a word selection from another subset. Ii is evident that the probebility distribution of deformation of the decoding algorithm determines the best division to be chosen which ensures the efficiency of error deteation. This distrinution is due to the operating experience, or it may be evaluatsd on the basis of qualitative analysis of the circuits. An effective encoding of information on tine address assignment to a subset is chiefly possible only if the zum-
ber of error types is small. On the other hand it is worth while emphasizing that the construotor may somehow influenoe the probability distribution of the types of errors, for instance by ohanging the dividing of circuits in the plug-in units. This is the case when intermittent errors oaused by oonneotors are a problem.


Fig. 3. Block diagram of check circuitry /Method II/.

Summarizing, the construction of the checked circuitry and that of the checking circuitry should mutually influenoe one another, this resulting in a system the exrors of which are easy to be detected.

An essential constructional problem appearing in both checking circuits /Method I and II/ is to build reliable multiargument orgates /of several hundred arguments/. A great amount of arguments and the current-souroe signals on the inputs of or-gates disqualify the most popular diode realization. The solution mhich satisfies both requirements very well, uses non-linearity of rectangular histeresis loop cores. This consists in adjoining one additional core to each word line. While selecting a word line, the additional core is $s$ witohed over and output pulses induced in reading wires. Each or-gate is made by one separate reading wire. Each reading wire is threaded only through additional cores of these word lines which are arguments of the very or-gate. A reading amplifier connected to each wire, amplifies and standarizes signals. The circuit diagram of the solution is shown in fig. 4. In fig. 5 a fragment of the encoder plate used in the PAO $4096 / 28$ memory [3] is presented. Referring to fig. 5 there are only two reading wires as in the memory the II-nd method II of the check has been applied in its simplest version, performing the parity check. Contacts visible in the bottom part of fig. 5 serve to check the word-line current by means of voltage measurement on the inserted resistance $/ 0,3 \Omega /$. They are used because of the prototype character of the memory.


Fig. 4. Circuit diagram of a part of the cheoking circuitry /with magnetio cores/.


Fig. 5. The fragment of the encoder plate.


Fig. 6a. Word-Iine current. Vert, soale $100 \mathrm{~mA} /$ div.

Fig. 6b. Checking-core out put signal. Vert. scale $50 \mathrm{mV} / \mathrm{div}$. Horizontal scale $0.5 \mu \mathrm{~s} / \mathrm{div}$.

The current waveform in the word-line is shown in the oscillogram, fig. 6a, whioh was done by means of a four-fold superimposing of current pulses, twice for a full-seleoted word line and twice when the magnetic-switch core driving the word line was half selected. A great uniformity of the current waveforms as well as a good selection ratio are quite evident. Fig. 6b presents the voltage response of the checking core in the full-selected line.

It is worth noticing that the construction of a multiargument or-gate used in a check circuitry may also be used to realize permanent storage oombined with a working memory. One more additional core should be plaoed in each word line for this purpose. Eaoh reading wire representing one binary position of the word is threaded only through those cores where ONE's are to be stored.

Such a solution is very similar to the construction of the permanent storage PAS-2 desoribed in [1] and [2]. It has the virtue of using the address oircuits of the working memory. The reading amplifiers are the only additional equipment. Moreover, the troublesome procedure of noise compensation from half-selected cores might be omitted because of the Inear selection applied instead of the coincident-current selection.

## References

1. £UKASZEWICZ L.: Permanent Ferrite Core Storage, Prace ZAH, Harsaw 1960:A4.
2. BOLIŃSKI R.: Permanent storage PAS-2, Prace ILX, Warsaw 1963:B2/15/.
3. DANDA J.: Ferrite Core Operational Memory, Report IMM, T-OF-27-D, Warsaw 1963.


[^0]:    * As regards p. 1 and 2 it is worth while to emphasize that the signal processing in the memory circuitry predominates over the signal processing in other units/such as erithmetic and control units/, where the information standard representation in principle does not change during all logic operations.

