php lcg_value与mt_rand生成0~1随机小数的效果对比分析


Posted in PHP onApril 05, 2017

因工作需要使用php生成0~1随机小数,之前写过一篇《php生成0~1随机小数方法》,基于mt_rand()及mt_getrandmax()实现。

后来有网友评论,php原生方法lcg_value()可实现0~1随机小数生成。

lcg_value说明

float lcg_value ( void )

lcg_value() 返回范围为 (0, 1) 的一个伪随机数。本函数组合了周期为 2^31 - 85 和 2^31 - 249 的两个同余发生器。本函数的周期等于这两个素数的乘积。

返回:范围为 (0, 1) 的伪随机数。

<?php
for($i=0; $i<5; $i++){
 echo lcg_value().PHP_EOL;
}
?>

输出:

0.11516515851995
0.064684551575297
0.68275174031189
0.55730746529099
0.70215008878091

两种生成0~1随机小数方法进行比较

1.执行时间比较

执行10万次基于mt_rand()与mt_getrandmax()算法的运行时间

<?php
/**
 * 生成0~1随机小数
 * @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;
}

// 记录开始时间
$starttime = get_microtime();

// 执行10万次获取随机小数
for($i=0; $i<100000; $i++){
 randFloat();
}

// 记录结束时间
$endtime = get_microtime();

// 输出运行时间
printf("run time %f ms\r\n", ($endtime-$starttime)*1000);
?>

输出:run time 266.893148 ms

执行10万次lcg_value()的运行时间

<?php
// 获取microtime
function get_microtime(){
 list($usec, $sec) = explode(' ', microtime());
 return (float)$usec + (float)$sec;
}

// 记录开始时间
$starttime = get_microtime();

// 执行10万次获取随机小数
for($i=0; $i<100000; $i++){
 lcg_value();
}

// 记录结束时间
$endtime = get_microtime();

// 输出运行时间
printf("run time %f ms\r\n", ($endtime-$starttime)*1000);
?>

输出:run time 86.178064 ms

执行时间上比较,因为lcg_value()直接是php原生方法,而mt_rand()与mt_getrandmax()需要调用两个方法,并需要进行计算,因此lcg_value()的执行时间大约快3倍。

2.随机效果比较

基于mt_rand()与mt_getrandmax()算法的随机效果

<?php
/**
 * 生成0~1随机小数
 * @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);
?>

随机效果图:

php lcg_value与mt_rand生成0~1随机小数的效果对比分析

lcg_value()的随机效果

php lcg_value与mt_rand生成0~1随机小数的效果对比分析

随机效果上比较,可以看出使用mt_rand()与mt_getrandmax()算法生成的随机效果较乱序,随机效果比lcg_value()较好。

总结:lcg_value()执行速度快,但随机效果不及基于mt_rand()mt_getrandmax()算法实现。

以上这篇php lcg_value与mt_rand生成0~1随机小数的效果对比分析就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php MsSql server时遇到的中文编码问题
Jun 11 PHP
php面向对象全攻略 (九)访问类型
Sep 30 PHP
破解图片防盗链的代码(asp/php)测试通过
Jul 02 PHP
PHP 文本文章分页代码 按标记或长度(不涉及数据库)
Jun 07 PHP
PHP HTML JavaScript MySQL代码如何互相传值的方法分享
Sep 30 PHP
解析php中session的实现原理以及大网站应用应注意的问题
Jun 17 PHP
discuz加密解密函数使用方法和中文注释
Jan 21 PHP
PHP函数in_array()使用详解
Aug 20 PHP
php函数实现判断是否移动端访问
Mar 03 PHP
php 解决扫描二维码下载跳转问题
Jan 13 PHP
PHP+MySQL高并发加锁事务处理问题解决方法
Apr 30 PHP
php+js实现裁剪任意形状图片
Oct 31 PHP
php str_getcsv把字符串解析为数组的实现方法
Apr 05 #PHP
php 从指定数字中获取随机组合的简单方法(推荐)
Apr 05 #PHP
php 判断页面或图片是否经过gzip压缩的方法
Apr 05 #PHP
通过php动态传数据到highcharts
Apr 05 #PHP
PHP 二维关联数组根据其中一个字段排序(推荐)
Apr 04 #PHP
EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
Apr 04 #PHP
php实现用户登陆简单实例
Apr 04 #PHP
You might like
浅析php插件 Simple HTML DOM 用DOM方式处理HTML
2013/07/01 PHP
php使用cookie保存用户登录的用户名实例
2015/01/26 PHP
[原创]PHP简单开启curl的方法(测试可行)
2016/01/11 PHP
PHP之认识(二)关于Traits的用法详解
2019/04/11 PHP
BOOM vs RR BO3 第二场2.13
2021/03/10 DOTA
图片之间的切换
2006/06/26 Javascript
基于JQuery实现CheckBox全选全不选
2011/06/27 Javascript
分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
2012/04/20 Javascript
jquery 实现checkbox全选,反选,全不选等功能代码(奇数)
2012/10/24 Javascript
eclipse如何忽略js文件报错(附图)
2013/10/30 Javascript
CSS或者JS实现鼠标悬停显示另一元素
2016/01/22 Javascript
jquery获取input type=text中的值的各种方式(总结)
2016/12/02 Javascript
Javascript中字符串相关常用的使用方法总结
2017/03/13 Javascript
Three.js入门之hello world以及如何绘制线
2017/09/25 Javascript
JavaScript 点击触发复制功能实例详解
2018/11/02 Javascript
JavaScript浅层克隆与深度克隆示例详解
2020/09/01 Javascript
python使用paramiko模块实现ssh远程登陆上传文件并执行
2014/01/27 Python
python实现超市扫码仪计费
2018/05/30 Python
Python3 Post登录并且保存cookie登录其他页面的方法
2018/12/28 Python
在pytorch中对非叶节点的变量计算梯度实例
2020/01/10 Python
python 根据列表批量下载网易云音乐的免费音乐
2020/12/03 Python
html5 Canvas绘制线条 closePath()实例代码
2012/05/10 HTML / CSS
Charlotte Tilbury美国官网:英国美妆品牌
2017/10/13 全球购物
英国Office鞋店德国网站:在线购买鞋子、靴子和运动鞋
2018/12/19 全球购物
杰夫·班克斯男士服装网上商店:Jeff Banks
2019/10/24 全球购物
心理健康心得体会
2014/01/02 职场文书
开学寄语大全
2014/04/08 职场文书
购房协议书范本(无房产证)
2014/10/07 职场文书
优秀班主任事迹材料
2014/12/16 职场文书
2014年幼儿园德育工作总结
2014/12/17 职场文书
学籍证明模板
2015/06/18 职场文书
旷工检讨书大全
2015/08/15 职场文书
《实心球》教学反思
2016/02/23 职场文书
广播稿:校园广播稿范文
2019/04/17 职场文书
Python下opencv库的安装过程及问题汇总
2021/06/11 Python
使用ORM新增数据在Mysql中的操作步骤
2021/07/26 MySQL