L-Closure : 高性能・高信頼プログラミング言語の実装向け言語機構
スポンサーリンク
概要
- 論文の詳細を見る
本研究では,実行中のプログラムがその実行スタックの内容を合法的に見たり変更したりするための"L-closure"という新しい言語機構を提案する.L-closureは入れ子関数定義を評価すると生成される軽量lexical closureであり,lexical closureは生成時環境におけるlexicalスコープの変数にアクセスできるため,その間接的な呼び出しにより合法的なスタックアクセスの手段を提供する.L-closureが追加された中間言語を高水準コンパイラで採用することにより,ごみ集め,チェックポインティング,マルチスレッディングや負荷分散といった高水準サービスがすっきりと効率良く実装可能となる.L-closureがアクセスする各変数では,共有のための場所のほかに,レジスタ割当て候補として私用の場所も用いる.共有の場所との値の一致をとるための処理や,L-closureの初期化処理は実際にL-closureが呼び出されるまで遅延される.多くの高水準サービスはL-closureを頻繁に生成するもののめったに(たとえばごみ集めにおけるルートスキャンのために)呼び出さないので,総合的なオーバヘッドは大幅に削減可能となる.GNUCコンパイラ(GCC)は入れ子関数をもともとサポートしており,L-closureを実装するためのGCCの拡張は比較的低コストで可能であった.本論文ではその実装の詳細を述べる.また,L-closureの低い生成・維持コストを示す評価結果について,変換ベースL-closure実装についての追加評価結果とともに述べる.
- 2008-01-15
著者
-
八杉 昌宏
京都大学大学院情報学研究科
-
湯淺 太一
京都大学大学院工学研究科情報工学専攻
-
平石 拓
京都大学学術情報メディアセンター
-
湯淺 太一
京都大学大学院情報学研究科
-
湯浅 太一
豊橋技術科学大学
-
平石 拓
京都大学大学院情報学研究科
-
篠原 丈成
京都大学大学院情報学研究科
-
Yasugi Masahiro
Department Of Communications And Computer Engineering Graduate School Of Informatics Kyoto Universit
-
Masahiro Yasugi
Graduate School Of Informatics Kyoto University
関連論文
- L-Closure:安全な計算状態操作機構(平成21年度論文賞の受賞論文紹介)
- L-Closure : 高性能・高信頼プログラミング言語の実装向け言語機構
- シームレスな高生産並列スクリプト言語の実現に向けて(並列プログラミング/スケジューリング,「ハイパフォーマンスコンピューティングとアーキテクチャの評価」に関する北海道ワークショップ(HOKKE-2009))
- シームレスな高生産並列スクリプト言語の実現に向けて (計算機アーキテクチャ・ハイパフォーマンスコンピューティング・「ハイパフォーマンスコンピューティングとアーキテクチャの評価」に関する北海道ワークショップ(HOKKE-2009))
- 階層的グループ化に基づくコピー型ごみ集めによる局所性改善
- ISLisp処理系の開発と複合他システムインタフェースについて
- ISO規格ISLISP処理系におけるオブジェクトシステムの実装について
- ISO規格ISLISP処理系の実装方式
- ISO規格ISLISP処理系の開発
- データ並列言語におけるベクトルプロセッサ向きコード生成
- 共有メモリプログラミングのための拡張C言語
- 標準プログラム言語の国際化
- 動的名前解決による通信先・移動先の柔軟な指定が可能な分散アンビエントシステムの設計
- 1.高信頼組込みシステムのための先進ソフトウェア技術(第1部:高い生産性を持つ高信頼ソフトウェア作成技術の開発,学と産の連携による基盤ソフトウェアの先進的開発)
- 構成的理論に基づいたプログラミング言語Zとその実装
- L-Closureを用いた真に末尾再帰的なSchemeインタプリタ
- シームレスな高生産並列スクリプト言語の実現に向けて(並列プログラミング/スケジューリング,「ハイパフォーマンスコンピューティングとアーキテクチャの評価」に関する北海道ワークショップ(HOKKE-2009))
- リターンバリア型実時間ごみ集めの抽象モデル検査
- Cache-conscious階層的グループ化データ配置法:Cache-oblivious配置法との実験的比較
- タプル空間によるブラウザ間通信を備えたScheme処理系の開発
- 2L-5 スタックスキャンを中断させるリターンバリアごみ集め(リーディングプロジェクト e-society:高信頼性組み込みソフトウェア(2),一般セッション,リーディングプロジェクト e-society)
- Lego MindStorms用のLisp処理系XS(ソフトウェア論文,ソフトウェア論文)
- 情報化
- リージョン変数の動的なエイリアス判定によるメモリ効率向上
- 遅延分割型負荷分散フレームワークの試験実装
- スタックベースのML処理系における効率的な一級継続の実装
- S式ベースC言語における変形規則による言語拡張機構
- 国内予選を突破せよ(プログラム・プロムナード)
- 実時間処理に適したメモリ管理を行うLisp処理系の設計と実装
- 入れ子関数を利用する動的負荷分散と高水準記述(言語処理系)
- 細粒度マルチスレッド言語における例外処理の効率良い実装
- 組み込みシステムにおける複数のフリーリストに割り振るメモリ量の最適化
- S式ベースC言語およびその拡張言語の変形に基づく実装(研究会推薦博士論文速報)
- 並行オブジェクトのための型システムとコンパイル技法
- バックトラックに基づく負荷分散のT2K並列環境における評価
- call/ccからcall/iocへの自動変換
- ヒューマノイド行動ソフトウェア基盤におけるマルチスレッドLispへの実時間GC機能の導入(サイバー増大ページ論文概要,新しいソフトウェアの実現,サイバー増大号)
- ソフトウェア論文座談会
- バックトラックに基づく負荷分散の高並列環境における評価
- Lispは楽しい(コラム)
- Seymour Papert: Mindstorms: Children, Computers, and Powerful Ideas(20世紀の名著名論)
- オブジェクト指向並列言語OPAのための遅延正規化手法
- 遅延タスク生成の反復計算向け拡張(並列処理)
- オブジェクト指向並列言語OPAのためのコード生成手法
- マルチコンテキスト管理をサポートする実装用言語
- 3Z-7 並列言語OPAにおける一貫性制御に対応した差分プログラミング
- Scheme処理系におけるC言語拡張コードへのライトバリア自動挿入
- Scheme処理系におけるC言語拡張コードへのライトバリア自動挿入
- データ並列言語における擬似ベクトル処理のための実行方式
- Highly Reliable Embedded Software Development Using Advanced Software Technologies(Software Engineering for Embedded Systems)
- バックトラックに基づく負荷分散の高並列環境における評価
- 2ZP-2 バックトラックに基づく負荷分散の広域分散環境における評価(情報爆発時代における分散処理と運用技術,学生セッション,「情報爆発」時代に向けた新IT基盤技術,情報処理学会創立50周年記念(第72回)全国大会)
- ロボット行動ソフトウェア環境に適した実時間ごみ集め(サイバー増大ページ論文概要,サイバー増大号)
- ネットワークコミュニティにおける関心の類似性に基づいた知識共有の促進(インタラクション技術の革新と実用化)
- Zinger:関心の類似性に基づく会話支援エージェント(「情報メディアとインタフェース」および一般)
- 共有メモリ向けプリミティブとそのGCCを使った実現
- データ並列言語におけるベクトルプロセッサ向きコード生成
- 等式分割を用いた配列データ依存解析手法
- 入れ子関数を利用した動的負荷分散
- Java上のScheme処理系「ぶぶ」における単一のクラスローダを用いたオブジェクトシステムの実装
- プログラムの部分移送に基づく遠隔実行機構とその知的インタフェースへの応用
- 3Z-6 並列Schemeにおける即時タスク生成法と遅延タスク生成法の融合
- 産業界からの理工系情報学科の研究教育内容への期待と大学の取り組み
- リターン・バリア
- 既存Cヘッダファイルの構文の異なる言語での有効利用(サイバー増大ページ論文概要,新しいソフトウェアの実現,サイバー増大号)
- Silly Sort(プログラム・プロムナード)
- 継続の生成におけるスタックコピーの遅延
- Javaアプリケーション組込み用のLispドライバ
- SchemeにおけるEvaluation Strategyの設計と実装
- 4L-6 ISLISPコンパイラの実装
- ワークスティーリングフレームワークにおけるブロードキャスト機能
- 分散制約充足問題のジョブ並列による求解
- A Transformation-Based Implementation of Lightweight Nested Functions
- Efficient and Portable Implementation of Java-style Exception Handling in C
- 適応的オブジェクトによる排他制御の実行時緩和 (並列処理)
- 入れ子関数を利用したマルチスレッドの実現
- Javaと相互呼び出し可能なScheme処理系「ぶぶ」における継続機能と例外処理機能の実装
- データ並列言語における通信最適化のためのコード移動手法
- 適応的オブジェクトのための局面解析手法
- オブジェクト指向並列言語によるN体問題の並列化とその評価
- ソフトウェア紹介 TUTScheme
- Safe AmbientsのためのJavaフレームワーク
- 動的スコープの利用による並列言語の同期・例外処理の階層的構造化
- Javaクラスライブラリに対する言語間インタフェース
- Parallel Graph Traversals using Work-Stealing Frameworks for Many-core Platforms
- 複数の最上位環境をサポートするLispモジュール機能
- 共有メモリ関連命令を生成可能な実装用言語の設計
- 部分評価を応用した動的Webページのキャッシュ機構
- Dijkstra, E.W., Lamport, L., et al., On-the-Fly Garbage Collection, An Exercise in Cooperation, CACM Vol.21, No.11, Nov.1978, pp.966-975(20世紀の名著名論)
- SIMD型並列計算機SM-1(特集知られざる計算機)
- 末尾再帰の最適化と一級継続を実現するためのJVMの機能拡張
- JLUGM--日本Lispユーザ会議(1)全体報告
- VPリストを用いたデータ並列言語のアクティビティ制御
- はじめての並列プログラミング
- 並列オブジェクト指向言語のためのガーベジコレクタ(並列処理)
- LEGO Mindstorms用のLisp処理系XSによるクラウド制御型ロボット開発(一般セッション(2),クラウドでつながるロボットサービス)
- ソフトウェア紹介 TUTScheme
- 「情報処理学会論文誌 : プログラミング」の編集について
- L-Closureの呼び出しコストの削減
- ACM国際学生プログラミングコンテスト