並列アーキテクチャの収束
並列マシンは、いくつかの異なるアーキテクチャで開発されています。このセクションでは、さまざまな並列コンピューターアーキテクチャとそれらの収束の性質について説明します。
通信アーキテクチャ
並列アーキテクチャは、通信アーキテクチャを使用してコンピュータアーキテクチャの従来の概念を強化します。コンピュータアーキテクチャは、重要な抽象化(ユーザーシステムの境界やハードウェアとソフトウェアの境界など)と組織構造を定義しますが、通信アーキテクチャは、基本的な通信と同期の操作を定義します。また、組織構造についても説明します。
プログラミングモデルは最上位層です。アプリケーションはプログラミングモデルで書かれています。並列プログラミングモデルには以下が含まれます-
- 共有アドレス空間
- メッセージパッシング
- データ並列プログラミング
Shared addressプログラミングは掲示板を使用するのと同じです。掲示板では、他のすべての個人が共有する特定の場所に情報を投稿することで、1人または複数の個人と通信できます。個々の活動は、誰がどのタスクを実行しているかに注目することによって調整されます。
Message passing 特定の受信者が特定の送信者から情報を受信する電話や手紙のようなものです。
Data parallelプログラミングは組織化された形の協力です。ここでは、複数の個人がデータセットの別々の要素に対して同時にアクションを実行し、情報をグローバルに共有します。
共有メモリ
共有メモリマルチプロセッサは、並列マシンの最も重要なクラスの1つです。マルチプログラミングワークロードでのスループットが向上し、並列プログラムをサポートします。
この場合、すべてのコンピュータシステムでは、プロセッサとI / Oコントローラのセットが、ハードウェアの相互接続によってメモリモジュールのコレクションにアクセスできます。メモリモジュールを追加するとメモリ容量が増加し、I / Oコントローラにデバイスを追加するかI / Oコントローラを追加するとI / O容量が増加します。より高速なプロセッサが利用可能になるのを待つか、プロセッサを追加することで、処理能力を高めることができます。
すべてのリソースは、中央のメモリバスを中心に編成されています。バスアクセスメカニズムを介して、任意のプロセッサがシステム内の任意の物理アドレスにアクセスできます。すべてのプロセッサはすべてのメモリ位置から等距離にあるため、すべてのプロセッサのアクセス時間または遅延はメモリ位置で同じです。これはsymmetric multiprocessor。
メッセージパッシングアーキテクチャ
メッセージパッシングアーキテクチャも、並列マシンの重要なクラスです。明示的なI / O操作としてプロセッサ間の通信を提供します。この場合、通信はメモリシステムではなくI / Oレベルで結合されます。
メッセージパッシングアーキテクチャでは、実際の通信操作を含む、多くの下位レベルのアクションを実行するオペレーティングシステムまたはライブラリ呼び出しを使用して実行されるユーザー通信。その結果、プログラミングモデルと物理ハードウェアレベルでの通信操作の間には距離があります。
Send そして receiveメッセージパッシングシステムで最も一般的なユーザーレベルの通信操作です。送信は、ローカルデータバッファ(送信される)と受信リモートプロセッサを指定します。受信は、送信プロセスと、送信データが配置されるローカルデータバッファを指定します。送信操作では、identifier または tag はメッセージに添付され、受信操作は、特定のプロセッサからの特定のタグや任意のプロセッサからの任意のタグなどの一致ルールを指定します。
送信と一致する受信の組み合わせにより、メモリからメモリへのコピーが完了します。両端は、ローカルデータアドレスとペアワイズ同期イベントを指定します。
収束
ハードウェアとソフトウェアの開発により、共有メモリとメッセージパッシングキャンプの間の明確な境界が薄れてきました。メッセージパッシングと共有アドレス空間は、2つの異なるプログラミングモデルを表しています。それぞれが、共有、同期、および通信のための透過的なパラダイムを提供します。ただし、基本的なマシン構造は共通の組織に向かって収束しています。
データ並列処理
並列マシンのもう1つの重要なクラスは、さまざまに呼ばれます-プロセッサアレイ、データ並列アーキテクチャ、および単一命令-複数データマシン。プログラミングモデルの主な機能は、大規模な通常のデータ構造(配列や行列など)の各要素に対して操作を並行して実行できることです。
データ並列プログラミング言語は通常、プロセスのグループのローカルアドレス空間をプロセッサごとに1つずつ表示し、明示的なグローバル空間を形成することによって適用されます。すべてのプロセッサが相互に通信し、すべての操作のグローバルビューがあるため、共有アドレス空間またはメッセージパッシングのいずれかを使用できます。
基本的な設計の問題
プログラミングモデルの開発は、コンピュータの効率を上げることはできず、ハードウェアの開発だけでそれを行うこともできません。ただし、コンピュータアーキテクチャの開発により、コンピュータのパフォーマンスに違いが生じる可能性があります。プログラムが機械をどのように使用し、どの基本技術が提供されているかに焦点を当てることで、設計の問題を理解することができます。
このセクションでは、通信の抽象化とプログラミングモデルの基本的な要件について説明します。
コミュニケーションの抽象化
通信の抽象化は、プログラミングモデルとシステム実装の間の主要なインターフェイスです。これは、同じプログラムを多くの実装で正しく実行できるようにプラットフォームを提供する命令セットのようなものです。このレベルでの操作は単純でなければなりません。
通信の抽象化は、ハードウェアとソフトウェアの間の契約のようなものであり、作業に影響を与えることなく相互に柔軟性を向上させることができます。
プログラミングモデルの要件
並列プログラムには、データを操作する1つ以上のスレッドがあります。並列プログラミングモデルは、スレッドが実行できるデータを定義しますname、これ operations 指定されたデータに対して実行でき、どの順序の後に操作が続きます。
プログラム間の依存関係が適用されていることを確認するには、並列プログラムがそのスレッドのアクティビティを調整する必要があります。