php lcg_value與mt_rand生成0~1隨機(jī)小數(shù)的效果對(duì)比分析
因工作需要使用php生成0~1隨機(jī)小數(shù),之前寫過一篇《php生成0~1隨機(jī)小數(shù)方法》,基于mt_rand()及mt_getrandmax()實(shí)現(xiàn)。
后來有網(wǎng)友評(píng)論,php原生方法lcg_value()可實(shí)現(xiàn)0~1隨機(jī)小數(shù)生成。
lcg_value說明
float lcg_value ( void )
lcg_value() 返回范圍為 (0, 1) 的一個(gè)偽隨機(jī)數(shù)。本函數(shù)組合了周期為 2^31 - 85 和 2^31 - 249 的兩個(gè)同余發(fā)生器。本函數(shù)的周期等于這兩個(gè)素?cái)?shù)的乘積。
返回:范圍為 (0, 1) 的偽隨機(jī)數(shù)。
<?php for($i=0; $i<5; $i++){ echo lcg_value().PHP_EOL; } ?>
輸出:
0.11516515851995
0.064684551575297
0.68275174031189
0.55730746529099
0.70215008878091
兩種生成0~1隨機(jī)小數(shù)方法進(jìn)行比較
1.執(zhí)行時(shí)間比較
執(zhí)行10萬次基于mt_rand()與mt_getrandmax()算法的運(yùn)行時(shí)間
<?php /** * 生成0~1隨機(jī)小數(shù) * @param Int $min * @param Int $max * @return Float */ function randFloat($min=0, $max=1){ return $min + mt_rand()/mt_getrandmax() * ($max-$min); } // 獲取microtime function get_microtime(){ list($usec, $sec) = explode(' ', microtime()); return (float)$usec + (float)$sec; } // 記錄開始時(shí)間 $starttime = get_microtime(); // 執(zhí)行10萬次獲取隨機(jī)小數(shù) for($i=0; $i<100000; $i++){ randFloat(); } // 記錄結(jié)束時(shí)間 $endtime = get_microtime(); // 輸出運(yùn)行時(shí)間 printf("run time %f ms\r\n", ($endtime-$starttime)*1000); ?>
輸出:run time 266.893148 ms
執(zhí)行10萬次lcg_value()的運(yùn)行時(shí)間
<?php // 獲取microtime function get_microtime(){ list($usec, $sec) = explode(' ', microtime()); return (float)$usec + (float)$sec; } // 記錄開始時(shí)間 $starttime = get_microtime(); // 執(zhí)行10萬次獲取隨機(jī)小數(shù) for($i=0; $i<100000; $i++){ lcg_value(); } // 記錄結(jié)束時(shí)間 $endtime = get_microtime(); // 輸出運(yùn)行時(shí)間 printf("run time %f ms\r\n", ($endtime-$starttime)*1000); ?>
輸出:run time 86.178064 ms
執(zhí)行時(shí)間上比較,因?yàn)閘cg_value()直接是php原生方法,而mt_rand()與mt_getrandmax()需要調(diào)用兩個(gè)方法,并需要進(jìn)行計(jì)算,因此lcg_value()的執(zhí)行時(shí)間大約快3倍。
2.隨機(jī)效果比較
基于mt_rand()與mt_getrandmax()算法的隨機(jī)效果
<?php /** * 生成0~1隨機(jī)小數(shù) * @param Int $min * @param Int $max * @return Float */ function randFloat($min=0, $max=1){ return $min + mt_rand()/mt_getrandmax() * ($max-$min); } header('content-type: image/png'); $im = imagecreatetruecolor(512, 512); $color1 = imagecolorallocate($im, 255, 255, 255); $color2 = imagecolorallocate($im, 0, 0, 0); for($y=0; $y<512; $y++){ for($x=0; $x<512; $x++){ $rand = randFloat(); if(round($rand,2)>=0.5){ imagesetpixel($im, $x, $y, $color1); }else{ imagesetpixel($im, $x, $y, $color2); } } } imagepng($im); imagedestroy($im); ?>
隨機(jī)效果圖:
lcg_value()的隨機(jī)效果
隨機(jī)效果上比較,可以看出使用mt_rand()與mt_getrandmax()算法生成的隨機(jī)效果較亂序,隨機(jī)效果比lcg_value()較好。
總結(jié):lcg_value()執(zhí)行速度快,但隨機(jī)效果不及基于mt_rand()與mt_getrandmax()算法實(shí)現(xiàn)。
以上這篇php lcg_value與mt_rand生成0~1隨機(jī)小數(shù)的效果對(duì)比分析就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
PHP遞歸實(shí)現(xiàn)文件夾的復(fù)制、刪除、查看大小操作示例
這篇文章主要介紹了PHP遞歸實(shí)現(xiàn)文件夾的復(fù)制、刪除、查看大小操作,結(jié)合實(shí)例形式分析了php遞歸算法結(jié)合php常用文件夾操作函數(shù)實(shí)現(xiàn)文件夾的復(fù)制、刪除、查看等相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-08-08PHP利用func_get_args和func_num_args函數(shù)實(shí)現(xiàn)函數(shù)重載實(shí)例
這篇文章主要介紹了PHP利用func_get_args和func_num_args函數(shù)實(shí)現(xiàn)函數(shù)重載的方法,實(shí)例展示了PHP實(shí)現(xiàn)重載的具體方法,是非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11PHP編程計(jì)算文件或數(shù)組中單詞出現(xiàn)頻率的方法
這篇文章主要介紹了PHP編程計(jì)算文件或數(shù)組中單詞出現(xiàn)頻率的方法,給出了2個(gè)統(tǒng)計(jì)單詞頻率的示例,涉及php正則、數(shù)組操作及字符串遍歷等相關(guān)技巧,需要的朋友可以參考下2017-05-05PHP中使用虛代理實(shí)現(xiàn)延遲加載技術(shù)
這篇文章主要介紹了PHP中使用虛代理實(shí)現(xiàn)延遲加載技術(shù),延遲加載是一種領(lǐng)域模型設(shè)計(jì)一種架構(gòu)模式,需要的朋友可以參考下2014-11-11PHP下用rmdir實(shí)現(xiàn)刪除目錄的三種方法小結(jié)
PHP本身有一個(gè)rmdir()函數(shù)可以用來刪除目錄,不過要求必須是空目錄,本文列舉了三種方法。1、遞規(guī)法;2、系統(tǒng)調(diào)用法;3、循環(huán)法 。2008-04-04php park、unpark、ord 函數(shù)使用方法(二進(jìn)制流接口應(yīng)用實(shí)例)
在工作中,我也逐漸了解到park,unpark,ord對(duì)于二進(jìn)制字節(jié)處理的強(qiáng)大。 下面我逐一介紹它們。2010-10-10PHP遠(yuǎn)程連接oracle數(shù)據(jù)庫操作實(shí)現(xiàn)方法圖文詳解
這篇文章主要介紹了PHP遠(yuǎn)程連接oracle數(shù)據(jù)庫操作實(shí)現(xiàn)方法,結(jié)合圖文形式詳細(xì)分析了php連接Oracle數(shù)據(jù)庫的相關(guān)配置、實(shí)現(xiàn)方法、遇到的問題、解決方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-04-04