Jump to content

Williams tube

From Wikipedia, the free encyclopedia
(Redirected from Williams tubes)

James Pomerene with a Williams–Kilburn tube, a 5CP1A cathode ray tube, used in the memory array of the IAS computer circa 1951
Williams–Kilburn tube from an IBM 701 at the Computer History Museum, in Mountain View, California
Memory pattern on SWAC Williams tube CRT

The Williams tube, or the Williams–Kilburn tube named after inventors Freddie Williams and Tom Kilburn, is an early form of computer memory.[1][2] It was the first random-access digital storage device, and was used successfully in several early computers.[3]

The Williams tube works by displaying a grid of dots on a cathode-ray tube (CRT). Due to the way CRTs work, this creates a small charge of static electricity over each dot. The charge at the location of each of the dots is read by a thin metal sheet just in front of the display. Since the display faded over time, it was periodically refreshed. It operates faster than earlier acoustic delay-line memory, at the speed of the electrons inside the vacuum tube, rather than at the speed of sound. The system was adversely affected by nearby electrical fields, and required frequent adjustment to remain operational. Williams–Kilburn tubes were used primarily on high-speed computer designs.

Williams and Kilburn applied for British patents on 11 December 1946,[4] and 2 October 1947,[5] followed by United States patent applications on 10 December 1947,[6] and 16 May 1949.[7]

Working principle

[edit]

The Williams tube depends on an effect called secondary emission that occurs on cathode-ray tubes (CRTs). When the electron beam strikes the phosphor that forms the display surface, it normally causes it to illuminate. If the beam energy is above a given threshold (depending on the phosphor mix) it also causes electrons to be struck out of the phosphor. These electrons travel a short distance before being attracted back to the CRT surface and falling on it a short distance away. The overall effect is to cause a slight positive charge in the immediate region of the beam where there is a deficit of electrons, and a slight negative charge around the dot where those electrons land. The resulting charge well remains on the surface of the tube for a fraction of a second while the electrons flow back to their original locations.[1] The lifetime depends on the electrical resistance of the phosphor and the size of the well.

Writing

[edit]

The process of creating the charge well is used as the write operation in a computer memory, storing a single binary digit, or bit. A positively charged dot is erased (filling the charge well) by drawing a second dot immediately adjacent to the one to be erased (most systems did this by drawing a short dash starting at the dot position, the extension of the dash erased the charge initially stored at the starting point). This worked because the negative halo around the second dot would fill in the positive center of the first dot. A collection of dots or spaces, often one horizontal row on the display, represents a computer word. Increasing beam energy made the dots bigger and last longer, but required them to be further apart, since nearby dots would erase each other.

The beam energy had to be large enough to produce dots with a usable lifetime. This places an upper limit on the memory density, and each Williams tube could typically store about 256 to 2560 bits of data.

Because the electron beam is essentially inertia-free and can be moved anywhere on the display, the computer can access any location, making it a random access memory. Typically, the computer would load the memory address as an X and Y pair into the driver circuitry and then trigger a time base generator that would sweep the selected locations, reading from or writing to the internal registers, normally implemented as flip-flops.

Reading

[edit]

Reading the memory took place via a secondary effect caused by the writing operation. During the short period when the write takes place, the redistribution of charges in the phosphor creates an electrical current that induces voltage in any nearby conductors. This is read by placing a thin metal sheet just in front of the display side of the CRT. During a read operation, the beam first writes to the selected bit locations on the display. Those locations that were previously written to are already depleted of electrons, so no current flows, and no voltage appears on the plate. This allows the computer to determine there was a "1" in that location. If the location had not been written to previously, the write process will create a well and a pulse will be read on the sheet, indicating a "0".[1]

Reading a memory location creates a charge well whether or not one was previously there, thus destroying the original contents of that location. So any read has to be followed by a rewrite to reinstate the original data. In some systems this was accomplished using a second electron gun inside the CRT that could write to one location while the other was reading the next.

Refreshing

[edit]

Since the display would fade over time, the entire display had to be periodically refreshed using the same basic method. As the data is read and then immediately rewritten, this operation can be carried out by external circuitry while the central processing unit (CPU) was busy carrying out other operations. This refresh operation is similar to the memory refresh cycles of DRAM in modern systems.

Erasing

[edit]

Since the refresh process caused the same pattern to continually reappear on the display, there was a need to be able to erase previously written values. This was normally accomplished by writing to the display just beside the original location. The electrons released by this new write would fall into the previously written well, filling it. The original systems produced this effect by writing a small dash, which was easy to accomplish without changing the master timers and simply producing the write current for a slightly longer period. The resulting pattern was a series of dots and dashes. There was a considerable amount of research on more effective erasing systems, with some systems using out-of-focus beams or complex patterns.

Visibility of data

[edit]

Some Williams tubes were made from radar-type cathode-ray tubes with a phosphor coating that made the data visible, while other tubes were purpose-built without such a coating. The presence or absence of this coating had no effect on the operation of the tube, and was of no importance to the operators, since the face of the tube was covered by the pickup plate. If a visible output was needed, a second tube connected in parallel with the storage tube, with a phosphor coating, but without a pickup plate, was used as a display device.

Development

[edit]

Developed at the University of Manchester in England, it provided the program storage medium for the Manchester Baby, the first electronic stored-program computer, which first successfully ran a program on 21 June, 1948.[8] Rather than the Williams tube memory being designed for the Baby, the Baby was a testbed to demonstrate the reliability of the memory.[9][10] Tom Kilburn wrote a 17-instruction program to calculate the highest proper factor of numbers as large as 218. Tradition at the university has it that this was the only program Kilburn ever wrote.[11]

Williams tubes tended to become unreliable with age, and most working installations had to be hand tuned. By contrast, mercury delay-line memory was slower and not random access, as the bits were presented serially, which complicated programming. Delay lines also needed hand tuning, but did not age as badly and enjoyed some success in early digital electronic computing despite their data rate, weight, cost, thermal and toxicity problems. The Manchester Mark 1, which used Williams tubes, was successfully commercialised as the Ferranti Mark 1. Some early computers in the United States also used Williams tubes, including the IAS machine (originally designed for Selectron tube memory), the UNIVAC 1103, IBM 701, IBM 702 and the Standards Western Automatic Computer (SWAC). Williams tubes were also used in the Soviet Strela-1 and in the Japan TAC (Tokyo Automatic Computer).[12]

See also

[edit]

References

[edit]
Notes
  1. ^ a b c Kilburn, Tom (1990), "From Cathode Ray Tube to Ferranti Mark I", Resurrection, 1 (2), The Computer Conservation Society, ISSN 0958-7403, retrieved 15 March 2012
  2. ^ Brian Napper (25 November 1998). "Williams Tube". University of Manchester. Retrieved 1 October 2016.
  3. ^ "Early computers at Manchester University", Resurrection, 1 (4), The Computer Conservation Society, Summer 1992, ISSN 0958-7403, retrieved 7 July 2010
  4. ^ GB Patent 645,691
  5. ^ GB Patent 657,591
  6. ^ U.S. patent 2,951,176
  7. ^ U.S. patent 2,777,971
  8. ^ Napper, Brian, Computer 50: The University of Manchester Celebrates the Birth of the Modern Computer, archived from the original on 4 May 2012, retrieved 26 May 2012
  9. ^ Williams, F.C.; Kilburn, T. (September 1948), "Electronic Digital Computers", Nature, 162 (4117): 487, Bibcode:1948Natur.162..487W, doi:10.1038/162487a0, S2CID 4110351. Reprinted in The Origins of Digital Computers
  10. ^ Williams, F.C.; Kilburn, T.; Tootill, G.C. (February 1951), "Universal High-Speed Digital Computers: A Small-Scale Experimental Machine", Proc. IEE, 98 (61): 13–28, doi:10.1049/pi-2.1951.0004.
  11. ^ Lavington 1998, p. 11
  12. ^ United States Office of Naval Research (1953). A survey of automatic digital computers. Office of Naval Research, Dept. of the Navy. p. 87.
Bibliography

Further reading

[edit]
[edit]

Lua error in Module:Navbox at line 535: attempt to get length of local 'arg' (a number value). Lua error in Module:Navbox at line 535: attempt to get length of local 'arg' (a number value). Lua error in Module:Navbox at line 535: attempt to get length of local 'arg' (a number value).