HEXA BLOG
ヘキサブログ
研究・開発
最新のマルチコアCPUを使いこなすには
こんにちは、イワサキです。
最近はプログラミングネタ担当となっているわけですが(笑)
さて、今日は次世代に向けたお話。
CPUはデュアルコア、クアッドコアが当たり前になってきている
昨今ですが、それをプログラマーが使いこなすにはどのような
プログラミングをすればいいのか。
最近では特にPlayStation3で注目を集めたCELLプロセッサが
多くのコアを搭載していますよね。
PlayStation3のCELLについてはこちらなどが分かりやすいでしょうか。
↓
CEDEC 2006 – CellプロセッサをGPU的に活用することができるのか
http://journal.mycom.co.jp/articles/2006/09/14/cedec3/index.html
CELLのようなCPUはヘテロジニアス・マルチコアプロセッサと言います。
非対称なCPUとは、同じものが複数あるわけではなく、
別のアーキテクチャのプロセッサが混在しているプロセッサです。
たとえば1対多数のような構成です。
CELLだとPowerPCコアが1個2スレッド、ストリーミングプロセッシングユニット
(SPU)が8基です。PlayStation3の場合はこれが6個です。
このような複雑な仕様を持つプロセッサを100%使い切るには
どうすればよいでしょうか。
答えは意外と身近なところに。
一番分かりやすいのは「お昼時のコンビニの店員さんの動き方」です。
店員さんをPowerPC、複数置いてある電子レンジをSPUとしましょう。
店員さんはお客(ジョブ)がくると、まず、
(1)品物を受け取り、お弁当を温める場合は電子レンジにセット
(2) すぐさま会計を済ませて、そのお客さんには横で待ってもらっておいて
次のお客の対応をします。
(3) 2回目は1人目客のお弁当が既にあたため中でレンジが動いていますので
2台目のレンジにセットします。客と応対途中でもレンジのあたためが
終わったら前の客を待たせないために優先的にそのお弁当を
前の客に渡します。
・・・とまぁ店員さんは常に大忙しで待つことなく100%の働きをしています。
レンジも次々に入れ替わり立ち代り同時に稼動していることになります。
これは本当にすごいなぁと感心してしまいます。
────これがもしもダメな店員だった場合。。。
↓
会計をまず全部終わらせてから電子レンジにセットして、
あたため終わるまでボーっと待って、
終わったらお客さんに渡してから次の人ー
という感じになります。
これでは電子レンジは1台しか動きませんし、かかる時間も相当長くなります。
客の回転も悪くなってしまいますよね。
これとおなじ現象がヘテロジニアスコアにも発生します。
メインのプロセッサはサブのプロセッサにどんどん仕事を投げて
投げた後のジョブは横に置いておいて次のジョブをとってきて…
というように次々ジョブをこなす。
そして結果がサブプロセッサから返ってきたらすぐに
以前置いておいたジョブの対応を優先的に再開する。
そうすると同じ原理でそれぞれが上手く回転するというわけです。
待ち時間を他の作業をして待つという具合です。
身近なところにヒントは隠れています。
生活自体も日々勉強です!みなさんも充実したライフを送りましょう!
CATEGORY
- about ヘキサ (166)
- 部活動 (6)
- CG (18)
- プロジェクトマネジメント (1)
- 研修 (5)
- 美学 (1)
- いいモノづくり道 (230)
- 採用 -お役立ち情報も- (149)
- プログラム (188)
- デザイン (99)
- ゲーム (274)
- 日記 (1,104)
- 書籍紹介 (113)
- その他 (875)
- 就活アドバイス (20)
- ラーメン (3)
- ライフハック (25)
- イベント紹介 (10)
- 料理 (23)
- TIPS (7)
- 怖い話 (3)
- サウンド (5)
- 子育て (1)
- 筋トレ (1)
- 商品紹介 (21)
- アプリ紹介 (31)
- ソフトウェア紹介 (33)
- ガジェット紹介 (12)
- サイト紹介 (10)
- 研究・開発 (34)
- 回路図 (4)
- アナログゲーム (40)
- 交流会 (21)
- 報告会 (3)
- インフラ (25)
- グリとブラン (6)
- カメラ (9)
- クラフト (27)
- 部活 (14)
- 画伯 (15)
- カレー (6)
- 音楽(洋楽) (6)
- 映画・舞台鑑賞 (43)
- 飼育 (5)
- いぬ (8)
- ねこ (19)
ARCHIVE
- 2024年
- 2023年
- 2022年
- 2021年
- 2020年
- 2019年
- 2018年
- 2017年
- 2016年
- 2015年
- 2014年
- 2013年
- 2012年
- 2011年
- 2010年
- 2009年
- 2008年
- 2007年