IBM 1401

IBMが1959年10月5日に発表した可変ワード長十進コンピュータ ウィキペディアから

IBM 1401

IBM 1401は、IBM1959年10月5日に発表した可変ワード長十進コンピュータであり、大成功となった IBM 1400 シリーズの最初の機種であり、パンチカードに格納したデータを処理する電気機械式のタビュレーティングマシンの代替となることを意図していた。1万台以上が生産され、アメリカで新機種に取って代わられた後も後進国にリースまたは再販された。1971年2月8日に販売終了となった。

Thumb
IBM 1401 Data Processing System. 左から、1402 カードリーダ/パンチ、1401処理装置、1403プリンター

歴史

Thumb
コンピュータ歴史博物館にて、ボランティアが IBM 1401 を修理している様子
Thumb
引き出されたカードケージ(IBM用語では gates)のクローズアップ。SMS回路基板が並んでいるのが見える。

発表には次のような文言がある。

全てトランジスタ化された 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]

アーキテクチャ

要約
視点
Thumb
IBM 1401 の制御パネル。下部は補助制御パネル。

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ゾーンと呼ぶが、12B,Aビット、11B ビット、0A ビットに対応させ、残る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文字、可変長フィールド、可変長レコードの場合がある。可変長フィールドを指す場合はアドレスの大きい端(数値の場合は最下位の桁)を指し、終端は最後の文字(最上位の桁)にワードマークをセットすることで示す。可変長フィールドの長さには制限がなく、メモリの許す限り長いフィールドを使用可能である。可変長フィールドを扱える命令としては、四則演算(AddSubtractMultiplyDivide)と比較命令 (Compare) と文字列転送(変換)命令(Move Characters to A or B Word MarkMove 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ボタンを押下しても停止したままとするようになっている。

ハードウェアの実装

Thumb
IBM 1403 高速ラインプリンター(ドイツ、IBM博物館)

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
Thumb
1401で使われていた種類のSMS基板

回路は紙エポキシ樹脂の片面実装プリント基板で構成されていた。基板は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 ...
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 オプション機能
閉じる

注釈

  1. 本項目では K を1000の意味で用いており、1024ではない。

出典

参考文献

関連項目

外部リンク

Wikiwand - on

Seamless Wikipedia browsing. On steroids.