

# Nonvolatile Storage with Magnetic Core Memory

Jack Brower

April 2021

## 1 Introduction

In the 1940s, the US Navy commissioned MIT to create a flight simulator to train incoming bomber pilots. Titled *Project Whirlwind*, this flight simulator would be the first computer to use modern data storage techniques by utilizing the properties of magnetic polarity to store data in the form of bits, 1s and 0s. The researchers of *Project Whirlwind* used relatively simple electric and magnetic mechanics to manipulate the state of ferrite cores in order to quickly store data as a form of early random-access memory, not unlike modern RAM.<sup>8</sup> The basic setup for a computer-model core memory bank is with two parallel rows of current-carrying wire, where any point which the wires cross creates a ferrite core node. This allows for any individual core to be manipulated by sending an on/off signal to two corresponding wires, e.g.  $(X_2, Y_3)$ . This changes the state of the core on said node. The ferrite cores then undergo magnetic hysteresis depending on the strength of their field relative to the magnetic flux. As seen in *figure 2*, there is a point on either side where magnetic flux  $B$  grows exponentially, and then “levels off”. The point at which magnetic flux “levels off” is the point where the state of the magnet changes to a 1 or a 0. On any given hysteresis graph, this point is found at the intersection where  $B = 0$ . This method of storage is also used in modern hard disk drives, where individual bits are stored on a film of ferromagnetic material, and pixels on the film are aligned to a magnetic pole through the process of hysteresis.<sup>3</sup>



fig 2. Hysteresis graph.<sup>3</sup>

In the case of core memory, the process of reading the cores destroys the data stored on the cores. However in this project, the cores are written to so long as there is power to the circuit, even without constant user input. This means that the circuit created is both non-volatile, meaning it maintains its state with or without power, and non-destructive, meaning reading the data does not interfere with hysteresis.



fig 1. Ferrite core grid.<sup>3</sup>

## 2 Methods

Magnetic core memory operates on the principle of the Ampère-Maxwell law (a revision of Ampère's Circuital Law), which states that a current carrying wire produces an encircling magnetic field. The related equation is:

$$\nabla \times \mathbf{B} = \mu_0 \mathbf{J} + \mu_0 \epsilon_0 \frac{\partial \mathbf{E}}{\partial t}$$

Where Maxwell's addition of the term  $\mu_0 \epsilon_0 \frac{\partial \mathbf{E}}{\partial t}$  accounts for electric displacement<sup>2</sup>, which is necessary to explain the function of the process of hysteresis in the ferromagnetic loop, see *fig. 2*. Individual bits a core memory module are stored in square-loop ferrite cores, which are looped in a certain number of wire, depending on the configuration. As per the Ampère-Maxwell law<sup>3</sup>, the magnetic cores undergo hysteresis, which is the alignment of atomic dipoles towards a certain polarity. In computer configurations, the state of the magnet is read by a sense wire (see *fig. 1*), which interferes with the state of the magnet and destroys the data held by the ferrite core. In the configuration used in this project, the charge of the cores themselves are used to store the state of a pair of LEDs in a JK latch circuit in a non-destructive and non-volatile way.



*fig 3. Modified JK latch circuit. The center loops are 4mm square-loop ferrite cores.<sup>9</sup>*

A JK latch is a type of circuit that operates on the principle of logic gates, which are themselves circuits that change states based on their inputs. The above circuit can be represented with logic gates as:



**Table 1: JK latch truth table**

| J | K | Q <sub>state</sub> | Change    |
|---|---|--------------------|-----------|
| 0 | 0 | Q                  | No change |
| 0 | 1 | 0                  | Reset     |
| 1 | 0 | 1                  | Set       |
| 1 | 1 | Q̄                 | Toggle    |

*fig 4. Perfect logic gate diagram and corresponding truth table.*

Where the circuit forms four logic gates of two different types, AND and NOR, which have different functions in of themselves depending on their two inputs. For example, a NOR gate would out an electric pulse (1) only if there is no electric signal. An AND gate would send out an electric pulse (1) only if both its inputs have an electric signal. For the circuit above, the state of the JK latch is stored in the two ferrite cores and switch when a different signal is manually sent. This differs from a JK flip-flop in that electric inputs are supplied on a certain frequency by a clock instead of on demand by the user.<sup>7</sup>

This project will be collecting data based on the output of the circuit itself (that is the state of the LEDs based on the user input of switches J and K) and on the relative change in flux (gauss) of the ferrite cores in both states as it is powered on. As the magnets undergo hysteresis in either state, there should me a measurable difference from the opposite state that is approximately the opposite of its alternate state. Magnetic flux will be measured using a gauss meter with a range of 0.1 mG to 10 mG.

## Error Analysis

The readings given by the gauss meter will be compared three sources: the original paper on magnetic core memory<sup>1</sup>, the book “Square-Loop Ferrite Circuitry: Storage and Logic Techniques”, and its sister book “Magnetic Core Storage”. These three materials report a reading of the square-loop ferrite cores, when in a 1 or a 0 state, to be  $(1800 \pm 400) \times 10^{-4}$  gauss, which is within the range of the gauss meter. Therefore, the following error analysis can be conducted.

$$\begin{aligned} \% \text{ Error} &= \left| \frac{G_{\text{theoretical}} - G_{\text{experimental}}}{G_{\text{theoretical}}} \right| \times 100 \\ \% \text{ Error} &= \left| \frac{(1800 \pm 400) \times 10^{-4} \text{ G} - G_{\text{experimental}}}{(1800 \pm 400) \times 10^{-4} \text{ G}} \right| \times 100 \end{aligned}$$

Given the uncertainty for  $G_{\text{theoretical}}$ ,  $G_{\text{theoretical}}$  will be calculated such that the measured value is within 0.1 mG of the theoretical, readings permitting.

### 3 Results & Analysis

The created circuit, when powered on, works as follows:



fig 5. Real circuit logic gate diagram.

Which is a perfect match to the theoretical model listed above. Furthermore, the state of the circuit is preserved on a power cycle, which is also in line with the non-volatile properties of a square-loop ferrite core. In other words, the circuit functions exactly as expected.

The below readings were taken from a distance of no more than five centimeters. Additionally, the readings were recorded in a dim room isolated from electronics excluding the circuit's power supply. Due to the limitations of the gauss meter, readings are only accurate to 0.5 mG.



Table 2: Gauss readings

| Left core state  | Flux in gauss |
|------------------|---------------|
| 0                | 8 mG          |
| 1                | 8 mG          |
| Right core state | Flux in gauss |
| 0                | 8 mG          |
| 1                | 8.5 mG        |

fig 6. Image of the powered-on circuit with gauss readings.

When compared to the target rating of  $1.8 \pm 0.4$  mG, there is a clear discrepancy. Conducting an error analysis reveals the following:

$$\begin{aligned} \% \text{ Error}_{\text{Left}_0 \wedge \text{Right}_0} &= \left| \frac{2.2 \text{ mG} - 8 \text{ mG}}{2.2 \text{ mG}} \right| \times 100 = 264\% \\ \% \text{ Error}_{\text{Right}_1} &= \left| \frac{2.2 \text{ mG} - 8.5 \text{ mG}}{2.2 \text{ mG}} \right| \times 100 = 286\% \end{aligned}$$

## 4 Conclusion

Unfortunately, the calculated error casts too much doubt on the data for it to be considered accurate. The reason for the difference between this project's data and the data reported in the reports mentioned above is likely due to a number of errors.

- The gauss meter is too inaccurate to measure the flux from the magnetic cores.
- The data used in sources 1, 3, and 4 is accurate only for a certain size of magnetic cores, or in the computer configuration see in *fig. 1*.
- There was background interference from other electronics, outside lights, or other unidentifiable sources.
- The circuit itself or its power supply caused interference, which would be inseparable from the magnetic cores without more precise tools.

Also worth noting is that there was no change in polarity as there should have been according to the above section. The gauss meter used to measure the change in magnetic flux does not represent polarity, only magnitude, and therefore the polarity was not considered in recording or in the error analysis.

Considering the circuit functioned as intended, and similar readings were given for both states for either magnetic core, the most plausible explanation is that there is a fundamental flaw in the way the readings were recorded and compared. That said, the lab succeeded in demonstrating basic concepts of circuits, magnets, and data storage.



*fig 7. The full circuit, off. The cores still keep their state even without power.*

Should this lab be conducted again, a more accurate form of measurement should be used. Specifically, the flux density of the field should be calculated relative to the distance and size of the ferrite core, and then compared to the theoretical values in sources 1, 3, and 4.

## 5 References

1. Papian, William. 1954. Review of The MIT Magnetic-Core Memory, MIT.
2. John David Jackson, and Wiley. 2011. Classical Electrodynamics. New Delhi: Wiley India.
3. C.J. Quartly. 1962. Square-Loop Ferrite Circuitry: Storage and Logic Techniques. Pearson-Hall.
4. Raymond Stewert-Williams. 1959. Magnetic Core Storage. Telemeter Magnetics.
5. Soshin Chikazumi. 2009. Physics of Ferromagnetism. Oxford Oxford Univ. Press.
6. Visintin-Trento, A. 2001. “Maxwell’s Equations with Vector Hysteresis.”
7. Farhat, Hassan A. 2004. Digital Design and Computer Organization. Boca Raton, Fl: Crc Press.
8. “Project Whirlwind — the MIT 150 Exhibition.” n.d. <http://museum.mit.edu/150/21>.
9. IEEE Journal of Solid State Circuits. 1969, p 288-291. Modified by Brek Martin.