IBM 704[1]は、IBM1954年4月に発表した、浮動小数点数演算ハードウェアを搭載した初の量産型コンピュータである[2]

NACA の IBM 704 (1957)
IBM 704。IBM 727 磁気テープ装置と IBM 780 CRTディスプレイが見える。(Image courtesy of LLNL.)
レオナルド・ダ・ヴィンチ記念国立科学技術博物館(ミラノ)のIBM 704

IBM 704 Manual of operation (下記外部リンク参照)にはこう記されている[3]

タイプ704電子データ処理機は大規模で高速な電子計算機であり、シングルアドレス型の内蔵プログラムによって制御される。

このように、当時の704は「かなり複雑な数学を扱える唯一のコンピュータ」と見なされていた[4]。IBM 704は、アーキテクチャと実装の面で、以前のIBM 701よりも大幅に改良されていた。701と同様に、704は真空管論理回路と36ビットのバイナリワードを使用した。

701からの変更点としては、ウィリアムス管の代わりに磁気コアメモリを使用したこと、浮動小数点演算命令、15ビットアドレス指定、3つのインデックスレジスタの追加などが含まれている。これらの新機能をサポートするために、命令は完全な36ビットワードに拡張された。701と互換性のない新しい命令セットは、その後のIBM 700/7000 シリーズの科学技術計算系コンピュータの基本となった。

IBMは、704は毎秒40,000個の命令を実行でき、1秒間に最大12,000個の浮動小数点加算を実行できるとした[2]。IBMは、1955年から1960年までに123台の704システムを販売した[5]

歴史的なできごと 編集

プログラミング言語FORTRAN[6]LISP[7]は704のために最初に開発された。後にSHARE (英語版がSHARE Assembly Programとして配布したSAP assembler-Symbolic Assembly Programと同様である。

最初のコンピュータ音楽プログラムであるMUSIC-Iは、マックス・マシューズによってIBM 704で開発された。

1961–1962年、物理学者 John Larry Kelly, Jr と Carol C. Lochbaum はベル研究所で IBM 704 を使用して音声合成を行った。[8] これはKelly–Lochbaumモデルと呼ばれる、ソフトウェア上でデジタル化された「声道アナログ・モデル」(声道を断面積の変わる複数の音響管(acoustic tube)で表現し進行波を計算する導波管モデル=初期のWaveguideシンセシス物理モデル音源))で、[9] 1961年に歌(デイジー・ベル)も歌わせている(伴奏にマックス・マシューズのプログラムを使用)。[10][11]このデモンストレーションをアーサー・C・クラークが実際に聴き[12]、『2001年宇宙の旅』でHAL 9000が同じ歌を歌うクライマックスのシーンが生まれた[13]

MITの数学講師であるエド・ソープは、彼のブラックジャックのゲーム理論を発展させながら、勝つ確率を調査するための研究の道具として IBM 704 を使用した[14][15]。彼はFORTRANを使って研究モデルの方程式を定式化した。

MIT計算センターのIBM 704は、1957年秋に、スミソニアン天体物理観測所Operation Moonwatch の公式トラッカーとして使用された。IBMは、スミソニアン天体物理観測所の科学者や数学者が衛星軌道の計算を行うのを支援するために、4人のスタッフ科学者を派遣した。

ロスアラモス国立研究所(LASL)は、バッチ処理を可能にするSLAMと名付けられた初期のモニター (英語版を開発した[16]

1959年3月12日、IBM 704は、日本の気象庁数値予報の導入に初めて用いられたコンピューターとなった[17]。数値予報とは、解析する大気の領域を有限個の格子点に分解し、それぞれの格子点に初期値を与えて、大気の状態を表す微分方程式を数値的に解く方法で、膨大な繰り返し計算を必要とする。そのため、計算機の構造上、繰り返し計算に便利な仕組みを多く持つIBM 704が選定された。

レジスタ 編集

 
IBM 704の真空管回路モジュール

IBM 704 の持つレジスタは次の通りである。

  • アキュムレータ×1、38ビット
  • 積・商レジスタ×1、36ビット
  • デクリメントレジスタ×3、15ビット

デクリメントレジスタとはインデックスレジスタであり、ベースアドレスからその値を引いて実効アドレスとするため、このように呼ばれた。1命令で3つのデクリメントレジスタ全てを関与させることもできる。命令にある3ビットのタグフィールドは各ビットがそれぞれデクリメントレジスタに対応しているので、複数をONにすれば複数のデクリメントレジスタをアドレス計算に使用できる。しかし、複数のインデックス・レジスタが選択された場合、デクリメントが行われる前に、それらの内容は加算されるのではなく、一緒に加算される。この動作は、IBM 709IBM 7090などの後の科学アーキテクチャのマシンでは、IBM 7094まで続いた。1962年に導入されたIBM 7094では、インデックス・レジスタの数を7つに増やし、一度に1つだけ選択された。またはIBM 7094の互換モードで利用可能なように残された[18]

命令形式とデータ形式 編集

命令形式にはタイプAとタイプBの2種類がある[19]。ほとんどの命令はタイプB形式である。

タイプAの命令形式は、「プレフィックス」3ビット、「デクリメント」15ビット、「タグ」3ビット、「アドレス」15ビットから構成される。プレフィックス部は命令の種類を指定する。デクリメント部は命令結果を修飾する即値を格納するか、命令の種類指定に使われる。タグ部はデクリメントレジスタを指定し、指定されたインデックスレジスタの内容がアドレスから引かれて実効アドレスとなる。アドレス部はアドレスか即値オペランドを格納している。タグフィールドで指定したデクリメントレジスタの内容に基づいて条件分岐する命令もある。プレフィックスの2ビット目と3ビット目が共にゼロの場合、タイプBと判断されるため、タイプAの命令は6種類しかない。しかもSTRという命令(バイナリで101)は IBM 709 で初めて実装されており、704 では5種類のタイプA命令しかなかった。

タイプBの命令形式は、12ビットの命令コード(うち2ビット目と3ビット目は常にゼロ)、2ビットのフラグフィールド、4ビットの未使用フィールド、3ビットのタグフィールド、15ビットのアドレスフィールドから構成される。

  • 固定小数点数が二進の符号+絶対値形式で格納された。
  • 単精度浮動小数点数は、符号ビット、8ビット指数(エクセス128)、27ビット仮数で構成される。
  • 文字は6ビットで表され(BCDの一種)、1ワードに6文字が格納される。

命令セットは、データ形式をタイプA命令と同じフィールド (接頭辞、デクリメント、タグ、アドレス) に暗黙のうちに細分化している。Store Tag命令はIBM 704には実装されていなかったが、ワードの残りの部分を変更することなく、データワード内のこれらのフィールドをそれぞれ変更する命令が存在した。

LISPの最初の実装では、アドレスとデクリメントフィールドをCONSセルの実装に使用し、リンクされたリストの先頭と末尾をそれぞれ格納している。LISPの原始関数 CAR と CDR はそれぞれ「Contents of Address part of Register number」と「Contents of Decrement part of Register number」のフィールドに由来する[20]

「contents of address register」と「contents of decrement register」の略とされることもあるが、IBM 704 にはユーザーがアクセスできるアドレスレジスタは存在しない。

メモリと周辺機器 編集

IBM 704には、IBM 711英語版パンチカードリーダー1台、IBM 716英語版アルファベットプリンタ1台、721パンチカードレコーダー1台、IBM 727磁気テープユニット5台と753テープコントロールユニット1台、733磁気ドラムリーダー&レコーダー1台、および737磁気コアストレージユニット1台の制御装置が含まれている。重量は約19,466ポンド(9.7ショートトン、8.8トン)[21][22]

704本体には、36個の制御スイッチやボタン、36個のデータ入力スイッチ (レジスタ内の各ビットに対応) を備えた制御コンソールが付属していた。この制御コンソールでは、基本的にはスイッチを使ってレジスタのバイナリ値を設定し、現代のLEDによく似た小さなネオン管のパターンで表示されるレジスタのバイナリ状態を表示することだけができる。コンピュータとの人間の対話では、プログラムはコンソールではなく、最初にパンチングカードに入力され、人間が読める出力はプリンタに送られる。

IBM 740英語版陰極線管出力レコーダーも利用可能で、人間が見るために20秒という非常に長い蛍光体持続時間を備えた21インチのベクターディスプレイで、7インチディスプレイは大型ディスプレイと同じ信号を受信するが、付属のカメラで撮影するように設計された蛍光体の輝度が急速に減衰するよう設計されたため高速であった[23]

737磁気コア記憶装置は、RAMとして4,096個の36ビットワード (18,432バイト相当) を搭載している[24]。727磁気テープユニットは、1リールあたり500万文字以上の6ビット文字を記録した。

参照項目 編集

脚注 編集

  1. ^ 704 photos from IBM
  2. ^ a b 704 Data Processing System”. IBM Archives - Exhibits - IBM Mainframes - Mainframes reference room - Mainframes product profiles. IBM (2003年1月23日). 2016年8月18日閲覧。
  3. ^ IBM Electronic Data-Processing Machines TYPE 704”. IBM 704 Manual of Operation. International Business Machines Corporation (1955年). 2017年12月28日閲覧。
  4. ^ Assemblers were once people: My aunt did it for NASA”. Software - Developer. The Register (2015年2月26日). 2016年8月18日閲覧。
  5. ^ History of IBM Timeline”. IBM (2003年1月23日). 2019年7月4日閲覧。
  6. ^ History of FORTRAN and FORTRAN II — Software Preservation Group”. www.softwarepreservation.org. 2020年9月19日閲覧。
  7. ^ LISP prehistory - Summer 1956 through Summer 1958.”. www-formal.stanford.edu. 2020年9月19日閲覧。
  8. ^ Kelly, John L.; Lochbaum, Carol (1962), “Speech synthesis”, Proceedings of the Speech Communications Seminar, paper F7 (Stockholm, Speech Transmission Laboratory, Royal Institute of Technology) 
  9. ^ Smith III, Julius O. (2010), “Singing Kelly-Lochbaum Vocal Tract”, Physical Audio Signal Processing, ISBN 978-0-9745607-2-4, https://ccrma.stanford.edu/~jos/pasp/Singing_Kelly_Lochbaum_Vocal_Tract.html 
  10. ^ 14. "Daisy Bell (Bicycle Built for Two)," Max Mathews (1961), “National Recording Registry Adds 25”, The Library Today (Library of Congress), (June 23, 2010), http://www.loc.gov/today/pr/2010/10-116.html, "This recording, made at Bell Laboratories on an IBM 704 mainframe computer, is the earliest known recording of a computer-synthesized voice singing a song. The recording was created by John L. Kelly, Jr., and featured musical accompaniment written by Max Mathews." 
  11. ^ 1961年デイジー・ベルを歌った最初のコンピュータをIBM 7094とする文献もあるが、IBM 7094 の初設置は1962年9月とされており時期的に合わない。
  12. ^ Arthur C. Clarke online Biography”. 2007年11月15日時点のオリジナルよりアーカイブ。2022年12月27日閲覧。
  13. ^ Bell Labs: Where "HAL" First Spoke”. 2013年5月30日時点のオリジナルよりアーカイブ。2022年12月27日閲覧。
  14. ^ ディスカバリーチャンネルのドキュメンタリーでのEd ThorpとVivian Thorpのインタビュー
  15. ^ The Tech (MIT) "Thorpe, 704 Beat Blackjack" Vol. 81 No. I Cambridge, Mass., Friday, February 10, 1961
  16. ^ Kaisler, Stephen H. (Nov 2018). First Generation Mainframes: The IBM 700 Series. Cambridge Scholars Publishing. p. 69. ISBN 978-1-5275-0650-3. https://books.google.com/books?id=B9l9DwAAQBAJ&pg=PA69 2019年4月25日閲覧。 
  17. ^ 朝日新聞
  18. ^ IBM 7094 Principles of Operation, IBM Systems Reference Library (fifth ed.), IBM, (1962), p. 8, A22-6703-4, http://bitsavers.trailing-edge.com/pdf/ibm/7094/A22-6703-4_7094_PoO_Oct66.pdf 
  19. ^ John Savard. From the IBM 704 to the IBM 7094. http://www.quadibloc.com/comp/cp0309.htm 2009年11月15日閲覧。. 
  20. ^ John McCarthy. Recursive Functions of Symbolic Expressions and Their Computation by Machine, Part I. http://www-formal.stanford.edu/jmc/recursive.html 2009年2月14日閲覧。. 
  21. ^ Weik, Martin H. (1955年12月). “IBM-704”. ed-thelen.org. 2020年9月19日閲覧。
  22. ^ Weik, Martin H. (1961年3月). “IBM 704”. ed-thelen.org. 2020年9月19日閲覧。
  23. ^ IBM Archives: 704 Cathode Ray Tube Output Recorder” (2003年1月23日). 2012年12月10日閲覧。
  24. ^ IBM Archives: IBM 737 Magnetic core storage unit” (2003年1月23日). 2012年12月10日閲覧。

参考文献 編集

  • Charles J. Bashe, Lyle R. Johnson, John H. Palmer, Emerson W. Pugh, IBM's Early Computers (MIT Press, Cambridge, 1986年)
  • Steven Levy, Hackers: Heroes of the Computer Revolution
  • IBM Type 704 Manual of operation, Form 24-66661-1, IBM, 1956

外部リンク 編集