ScholarGate
アシスタント

並列プログラミングモデル

並列プログラミングモデルは、プログラマが速度向上を目的として、多数のプロセッサ間で計算を表現し、調整するための抽象化された手段です。

PaperMindでテーマを探す近日公開Find papers & topics
Tools & resources
スライドをダウンロード
Learn & explore
動画近日公開

Definition

並列プログラミングモデルとは、並列コンピュータの抽象化であり、計算がどのように並行タスクに分解されるか、それらのタスクがどのように通信および同期するか、そしてデータがプロセッサ間でどのように共有または分散されるかを定義するものです。これにより、複数の処理ユニットを使用することで問題をより速く解決することが可能になります。

Scope

この分野では、主要な並列プログラミングモデル(共有メモリとデータ並列性(スレッド、OpenMP)、メッセージパッシング(MPI)、アクセラレータ/GPUプログラミング(CUDA、OpenCL))に加え、フリンの並列アーキテクチャ分類、並列アルゴリズムの設計、およびその利点を制限・測定する性能法則(アムダールの法則、グスタフソンの法則)と指標(スピードアップ、効率、スケーラビリティ)を扱います。これは、サブフィールドの分散システム側に対する並列コンピューティングの補完的な側面です。

Sub-topics

Core questions

  • 計算はどのようにタスクに分解され、プロセッサにマッピングされるべきか?
  • どのプログラミングモデル(共有メモリ、メッセージパッシング、アクセラレータ)が特定のアーキテクチャと問題に適しているか?
  • 並列処理から得られるスピードアップを制限するものは何か、またスケーラビリティはどのように測定されるか?

Key theories

フリンの分類
並列アーキテクチャは、命令ストリームとデータストリームによってSISD、SIMD、MISD、MIMDに分類され、この枠組みはベクトル、GPU、マルチコアマシンに関する考察を今なお整理しています。
アムダールの法則とグスタフソンの法則
アムダールの法則は、固定された問題サイズに対してプログラムの逐次部分によってスピードアップを制限する一方、グスタフソンの再構築は、より大きな問題がより多くのプロセッサを有効に活用できることを指摘し、これらが並列処理の限界と可能性を共に示しています。
並列設計パターン
タスクとデータの分解、パイプライン、幾何学的分解、マスター・ワーカーといった繰り返し現れる戦略は、モデルを超えて並列プログラムを設計するための構造化された語彙を提供します。

Clinical relevance

並列プログラミングモデルは、高性能計算や科学計算、GPU上での機械学習トレーニング、およびマルチコアプロセッサの日常的な活用基盤となっています。モデルの選択は、達成可能な性能とハードウェア間の移植性を決定します。

History

フリンの1972年の分類とアムダールの1967年のスピードアップに関する議論は、当初から並列コンピューティングの枠組みを形成しました。標準化されたモデルは、1990年代のMPIとOpenMP、2000年代のGPUコンピューティングとともに登場し、Gramaらの教科書は並列アルゴリズムの設計と分析を体系化しました。

Debates

デフォルトモデルとしての共有メモリとメッセージパッシング
共有メモリモデルはプログラミングが容易ですが、スケーラビリティが低く、微妙なデータ競合のリスクがあります。一方、メッセージパッシングは明示的な通信を必要とするものの、大規模なクラスタにスケールします。ハイブリッドモデルは両者を組み合わせますが、適切なデフォルトはワークロードとアーキテクチャに依存します。

Key figures

  • Gene Amdahl
  • Michael Flynn
  • Vipin Kumar
  • John Gustafson

Related topics

Seminal works

  • grama2003
  • amdahl1967
  • flynn1972

Frequently asked questions

なぜプロセッサを増やしても、どんなプログラムでも任意に高速化できるわけではないのですか?
アムダールの法則は、計算の逐次部分(並列化できない作業)が全体のスピードアップを制限することを示しています。たとえごく一部が本質的に逐次的なものであっても、プロセッサ数が増えるにつれてそれが支配的になり、達成可能な加速に上限を設けます。

Methods for this concept

Related concepts