IBM 1401
IBM 1401は、IBMが1959年10月5日に発表した可変ワード長十進コンピュータであり、大成功となった IBM 1400 シリーズの最初の機種であり、パンチカードに格納したデータを処理する電気機械式のタビュレーティングマシンの代替となることを意図していた。1万台以上が生産され、アメリカで新機種に取って代わられた後も後進国にリースまたは再販された。1971年2月8日に販売終了となった。
歴史
[編集]発表には次のような文言がある。
全てトランジスタ化された IBM 1401 データ処理システムは、従来パンチカード機器しか使えなかった中小企業でも手の届く価格で電子式データ処理システムの機能を提供する。高速カードパンチおよび読み取り、磁気テープ入出力、高速印刷、内蔵式プログラム、算術および論理演算能力といった機能がある。
1401は独立したシステムとしても、IBMパンチカード機器と連携した形でも、IBM 700 または 7000 シリーズのシステムの補助装置としても運用できる。[1]
1401の月額レンタル料は2,500ドルからとなっていた[2]。
IBMは発表後5週間で5,200の注文を受けており、その勢いはあらゆる予測を超えていた[3]。1961年末までにアメリカ国内で2000システムが納入されたが、これは全製造業者が出荷した全電子式プログラム内蔵コンピュータの4分の1にほぼ相当する。1960年代中ごろのピーク時、1万台を越える1401システムが設置されていた。実際、1960年代中ごろの世界の全てのコンピュータシステムのほぼ半数が1401型のシステムだった[3]。このシステムは1971年2月まで販売された[4]。
主に中小企業で使われた IBM 1401 は、メインフレームのオフライン周辺制御装置としても多く使用された。この形態のシステムでは大型機(IBM 7090 など)は入出力を全て磁気テープで行い、1401 は他の形式の入力データ(パンチカードなど)を磁気テープに変換したり、出力テープの内容を他の周辺機器(1402カードパンチャーや1403ラインプリンタなど)に出力するのに使われた。
ジョン・ハーンストラ率いる1401部門は市場の要望に応じて 1401 を大規模化するサポート(たとえば IBM 1410)は継続していたが、1964年に全てのリソースをSystem/360に集約するという決定がなされ、1400シリーズはやや唐突に終わることになった。360が1401と非互換であったため、1400シリーズ互換の Honeywell 200シリーズとの競合が生じたため、IBMはマイクロコードをROMの形式で360の一部モデルに搭載し、1401の命令をエミュレートできるようにした[5]。
カリフォルニア州マウンテンビューのコンピュータ歴史博物館にて2台の1401システムが動作可能な状態に復元され、当時(あるいは現在のデータセンター)のような「上げ底」の床で配線を隠した状態で展示されている[6][7]。
アーキテクチャ
[編集]1401では各英数字を6ビットで表現し、各ビットを B, A, 8, 4, 2, 1 と呼ぶ。B,A ビットは「ゾーン」ビット、8,4,2,1 のビット群は「数字」ビットと呼ぶ。これらの呼称はIBMの80欄パンチカードから採られている。
- 1から9の数字については、ゾーンビットをゼロとし、数字ビット列でBCDで符号化している。数字の0は数字ビット列を全てゼロにするのではなく、8,2 を1にする。
- アルファベットではソーンビットと数字ビットを使い、80欄パンチカードでの文字コードに対応させている。パンチカードの上3列を12-11-0ゾーンと呼ぶが、12 を B,Aビット、11 を B ビット、0 を A ビットに対応させ、残る1から9の列を数字ビットに対応させた。従って、例えばAという文字はパンチカード上は 12.1 だが、これがメモリ上では B,A,1 と符号化される。
- 他の文字の符号化については、文字コードと命令コードの節を参照。
IBMは1401の文字コードをBCDと称していたが、実際のところこの用語は十進の数字の符号化しか説明していない。1401の英数字の照合順序はパンチカードの称号順序と互換となっている。
記憶装置上では、この6ビットにさらに2ビットが付属し、C ビットは 「odd パリティチェック」であり、M ビットは「ワードマーク」ビットである。
メモリ上、これらビットは以下のようなフォーマットで配置される:
C B A 8 4 2 1 M
1401のメモリ構成は 1.4K、2K、4K、8K、16K の5種類あった(ごく一部の1401は特注で32Kまで拡張された)[※ 1]。メモリは文字単位でアドレス指定可能であり、アドレス範囲は0から15999までだった。
一部命令は特定のメモリ位置を使用するが、それらの位置は予約されているわけではなく、他の用途にも使用可能である。Read a card 命令は80欄ぶんのデータをパンチカードから読み取り、メモリ位置 001-080 に格納する。インデックスレジスタはメモリ上に3本あり、それぞれ 087-089、092-094、097-099 の位置である。Punch a card 命令は 101-180 の位置の内容をパンチカードにパンチする。Write a line 命令は 201-332 の位置の内容をプリンターに出力する。
1401の命令フォーマットは次の通りである。
Opcode with [A-or-I-or-unit-address [B-address]] [modifier] word mark
命令コード (Opcode) は1文字である。メモリアドレス("I" は分岐先アドレス、"A" と "B" はデータのアドレス)と装置アドレスは3文字で表される。命令コードの修飾子 (modifier) は1文字である。以上から命令の長さは、1文字、2文字、4文字、5文字、7文字、8文字がある。多くの命令は後続文字(通常、次の命令の命令コード)にワードマークを必要とする。
命令一覧は、文字コードと命令コードの節を参照。
命令で使用するメモリアドレスは3文字だが、これは5文字で表されるメモリアドレスを符号化したものである。5文字アドレスの下3桁 000 から 999 までは3文字の数字ビット列を使って指定する。最上位の桁を表す文字のゾーンビットがその3桁への加算値を表しており、A なら 1000、B なら 2000、B,A なら 3000 を加算するので、0から3,999番地までを表現できる。さらに最下位の桁を表す文字のゾーンビットで、A なら 4000、B なら 8000、B,A なら 12000 を加算するので、最大16,000文字までのメモリ位置を指定できる。例えば3文字アドレス "I99" は 3000 + 999 であり、3,999番地を指している。
アドレスの真ん中の文字のゾーンビットはオプション機能のインデックスレジスタを指定するのに使用される。
A-address と B-address が指しているオペランドは、1文字、可変長フィールド、可変長レコードの場合がある。可変長フィールドを指す場合はアドレスの大きい端(数値の場合は最下位の桁)を指し、終端は最後の文字(最上位の桁)にワードマークをセットすることで示す。可変長フィールドの長さには制限がなく、メモリの許す限り長いフィールドを使用可能である。可変長フィールドを扱える命令としては、四則演算(Add、Subtract、Multiply、Divide)と比較命令 (Compare) と文字列転送(変換)命令(Move Characters to A or B Word Mark、Move Characters and Edit)がある。1つ以上の可変長フィールドで可変長レコードを構成できる。可変長レコードを指す場合はアドレスの大きい端を指し、フィールドはワードマーク付きの Group Mark 文字で区切り、レコード終端(アドレスの一番小さい位置)に Record Mark 文字を置く。Move Characters to Record or Group Mark という命令でレコードをまとめたブロックを作ることができる。
アドレスレジスタには命令実行でアクセスしたオペランドのアドレスが残るので、連続するオペランドを使って処理をする場合、アドレスを省略して連鎖させることができる。例えば、連続するデータフィールド群の加算を行うコードが "A 700,850", "A 695,845", "A 690,840" だったとする。これを連鎖させて "A 700,850", "A", "A" のようにアドレス指定を省略することができる[8]。
ブートとサンプルプログラム
[編集]IBM 1402 (パンチカード読み取り/パンチ装置)のLOADボタンが押下されると、カードがバッファ(メモリ上の 001-080 番地)に読み込まれる。このとき001番地の文字にワードマックがセットされ(カードの最初の命令を有効にする)、002-080番地のワードマークはクリアされる。先頭の命令は常に2オペランド(7文字)の Set Word Mark 命令であり、これは後続の命令コードにワードマークがなくとも実行可能で、後続の2命令にワードマークをセットできる。このようにしてカードデッキ内の命令列の実行が継続され、プログラムをメモリにロードし、ワードマークをセットし、最後にプログラムの開始アドレスに分岐する。
パンチカード1枚に収まる実用的なプログラムもある。よく使われたのは後続のカードデッキの内容をそのままプリンターに出力するプログラムや後続のカードデッキをそのままカードパンチで複写するプログラムなどである。Tom Van Vleck のウェブサイト[9]には、"HELLO WORLD" とプリンターに出力するパンチカード1枚に収まるプログラムが紹介されている。
- ,008015,022029,036043,050054,055062,063065,069080/333/M0792502F1.065HELLO WORLD
上述のようにLOADボタンを押下すると001番地(先頭の ",")から実行を開始する。"," は命令コードとしては Set Word Mark 命令である。それが7命令続いており、読み込んだ全命令にワードマークを設定する。"/" は Clear Storage 命令で、オペランド333で指定されたプリンター出力エリアの 333-300 の範囲をクリアし、次の "/" で連鎖アドレスを使って 299-200 の範囲をクリアする。次の命令コード "M" は Move Charactors to Word Mark 命令であり、079番地から250番地へワードマークまで文字列転送を行うが、これが "HELLO WORLD" をプリンター出力エリアにコピーすることになる。次の "2" が Write line 命令で印字を行い、次の "F" が Control Carriage 命令(修飾子が 1)でプリンターにページ送りをさせ、次の "." が Halt 命令となっていて停止する。065はHalt命令の番地であり、STARTボタンを押下しても停止したままとするようになっている。
ハードウェアの実装
[編集]1401の論理回路のほとんどは Diode-transistor logic(DTL)であり、IBMはこれをCDTLと称した。IBMは他にも以下のような回路を使用した。
- Alloy - 一部の論理回路にも使われたが、大抵の場合論理回路以外で使用。アロイ型トランジスタを使用。
- CTRL - Resistor-transistor logic(RTL)の一種
後のアップグレードでは「ドリフト」型トランジスタ(1953年にハーバート・クレーマーが発明)を使用したDTLで高速化を図っている。これをIBMはSDTLと称した。典型的な論理回路の電圧レベルは次の通り:
- S & U レベル: high - 0Vから-0.5V, low - -6Vから-12V
- T レベル: high - 6Vから1V, low - -5.5Vから-6V
回路は紙エポキシ樹脂の片面実装プリント基板で構成されていた。基板は2.5インチ×4.5インチで16ピンの金メッキコネクタが1つあるものか、5.375インチ×4.5インチで16ピン金メッキコネクタが2つあるものが使われた。IBMはこれをSMSカード(Standard Modular System)と称した。ひとつのカード上の論理回路は7400シリーズなどと同等レベルである(小さいカードには3から5個の論理ゲートか1、2個のフリップフロップ、大きいカードには最大20個の論理ゲートか4個のフリップフロップが実装された)。
これらのSMSカードは、IBMがgatesと称したラック内のソケットに挿入された。
当時の多くのマシンと同様、1401は磁気コアメモリを使用している。コアの直径は約1mmで、4本のワイヤが通っている。1枚にコアが4000個(4096個ではない)実装されており、コア1個が1ビットに対応している。したがって、そのようなものを8枚使って4000文字ぶんの記憶装置となる[10]。そのようなモジュールが1個、1401の主筐体にある。追加のメモリを装備するには 1406 Core Memory Unit という別筐体が必要である。メモリアクセスは文字単位で、1401は基本サイクルタイムである11.5μ秒の間に1文字をリードまたはライトできる[11]。命令のタイミングは全てこの基本サイクルタイムの倍数となっている[12]。
ソフトウェア
[編集]1401向けソフトウェアとしては、次のようなものがあった。
- IBM 1401 Symbolic Programming System (SPS) - 単純なアセンブラ。SPS-1 は1.4Kメモリのマシンでも動作可能。SPS-2 は4K以上のメモリが必要。
- Autocoder - より高度なアセンブラ。4Kメモリと4台のテープ装置を必要とする。
- FARGO (Fourteen-o-one [1401] Automatic Report Generation Operation) - RPGの前身。4Kメモリが必要。
- FORTRAN II - 8Kメモリが必要。後のPコードのようなコードを生成し、インタプリタで実行する方式で、小規模なメモリで実行可能[13]。
- FORTRAN IV - 12Kメモリと4台のテープ装置か1台の IBM 1311 ディスク装置を必要とする。
- COBOL - 4Kメモリと4台のテープ装置を必要とする。
- IBM RPG (Report Program Generator) - Basic RPG は4Kメモリで動作。
IBM 1401 から生まれた芸術
[編集]2006年10月、アイスランド出身の前衛音楽家ヨハン・ヨハンソンが4ADから IBM 1401, A User's Manual というアルバムをリリースしている[14]。アイスランド初のコンピュータの保守技術者だった彼の父と、その友人でアイスランド初のプログラマとなった Elias Davidsson が1964年に作った曲をベースとしている。ヨハン・ヨハンソンは電子音や父が保管していた IBM 1401 が歌った歌を録音したオープンリールの録音テープなども加え、それをオーケストラ向けに書き直して長くした[15]。
1401 の文化
[編集]IBMが提供した最初のアセンブラ Symbolic Programming System は1,400文字のメモリしか搭載していない最小構成のマシンでも動作するよう設計されている。そのため、1パス目で入力命令毎にパンチカードを1枚ずつパンチし、そのカードデッキを2パス目でロードするようにしている。シカゴ大学など多くの場所で、より一般的な4Kメモリを使用し1パス目の出力がパンチカード1枚に複数の命令を入れるようになったアセンブラを使用した。他にも1パス目の出力をメモリに保持するアセンブラも書かれた。
CPUの上にトランジスタラジオを置くと雑音で音楽を奏でることができたため、様々な音楽を演奏するデモプログラムが作られた[16]。また、プリンターで "X" と "0" などを並べて印字することでキッチュな絵を描くというデモプログラムも作られた[17]。
1401は単純だったため、それなりに負荷をかけても信頼性を保つことができた。アメリカ陸軍は IBM 1401 をベトナムなどで多用した。
1970年代にはインドやパキスタンで多く導入され、1980年代にも使われ続けていた。現在のインド人およびパキスタン人のIT起業家の一部は 1401 でコンピュータに触れたのである。例えば、パキスタン初のコンピュータは 1401 で、パキスタン国際航空が導入した[18]。
文字コードと命令コード
[編集]以下の表はキャラクターを辞書的順序で示したものである。
- 注: ワードマークがセットされている場合、C ビットが示されているのとは反対の値になる。その場合、C ビットはマシンが自動的に設定/チェックするので、通常はプログラマが気にする必要はない。補助制御パネルから入力する際には操作者が C ビットを気にする必要がある。プログラマはデバッグの際に素早くパッチを当てるのに補助制御パネルを使うことがあった。
BCD文字 | Print-A | Print-H | カード | BCD | 操作 | 定義その他 |
---|---|---|---|---|---|---|
空白 | C | |||||
. | . | . | 12-3-8 | BA8 21 | Halt | |
¤ | ¤ | ) | 12-4-8 | CBA84 | Clear Word Mark | Lozenge |
[ | 12-5-8 | BA84 1 | ||||
< | 12-6-8 | BA842 | Less Than | |||
12-7-8 | CBA8421 | Group Mark | ||||
& | & | + | 12 | CBA | ||
$ | $ | $ | 11-3-8 | CB 8 21 | ||
* | * | * | 11-4-8 | B 84 | ||
] | 11-5-8 | CB 84 1 | ||||
; | 11-6-8 | CB 842 | ||||
Δ | 11-7-8 | B 8421 | Delta (モード変更) | |||
- | - | - | 11 | B | ||
/ | / | / | 0-1 | C A 1 | Clear Storage | |
, | , | , | 0-3-8 | C A8 21 | Set Word Mark | |
% | % | ( | 0-4-8 | A84 | Divide | オプション機能 |
ˠ | 0-5-8 | C A84 1 | Word Separator | |||
\ | 0-6-8 | C A842 | Left Oblique | |||
⧻ | 0-7-8 | A8421 | Tape Segment Mark | |||
ƀ | ‡ | ‡ | N/A 0 |
A | カードからは読めない。 ゼロとしてパンチ。 テープでは Blank with "even-parity" | |
# | # | = | 3-8 | 8 21 | Modify Address | オプション (4000文字分以上のメモリを要する) |
@ | @ | ' | 4-8 | C 84 | Multiply | オプション機能 |
: | 5-8 | 84 1 | ||||
> | 6-8 | 842 | Greater Than | |||
√ˉ | 7-8 | C 8421 | Tape Mark | |||
? | & | & | 12-0 | CBA8 2 | Zero and Add | Plus Zero |
A | A | A | 12-1 | BA 1 | Add | |
B | B | B | 12-2 | BA 2 | Branch | |
C | C | C | 12-3 | CBA 21 | Compare | |
D | D | D | 12-4 | BA 4 | Move Numerical | (ビット) |
E | E | E | 12-5 | CBA 4 1 | Move Characters and Edit | |
F | F | F | 12-6 | CBA 42 | Control Carriage | (プリンタ) |
G | G | G | 12-7 | BA 421 | ||
H | H | H | 12-8 | BA8 | Store B-Address Register | オプション機能 |
I | I | I | 12-9 | CBA8 1 | ||
! | - | - | 11-0 | B 8 2 | Zero and Subtract | Minus Zero |
J | J | J | 11-1 | CB 1 | ||
K | K | K | 11-2 | CB 2 | Select Stacker | (カード) |
L | L | L | 11-3 | B 21 | Load Characters to Word Mark | |
M | M | M | 11-4 | CB 4 | Move Characters to Word Mark | |
N | N | N | 11-5 | B 4 1 | No Operation | |
O | O | O | 11-6 | B 42 | ||
P | P | P | 11-7 | CB 421 | Move Characters to Record or Group Mark |
オプション機能 |
Q | Q | Q | 11-8 | CB 8 | Store A-Address Register | オプション機能 |
R | R | R | 11-9 | B 8 1 | ||
‡ | ‡ | ‡ | 0-2-8 | A8 2 | Record Mark | |
S | S | S | 0-2 | C A 2 | Subtract | |
T | T | T | 0-3 | A 21 | ||
U | U | U | 0-4 | C A 4 | Control Unit | (テープ) |
V | V | V | 0-5 | A 4 1 | Branch if Word Mark and/or Zone |
|
W | W | W | 0-6 | A 42 | Branch if Bit Equal | オプション機能 |
X | X | X | 0-7 | C A 421 | Move and Insert Zeros | オプション機能 |
Y | Y | Y | 0-8 | C A8 | Move Zone | (ビット) |
Z | Z | Z | 0-9 | A8 1 | Move Characters and Suppress Zeros |
|
0 | 0 | 0 | 0 | C 8 2 | ||
1 | 1 | 1 | 1 | 1 | Read a Card | |
2 | 2 | 2 | 2 | 2 | Write a Line | |
3 | 3 | 3 | 3 | C 21 | Write and Read | |
4 | 4 | 4 | 4 | 4 | Punch a Card | |
5 | 5 | 5 | 5 | C 4 1 | Read and Punch | |
6 | 6 | 6 | 6 | C 42 | Write and Punch | |
7 | 7 | 7 | 7 | 421 | Write, Read, and Punch | |
8 | 8 | 8 | 8 | 8 | Start Read Feed | オプション機能 |
9 | 9 | 9 | 9 | C 8 1 | Start Punch Feed | オプション機能 |
注釈
[編集]- ^ 本項目では K を1000の意味で用いており、1024ではない。
出典
[編集]- ^ “1401 Data Processing System”. IBM Archives (1959年10月5日). 2010年6月2日閲覧。
- ^ Columbia University, Computing History Project
- ^ a b Spicer, Dag. “Back to Life: The story behind CHM's IBM 1401 Restoration”. Computer History Museum. 2011年5月27日閲覧。
- ^ “FAQ's for Products and Services”. IBM Archives. 2010年6月2日閲覧。
- ^ Pugh, Emerson W. (1995). Building IBM: Shaping an Industry and Its Technology. MIT. p. 273. ISBN 0-262-16147-8
- ^ “1401 Restoration Project”. 2012年7月24日閲覧。
- ^ “1401 "Rebuilding the IBM," by Philip E. Ross, IEEE Spectrum, November 2009”. 2012年7月24日閲覧。
- ^ IBM (April 1962). IBM 1401 Data Processing System: Reference Manual. p. 20. A24-1403-5
- ^ “Tom Van Vleck: 1401s I have known”. 2012年7月24日閲覧。
- ^ Rob Storey. “Core memory frame from an IBM 1401”. 2012年7月15日閲覧。
- ^ “The IBM 1401”. IBM 1401 Restoration Project. Computer History Museum. 2012年7月15日閲覧。 “The 1401’s clock frequency is 86,957 cycles per second, or about 87 kiloHertz! This corresponds to an 11.5 micro-second system clock cycle time. ... The 1401 CPU does everything in a character-serial manner. In order to add say two N-digit numbers, the CPU takes several cycles to fetch the instruction itself and then one cycle for every character of the instruction’s two operands or arguments, or 2N cycles total.”
- ^ IBM Corporation (1961年). “IBM 1401 Principles of Programming, Section 7” (PDF). IBM Personal Study Program. IBM Corporation. p. 19. 2012年7月15日閲覧。 “The timing of the IBM 1401 is described in terms of the time required for one complete core storage cycle, which is 11.5 microseconds ... The time required for any internal processing instruction is always a multiple of this interval of time.”
- ^ John A. N. Lee(著)、The Anatomy of a Compiler、1968年、Appendix
- ^ “Jóhann Jóhannsson profile”. 4AD web site. 2010年6月2日閲覧。
- ^ “Jóhann Jóhannsson: IBM 1401, A User's Manual”. work's web site. 2010年6月2日閲覧。
- ^ “1401-music-Movie”. 2012年7月24日閲覧。
- ^ Gansing, Kristoffer (2007年). “Working Paper version - Humans Thinking Like Machines - Incidental Media Art in the Swedish Welfare State”. University of Malmö, School of Arts & Communication. 2024年2月24日閲覧。 A full version to be published in Place Studies in Art, Media, Science and Technology, VDG Weimar , 2009
- ^ “History of PIA”. 2012年7月24日閲覧。
参考文献
[編集]- Bashe, Charles J.; Johnson, Lyle R; Palmer, John H.; Pugh, Emerson W. (1986). IBM's Early Computers. MIT. pp. 717. ISBN 0-262-02225-7 Chapter 12 Broadening the Base pages 465-494, 1401および1403開発の歴史
- IBM (April 1966) (PDF). IBM 1401 System Summary. A24-1401-1 機能概要、コンポーネント概要、コンフィギュレーションなどの説明
- IBM (April 1962) (PDF). IBM 1401 Data Processing System: Reference Manual. A24-1403-5
関連項目
[編集]外部リンク
[編集]- IBM 1401 documents on bitsavers.org
- A Century of Smart: The IBM 1401 (1959). IBM Social Media. 16 November 2009. 2009年11月17日閲覧。 2009年ニューヨーク州エンディコットで行われた1401開発者の同窓会で撮影されたビデオを編集したもの。当時の販促映画からの映像もある。
- IBM 1401 videos and sounds
- 1401s I have Known, Tom Van Vleck
- Haines, L. H. (1965). “Serial compilation and the 1401 FORTRAN compiler”. IBM Systems Journal 4 (1): 73-80. doi:10.1147/sj.41.0073 .. This article was reprinted, edited, in both editions of
- Lee, John A. N. (1967(1st), 1974(2nd)). Anatomy of a Compiler. Van Nostrand Reinhold の再編集版