概要
ISLisp基準、準拠のEasy-ISLispはver5.0において分散並列機能を追加することを計画しています。現在、ver4.5においてその機能の基本部分が機能するようになりましたのでご報告します。
目的
現在のコンピューターはマルチコア化しています。動作クロックの高速化は上限に達しつつあり、これを補うために並列にその道を見出しているようです。量子コンピューターはブレークスルーですが、それが実用になるのはまだまだ先のことと思います。この間、現在のノイマン型デジタルコンピューターが現役となるでしょう。
現在、流行のプログラム言語において種々の並列化が試みられています。プログラム言語は流行りすたりがあり、ひととき瞬いた後でいつのまにか消え去っているものも多くあります。今、主流の言語も将来、どうなるかは定かではありません。一方。Lispは現在、主流の言語ではありませんが、60年以上の歴史があります。Lispは数学に根差しており今後もしぶとく生き残ることでしょう。この言語で並列計算の経験を積んでおくことは、良い経験になると思います。枝葉末節のことではない並列計算の基本的なことの経験は将来においても色褪せることはないと私は考えました。
分散の仕組み
TCP/IP通信を利用して複数のコンピューターを接続します。1台の親Lispから計算を分解して複数のコンピューターに仕事を依頼します。
親Lispは並列計算したいプログラムを子Lispに一斉に転送します。さらに一斉にコンパイルし、loadします。これらを親Lispから操作します。このために次の拡張機能を用意してあります。
〇 eisl -n -nオプションにより子Lispを起動します。これにより子Lispはネットワークモードで動作します。
〇 (dp-create c0 c1 ...cn) 子機のIPアドレスを親Lispに与えてTCP/IP通信を確立する。
〇 (dp-let forms body) let構文の分散並列版です、
〇 (dp-transfer fn) ファイルfnを与えて親機からすべての子機にファイルを転送します。
〇 (dp-compile fn) ファイルfnを親機、子機においてコンパイルします。
〇 (dp-load fn) ファイルfnを親機、子機においてloadします。
〇 (dp-system n sexp) n番目の子LispにS式を評価させます。子機のテストに使います。
〇 (dp-close) 子機に終了命令を送り、通信をクローズします。
動作例
- 子機においてネットワークモードでLispを起動します。
- 親機を起動します。このときコンパイラも使いたいので-cオプションで起動します。
- (dp-create c0 c1)を使って2台の子機との通信を確立させます。
-
(dp-load fn) を使ってコードを親機、子機のすべてでloadします。
- 親機で計算テスト
dp-letを使った分散並列が機能していることを確かめます。
子機にいおいては親機とのやりとりがターミナルに表示されています。
今後の展望
計画している並列機能は下記の通りです。
(dp-exec x0 x1 ... xn) 単純並列実行
(dp-part t x0 x1 ... xn) 部分並列実行
(dp-part nil x0 x1 ... xn) 部分並列実行
(dp-call fn a0 a1 ... an) 並列構文
(dp-report str) 子機から親機の端末に文字列strを表示する。
将来課題
今のところイミュータブルなデータでの実行を考えています。大域変数への破壊的代入、参照を許すこととするととても複雑になります。子Lispが大域変数を書き換えた場合には競合が起こらないように制御しながら各機の大域変数を書き換えなくてはなりません。
当面、決定性の問題、例えばパズルを解くことですとか、クイックソートのように完全に並列分離しているアルゴリズムに絞って計算が機能するのかを確認します。
流体力学の計算のようなことをやろうとするとMPIのような仕組みが必要となります。これは必要に迫られたときの将来課題としたいと考えています。
実装
Easy-ISLispはgithubにおいてあります。BSD2ライセンスです。ご自由にお試しください。
https://github.com/sasagawa888/eisl
蛇足
以下は個人的意見です。Lisperの中には昔のことに異常に拘る人がいます。あるいはEmacsなどツールに異常に拘る人がいます。古きを訪ねて新しきを知ることはとても重要なことです。古い知恵が未来を切り開くかもしれません。過去だけにしがみついていたらもうそれ以上の発展はありません。Lispには未来言語であってほしいと私は願っています。