ソラマメブログ
プロフィール
ぺんぎん
ぺんぎん
どもっす( ◎v◎ )
ぺんぎんっす。

「ぺんぎんさん」でいいっす。
「ぺんさん」でもOKっすよ。
何だって良いんっすけどね。
[個体名:Naoya Bellic]
(非商用)
読者登録
メールアドレスを入力して登録する事で、このブログの新着エントリーをメールでお届けいたします。解除は→こちら
現在の読者数 1人

2009年01月17日

もうちょっといじるっす

MT19937(メルセンヌ・ツイスター)をLSLで書いてみたんっすけど、
問題が多いので公開は見送りっす。
どうもぺんぎんっす( ◎v◎ )


速度比較してたんっすけど、良くないっすね・・・
listに624個要素を詰めてるっていうのもマイナスポイントっす。

[実験場所] http://slurl.com/secondlife/Rekal%20Thor/244/131/37
10,000個の生成にかかる時間を比較したっす。
以下は10回の平均っす。単位は秒っす。

llFrand
LSL2: 8.48618
Mono: 0.223984

xorshift_i コード
LSL2: 15.00481
Mono: 0.109913

xorshift_f コード
LSL2: 18.15633
Mono: 0.111567

mt19937
LSL2 (記録なし ※)
Mono: 8.56182


※Script run-time error Stack-Heap Collision
というわけで測定できなかったっす。


listを初期化

listをコネコネ
↓  ↑
listから取り出してゴニョゴニョ(ここでreturnしてるっす)
っていう流れっす。

時間がかかってるのは「listをコネコネ」っす。
listの要素624個全部をコネコネしてるっすから、
かなり時間がかかってるっす。

しかも「ゴニョゴニョ」を624回するたびに「コネコネ」しないとダメっす。
つまり、初期化→コネコネで待った後は一気に進んで、
コネコネで待ってまたダーッと進んでコネコネ待ち・・・
全体的に遅いんじゃなくて、コネコネが遅いっす。

一応解決策も考えたっすけど、劇的に改善されないかぎりはお蔵入りっす。
公開もナシっす。
そうなった場合でもSFMTを頑張ってやってみるっす。
挑戦したい方は広島大学さんからCのソースを
ダウンロードしてやってみてくださいっす。
[09/02/27 追記]
 Monoコンパイルで10,000個の生成に2.4[sec]で出来るようになったっす。
 コードを公開したっす。

(注)あくまで遅いのはLSLでの話っす。
自分のコーディングに問題があるのかもっす。
メルセンヌ・ツイスターは優れたアルゴリズムっすよ。

タグ :ぺんぎん

同じカテゴリー(スクリプト)の記事画像
位置判定っす
同じカテゴリー(スクリプト)の記事
 久しぶりの新関数っす (2011-04-23 23:19)
 11日(土)のオフィスアワーっす (2010-12-10 23:49)
 C#プロジェクトは凍結みたいっす (2010-07-01 22:35)
 4月24日のスクリプターズ・カフェっす (2010-04-27 19:06)
 潜入!1.38サーバーっす (2010-03-09 22:25)
 風の観測で分かったことっす (2009-08-16 22:11)

Posted by ぺんぎん at 21:32│Comments(0)スクリプト
上の画像に書かれている文字を入力して下さい
 
<ご注意>
書き込まれた内容は公開され、ブログの持ち主だけが削除できます。