« 2010年4月19日

2010年4月20日の投稿

2010年4月23日 »

HTML5で多くのAPIが拡張されます。そのうちのひとつであるWeb Workersを少し使ってみたいと思います。使用したい理由はChrome等の昨今のブラウザはマルチプロセス化がトレンドですが、Javascriptの実行処理部分がどの程度マルチスレッドに対応しているか調べてみたかったためです。

そこでサンプルとしてモンテカルロシミュレーションで円周率をJavascriptで計算したスクリプトをWeb Workersに対応させました。ソースは、ソース置き場のwebworkerssample.zipにあります。解凍してwebworkerssample.htmlをブラウザ(Firefox,Chrome,Safariのどれか)で開いていください。

モンテカルロシミュレーションでの円周率の求め方に関しては、ネット上に取り上げらていますので解説しません。ここでWeb Workersを使い方は、ループ回数をスレッド数で割った値を各スレッドに依頼し、計算が終了したらその結果を本体に渡して合計して計算します。作りは以下の様になっています。

■動作イメージ

workersにランダムで出した2点が1/4 円に収まる回数を計算させています。本体が各workersから帰ってきた値を集計して円周率を求めます(精度はかなり低いですが)。

■動作画面

loopとthreadを指定して"π cal"をクリックしてください。計算が始まります。また、threadやloopを変更して何度も測定できます。さらに、threadを0にした場合はWeb Workersを使用しないでそのままループに入ります。その場合だけstatusが変わりませんし、UI部分が遅くなることがあります。

このサンプルを動作させたときの各ブラウザ(Firefox、Chroem、Safari)のスレッド毎の時間を測定しました。OperaとIEをハブしたのはWeb Workersがサポートされていないためです。測定したPCは4コアのPhenom II X4 950BE(3.0GHz)です。ループ回数は40,000,000回実施しています。

ループ回数は、thread=0の時にこのスペックでSafariが途中で止まらない値だからです。また、threadが16個までしかないのはChromeが16個までしかサポートしていないためです。

以下がスレッド数と計測時間の関係です。値が小さいほど高速であることを示しています。

測定中に変わっていたのはFirefoxの動作です。ChromeとSafariは4スレッド以上を指定するとCPUが100%使用されます。これは予想通りの事象です。ですが、Firefoxは75%前後までしか上がりません。どうも最後のコアを使用しないような作りになっているように思えます。

以下が4スレッド時のCPU使用率です。

■Chrome

■Safari

■Firefox

Web Workersを使ってモンテカルロシミュレーションの計算時間を短くすることができました。これで処理が重い処理をブラウザで行う場合のやり方が実現できました。

Web Workersを使用して以下の点に気づきました。

・デバッグできない(console、alert、IDEも効かない...これは既にWEB上で公開されている情報)
・ブラウザ毎の動作が違いすぎる(動かなかったり、スレッド数の上限やCPUコアの使用数など)
・スレッドセーフ(スレッドから戻ってきたところで排他処理になっているようだ)

特にデバッグができない問題は相当な大きいと思います。IDEがないと目をつぶって歩くことを強要されている感じがします。このあたりが改善されないとWeb Workersに対応したWEBアプリが出てこないでしょう。

Web WorkerはWebSocketのために作られたのかも知れませんが、それでも昨今のマルチコアCPUをJavascriptで使い尽くすにはWeb Worker以外の選択肢がないのですからブラウザメーカーの方々にはIDEの対応をお願いしたいものです。

【Javascript関係】
Firefox 3.1のJavascriptマルチスレッドプログラミングができるweb workersを使ってみる
V8 Benchmark Suite V5をいじってみた
バージョン別ブラウザシェアをグラフ化してみた

櫻吉 清(さくらきち きよし)

« 2010年4月19日

2010年4月20日の投稿

2010年4月23日 »

» このブログのTOP

» オルタナティブ・ブログTOP



プロフィール

櫻吉 清

櫻吉 清

IT業界ウオッチを趣味としている。知的好奇心の趣くままに何でもチャレンジして、とりあえず壁にぶつかってみる。

詳しいプロフィール

Special

- PR -
カレンダー
2013年4月
  1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30        
kichi
Special オルタナトーク

仕事が嫌になった時、どう立ち直ったのですか?

カテゴリー
エンタープライズ・ピックアップ

news094.gif 顧客に“ワォ!”という体験を提供――ザッポスに学ぶ企業文化の確立
単に商品を届けるだけでなく、サービスを通じて“ワォ!”という驚きの体験を届けることを目指している。ザッポスのWebサイトには、顧客からの感謝と賞賛があふれており、きわめて高い顧客満足を実現している。(12/17)

news094.gif ちょっとした対話が成長を助ける――上司と部下が話すとき互いに学び合う
上司や先輩の背中を見て、仕事を学べ――。このように言う人がいるが、実際どのようにして学べばいいのだろうか。よく分からない人に、3つの事例を紹介しよう。(12/11)

news094.gif 悩んだときの、自己啓発書の触れ方
「自己啓発書は説教臭いから嫌い」という人もいるだろう。でも読めば元気になる本もあるので、一方的に否定するのはもったいない。今回は、悩んだときの自己啓発書の読み方を紹介しよう。(12/5)

news094.gif 考えるべきは得意なものは何かではなく、お客さまが高く評価するものは何か
自社製品と競合製品を比べた場合、自社製品が選ばれるのは価格や機能が主ではない。いかに顧客の価値を向上させることができるかが重要なポイントになる。(11/21)

news094.gif なんて素敵にフェイスブック
夏から秋にかけて行った「誠 ビジネスショートショート大賞」。吉岡編集長賞を受賞した作品が、山口陽平(応募時ペンネーム:修治)さんの「なんて素敵にフェイスブック」です。平安時代、塀に文章を書くことで交流していた貴族。「塀(へい)に嘯(うそぶ)く」ところから、それを「フェイスブック」と呼んだとか。(11/16)

news094.gif 部下を叱る2つのポイント
叱るのは難しい。上司だって人間だ、言いづらいことを言うのには勇気がいるもの。役割だと割り切り、叱ってはみたものの、部下がむっとしたら自分も嫌な気分になる。そんな時に気をつけたいポイントが2つある。(11/14)

news094.gif 第6回 幸せの創造こそ、ビジネスの使命
会社は何のために存在するのでしょうか。私の考えはシンプルです。人間のすべての営みは、幸せになるためのものです――。2012年11月発売予定の斉藤徹氏の新著「BE ソーシャル!」から、「はじめに」および、第1章「そして世界は透明になった」を6回に分けてお送りする。(11/8)

オルタナティブ・ブログは、専門スタッフにより、企画・構成されています。入力頂いた内容は、アイティメディアの他、オルタナティブ・ブログ、及び本記事執筆会社に提供されます。


サイトマップ | 利用規約 | プライバシーポリシー | 広告案内 | お問い合わせ