Difference between revisions of "IMLAC PDS-1"
|  (Stub.) |  (→External links:  Good caption for link; add front panel image) | ||
| (12 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| − | + | The '''IMLAC PDS-1''' was a very early [[workstation]] (1970, well before the [[Xerox Alto]]).  PDS means Programmable Display System.  It generally did not have any [[secondary storage]], and was mostly used only as a [[terminal]] on a larger system, communicating with it via an [[asynchronous serial line]]. | |
| − | {{stub}} | + | This computer was host to the first version of the game [[Maze War]].  As a terminal, it was used to develop the game [[Zork]], and edit the manuscript for the book ''Gödel, Escher, Bach''. | 
| + | |||
| + | It had a [[vector graphics]] [[display]], controlled by a [[display program]] in the machine's [[main memory]] ([[core memory]], at that point in time). It also included a small 16-bit [[minicomputer]]; the two shared access to the main memory, with the display processor having priority for access. The [[Central Processing Unit|CPU]] (said by many to be reminiscent of a [[PDP-8 family|PDP-8]]) was built out of [[74 series]] [[integrated circuit|ICs]], and had a classical [[front panel]] for control. The display was a [[cathode ray tube|CRT]]. | ||
| + | |||
| + | There were several different variants; the original 'PDS-1' had an [[instruction]] [[cycle time]] of 2.0 μsec, and the 'PDS-1D' had a cycle time of 1.8 μsec, but seems otherwise to have been almost identical. There were also 'Alpha' and 'Graphics' versions (see below); the PDS-1D was a 'Graphics' machine.  The last model was called PDS-4, with a memory cycle of "less than a microsecond" and optional floating point hardware. | ||
| + | |||
| + | ==Differences between Alpha and Graphics machines== | ||
| + | |||
| + | The first type of the IMLAC PDS-1 was called an ''Alpha machine'', and had a somewhat less capable display processor than the later ''Graphics machines''.  There is no surviving documentation for the Alpha machine, but the details have been reverse engineered by Zachary Harper from the listing for the '''[[Freeway Crossing]]''' game. | ||
| + | |||
| + | On an Alpha machine, the D LDXA and D LDYA instructions load bits 4 to 10 into the accumulator MSB.  On a Graphics machine, bits 6-11 load into the MSB.  On both machines, bits 12-16 are loaded into the LSB, and the least significant "½ point" bit is cleared. | ||
| + | |||
| + | On an Alpha machine, beam deflection from the MSB is scaled up by 9 LSB units.  On a Graphics machine, the MSB is scaled up by 16 LSB units.  (The LSB least significant bit is 0.5 units.) | ||
| + | |||
| + | On an Alpha machine, incrementing or decrementing the LSB does not add any carry to the MSB.  The LSB can go outside 0-15 units; exactly by how much is unknown.  On an Graphics machine, going outside 0-15 wraps around and carries to the MSB. | ||
| + | |||
| + | On an Alpha machine, incrementing or decrementing the MSB is done according to the scale factor.  On a Graphics machine, it's done by 1.  | ||
| + | |||
| + | {{semi-stub}} | ||
| + | |||
| + | ==External links== | ||
| + | |||
| + | * [http://www.bitsavers.org/pdf/imlac/ imlac] - documentation at [[Bitsavers]] | ||
| + | ** [http://www.bitsavers.org/pdf/imlac/PDS-1_TechnicalMan.pdf IMLAC PDS-1 Programmable Display System Preliminary Technical and Operator Manual] | ||
| + | ** [http://www.bitsavers.org/pdf/imlac/PDS-1D_ProgrammingGuide.pdf IMLAC PDS-1D Programming Guide] <!-- also http://www.ubanproductions.com/ImlacDocs/PDS-1D_ProgrammingGuide.pdf --> | ||
| + | * [http://www.ubanproductions.com/imlac.html Imlac Anatomy] - large collection of very good images of a PDS-1D; details of getting Maze War running at the 2004 7th annual West Coast Vintage Computer Festival | ||
| + | ** [http://www.ubanproductions.com/imlac_sw.html Imlac Software Library] - includes many IMLAC documents, not all of which are at Bitsavers (above) | ||
| + | ** [http://www.ubanproductions.com/Images/imlac2.jpg The programmer's console] - large image of the front panel | ||
| + | * [http://www.blinkenlights.com/classiccmp/imlac/ Imlac PDS-1] | ||
| + | * [https://github.com/larsbrinkhoff/imlac-software/blob/master/washington/Screen%20Addressing%20in%20FREEWAY%20(1971)%20for%20the%20IMLAC%20PDS-1.pdf Screen Addressing in FREEWAY (1970) for the IMLAC PDS-1] | ||
| + | |||
| + | [[Category: Workstations]] | ||
Latest revision as of 21:51, 27 June 2025
The IMLAC PDS-1 was a very early workstation (1970, well before the Xerox Alto). PDS means Programmable Display System. It generally did not have any secondary storage, and was mostly used only as a terminal on a larger system, communicating with it via an asynchronous serial line.
This computer was host to the first version of the game Maze War. As a terminal, it was used to develop the game Zork, and edit the manuscript for the book Gödel, Escher, Bach.
It had a vector graphics display, controlled by a display program in the machine's main memory (core memory, at that point in time). It also included a small 16-bit minicomputer; the two shared access to the main memory, with the display processor having priority for access. The CPU (said by many to be reminiscent of a PDP-8) was built out of 74 series ICs, and had a classical front panel for control. The display was a CRT.
There were several different variants; the original 'PDS-1' had an instruction cycle time of 2.0 μsec, and the 'PDS-1D' had a cycle time of 1.8 μsec, but seems otherwise to have been almost identical. There were also 'Alpha' and 'Graphics' versions (see below); the PDS-1D was a 'Graphics' machine. The last model was called PDS-4, with a memory cycle of "less than a microsecond" and optional floating point hardware.
Differences between Alpha and Graphics machines
The first type of the IMLAC PDS-1 was called an Alpha machine, and had a somewhat less capable display processor than the later Graphics machines. There is no surviving documentation for the Alpha machine, but the details have been reverse engineered by Zachary Harper from the listing for the Freeway Crossing game.
On an Alpha machine, the D LDXA and D LDYA instructions load bits 4 to 10 into the accumulator MSB. On a Graphics machine, bits 6-11 load into the MSB. On both machines, bits 12-16 are loaded into the LSB, and the least significant "½ point" bit is cleared.
On an Alpha machine, beam deflection from the MSB is scaled up by 9 LSB units. On a Graphics machine, the MSB is scaled up by 16 LSB units. (The LSB least significant bit is 0.5 units.)
On an Alpha machine, incrementing or decrementing the LSB does not add any carry to the MSB. The LSB can go outside 0-15 units; exactly by how much is unknown. On an Graphics machine, going outside 0-15 wraps around and carries to the MSB.
On an Alpha machine, incrementing or decrementing the MSB is done according to the scale factor. On a Graphics machine, it's done by 1.
External links
- imlac - documentation at Bitsavers
-  Imlac Anatomy - large collection of very good images of a PDS-1D; details of getting Maze War running at the 2004 7th annual West Coast Vintage Computer Festival
- Imlac Software Library - includes many IMLAC documents, not all of which are at Bitsavers (above)
- The programmer's console - large image of the front panel
 
- Imlac PDS-1
- Screen Addressing in FREEWAY (1970) for the IMLAC PDS-1

