差分

移動先: 案内検索

マルチプロセッサとプロセス

4,017 バイト追加, 2021年10月8日 (金) 18:57
/* マルチコアが当たり前の時代に */
=== マルチコアが当たり前の時代に ===
 
以前は(パッケージとしての)CPUの中に1つのプロセッサ(プロセッサ・コア)しか搭載されておらず、それをマザーボードに複数搭載してマルチプロセッサのシステムとして使っていました。
近年ではデスクトップPCでもノートPCでも採用しているCPUがマルチコアなのが当たり前という時代になってきました。
マルチコアとは物理的に1つのプロセッサ・チップ (あるいはプロセッサのパッケージの中に) に複数の物理的プロセッサ・コアを搭載しているCPUパッケージのことです。
部品としてのパッケージ化されたCPUは1つでも、その中には複数のプロセッサが存在しています。
2018年においては一般に販売されているPCでマルチコア以外はみかけません。
またスマートフォンやタブレットでもマルチコアのCPUを採用するのが主流となっています。
 
=== マルチプロセッサとプロセス ===
さらにそのSMPを構成しているハードウェア上で対称型マルチプロセッシング対称マルチプロセッサ(SMP) を構成しているハードウェア上でソフトウェアが対称型マルチプロセッシング(SMP: Symmetric multiprocessing)を実現しているのもSMPです。を実現しています。ハードウェアがSymmetric 理屈的にはハードウェアがSymmetric Multi-Processorでもソフトウェアでは(Symmetric ProcessorでもソフトウェアではSymmetric multiprocessingではないOSの実装もありえます<ref>ありえますが、筆者はそのような実装はみたことはありません。</ref>が、少なくともLinuxのカーネルと、その処理についての文脈でSMPと呼んでいる時、ハードウェアがSMPなものにソフトウェアもSMPを実装しているので結果としておなじ意味になります。
ある一定のデータを処理するプログラムをまず仮定します。プロセス単位で割り当てるならプログラム側はSMPを何にも意識しなくても構いません。たくさんのプロセスがスケジュールされている場合でもCPU が多い分、自分の番が回ってくる回数が増えるため負荷に強いという意味で、処理能力が向上します。CPUが1個の時に同時に2つのプロセスを動かす時の処理時間とCPUが2個の時に同時に2つのプロセスを動かす時の処理時間を比較すると、後者の方が速くなります。しかし1つのプロセスに着目してみればCPUが1個で1つのプロセスしか動いていない時の処理時間よりは速くなることがありません。
 
=== マルチプロセッサとスレッド ===
 
 
スレッド単位で割り当てる場合、実行中プログラムの持つ複数のスレッドが複数のCPUに同時に割り当てられていきます。
その場合はプログラムの処理のスピードは CPU 単体の最大処理速度を越えることが可能になります。
ただ、それでも上手にスレッドを分割し、その処理タイミングをきちんとプログラミングできる場合という前提が満たされることが必要です。
 
 
[[File:CodeCogsEqn-2.png|thumb|left|250px|こんな計算を仮定してみる。]]
 
 
まず、a1 * a2 * a3 * ... * anを計算しAに代入するスレッドとa1 + a2 + a3+ ... + anを計算しBに代入するスレッドを作ります。両方のスレッドの計算の終了を待ってA/Bを計算します。
この時、各々のスレッドが別々のCPUで並列に動くので1個のCPUで全部を計算させるよりも速く計算 <ref>マルチスレッドを使い円周率を計算したプログラム例: http://uc2.h2np.net/src/mt-bbp.c </ref> ができるはずです。
 
 
 
しかしこの場合、処理効率が単純に2倍に上がるわけではありません。
たとえば1CPUでの計算に20秒かかったとしましょう。
2CPU を使い分母、分子の計算が分割でき並列に計算されたとしても、もし、分子の計算が12秒かかり、分母の計算が10秒かかり、分子÷分母の計算が0.5秒かかったならば、分母の計算時間と割り算の時間を足したものがクリティカルパスですから、その処理時間は12.5秒となります。このようにCPU数が増えたからといって単純に性能がCPU数に合わせて倍数的に増えていくわけではありませんし、もちろん処理が並列化されていないプログラムをいくら走らせても当然ながらその結果はCPUを1つ占有出来ること以上の効果はありません。
 
;調べよう: 並列処理一般において処理効率には上限があることを示しているのがアムダールの法則です。アムダールの法則について調べてみましょう。<ref>ジーン・アムダールが書いた1967年の論文 "[http://www-inst.eecs.berkeley.edu/~n252/paper/Amdahl.pdf http://www-inst.eecs.berkeley.edu/~n252/paper/Amdahl.pdf]" が公開されています。ここに書かれている並列計算の遅滞に関する内容が後にアムダールの法則と呼ばれるようになります。</ref>
 
 
== 脚注 ==
 
<references/>
 
----
[[プロセス管理]]
もしくは
[[目次]]
へ移動