[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 2chのread.cgiへ]
Update time : 05/24 09:08 / Filesize : 196 KB / Number-of Response : 619
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

Visual Studio 2010 Part18



12 名前:デフォルトの名無しさん mailto:age [2012/01/05(木) 21:51:18.38 ]
OpenMPでプログラムの並列化に取り組んでいるんですが、
スレッド生成・クローズのオーバーヘッドが大きすぎて逆に遅くなってしまいます。

#pragma omp parallel for
for( int i = 0; i < N; i++ )
{
  ・逐次処理では30000クロックほどかかる処理
  ・ループ間での依存性はまったくなし
}

こうすると60000クロックくらいかかってしまうので、
スレッド生成・クローズのオーバーヘッドが30000クロックもあることになります。

このオーバーヘッドを避けたいと思い、調べていると、スレッドプールというテクニックがあることを知りました。
予めスレッドを生成しておいて、必要に応じてそれを割り当てるという方法です。
この方法だと、最初の一回だけスレッドを生成すれば後はfor文に差し掛かる度にスレッドを生成する必要がなくなります。

ただ、これを実装するのは、OpenMPとは比べ物にならないほど煩雑で気が進みません。

そこで、VC++2010で追加されたPPL(Parallel Pattern Library)がどうかと思ったのですが、
スレッド生成オーバーヘッドが小さかったり、あるいはそれを回避する手法を手軽に取れたりするでしょうか?






[ 続きを読む ] / [ 携帯版 ]

全部読む 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<196KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef