Chapel
Chapel は、クレイ社によって開発されたプログラミング言語である[1]。この言語は今もなお「クレイ・カスケード・プロジェクト」として開発されている。もともと、このプロジェクトは米国国防高等研究計画局の高生産性計算機システムプロジェクトの一部だったもので、その目標は、2010年までの間にスーパーコンピューターの生産性を改善するというものであった。Chapel が狙っているのは、並列計算機、とりわけ、
Chapel言語はデータやタスクの並列化や入れ子構造の並列化をする仕組みを備えている。これらは高水準のマルチスレッド並列プログラミングモデルを支援するものである。これらの仕組みによってデータの分配やデータ駆動による部分演算の割り当ては抽象化されるため、プログラム中のデータと演算の局所性の最適化が可能になっている。また、オブジェクト指向と汎用プログラミングの仕組みによって、プログラムコードの再利用と汎用化も可能である。例えば、Chapel ではロケールを宣言することができる[2]。
Chapel言語では先行する言語からアイデアを借用している。並列性に関する考え方で最も近いのは High Performance Fortran、ZPL そして Cray MTA の FORTRAN 拡張とC言語拡張である。
西暦2021年現在この言語は、Apache 2ライセンスの下、オープンソースのプロジェクトして開発が進行中である[3]。
なお、言語の名前「Chapel」は「多段高生産性言語」を意味する英語「cascade high productivity language」にちなんで名付けられたものである。
脚注
- ^ デビッド E. ライトフット 著、「Modular programming languages: 7th Joint Modular Languages Conference」、2006年、ISBN 3-540-40927-0、20ページ
- ^ Bongen Gu; Wikuan Yu; Yoonsik Kwak (28–30 June 2011). "Communication and Computation Overlap through Task Synchronization in Multi-locale Chapel Environment". In James J. Park, Laurence T. Yang and Changhoon Lee (ed.). Future Information Technology, Part I: 6th International Conference. ギリシャ Loutraki: シュプリンガー・フェアラーク. pp. 285–292. ISBN 978-3-642-22332-7. 2020年9月9日閲覧。
- ^ Chapel License Information