研究概要 |
本年度の主な研究内容は, 高並列環境向けタスク並列処理系の高性能な実行時システムを構築する要素技術となる, タスクのスケジューリング手法に関しての検討である. 近年の並列計算機は複数の計算ノードをインターコネクトによって接続した分散メモリ環境として構成されているため, タスク並列処理系の実行時システムにはハードウェア構成やアプリケーションの特徴に配慮してデータ配置やタスクのスケジューリングを行い, オーバーヘッドの大きいノード間通信の量を抑えることが求められる. 本研究では, これを達成するため, タスク並列処理におけるスケジューリング戦略をプログラマがカスタマイズすることを可能にする機能を実行時システムに追加する手法を提案している. 提案手法では, タスク並列処理の代表的なスケジューリング手法であるLazy Task Creationをスケジューリング戦略の骨子として用い, カスタマイズにかかる負担を抑えるために, カスタマイズ可能な範囲を, アイドル状態のハードウェアが他から実行可能なタスクを奪うことで負荷分散をとる, ワークスチーリングの際の戦略に限定している. 提案手法においては, プログラマは(1)各タスクにワークスチーリングの際のヒントとして用いる任意のデータを割り当てる機能(2)奪うことが可能なタスクに割り当てられているヒントを読み取る機能(3)得られたヒントをもとにワークスチーリングを実際に試行する機能, の3つを利用して, ワークスチーリングの戦略を実装することでスケジューリングのカスタマイズを行う. さらに, 共有メモリ環境を用いた提案手法の予備評価として, 密行列積と配列の繰り返し加算の2種類のベンチマークにアプリケーションの特徴に配慮したカスタマイズを行い, それぞれのベンチマークにおいて実行性能の向上がみられることを確認している.
|
今後の研究の推進方策 |
今後は, 実アプリケーションを利用した提案手法の有効性の検証や, より抽象度が高く容易に利用できるカスタマイズ手法についての検討を行うことを主な研究内容とする. さらに, 共同研究者によって進められているMassiveThreadsと大域アドレス空間との統合の成果と連携して, 分散環境における評価を行う予定である.
|