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中的串行化变量和序列化对象
Sep 05 PHP
PHP新手上路(七)
Oct 09 PHP
在PHP中检查PHP文件是否有语法错误的方法
Dec 23 PHP
php设计模式之观察者模式的应用详解
May 21 PHP
如何使用FireFox插件FirePHP调试PHP
Jul 23 PHP
标准版Eclipse搭建PHP环境的详细步骤
Nov 18 PHP
php数组函数array_walk用法示例
May 26 PHP
php实现生成带二维码图片并强制下载功能
Feb 24 PHP
php根据命令行参数生成配置文件详解
Mar 15 PHP
PHP使用观察者模式处理异常信息的方法详解
Sep 24 PHP
Laravel框架控制器的middleware中间件用法分析
Sep 30 PHP
thinkphp5框架路由原理与用法详解
Feb 11 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
通过html表格发电子邮件
2006/10/09 PHP
php tp验证表单与自动填充函数代码
2012/02/22 PHP
PHP中的Streams详细介绍
2014/11/12 PHP
typecho插件编写教程(五):核心代码
2015/05/28 PHP
php数组随机排序实现方法
2015/06/13 PHP
JS window.opener返回父页面的应用
2009/10/24 Javascript
为指定元素增加样式的js代码
2009/12/09 Javascript
jquery提取元素里的纯文本不包含span等里的内容
2013/09/30 Javascript
javascript中bind函数的作用实例介绍
2014/09/28 Javascript
JavaScript中pop()方法的使用教程
2015/06/09 Javascript
javascript 常见功能汇总
2015/06/11 Javascript
Jquery实现弹性滑块滑动选择数值插件
2015/08/08 Javascript
ui组件之input多选下拉实现方法(带有搜索功能)
2016/07/14 Javascript
基于JavaScript实现树形下拉框
2016/08/10 Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
2020/11/30 Javascript
javascript实现动态显示颜色块的报表效果
2017/04/10 Javascript
结合Vue控制字符和字节的显示个数的示例
2018/05/17 Javascript
微信小程序如何获取用户收货地址
2018/11/27 Javascript
jQuery事件绑定和解绑、事件冒泡与阻止事件冒泡及弹出应用示例
2019/05/13 jQuery
利用JavaScript的Map提升性能的方法详解
2019/08/14 Javascript
Python3基础之基本运算符概述
2014/08/13 Python
Python实现周期性抓取网页内容的方法
2015/11/04 Python
windows10系统中安装python3.x+scrapy教程
2016/11/08 Python
Python与R语言的简要对比
2017/11/14 Python
浅谈django rest jwt vue 跨域问题
2018/10/26 Python
numpy 声明空数组详解
2019/12/05 Python
将pycharm配置为matlab或者spyder的用法说明
2020/06/08 Python
用CSS3将你的设计带入下个高度
2009/08/08 HTML / CSS
Vans奥地利官方网站:美国原创极限运动潮牌
2018/09/30 全球购物
Yahoo-PHP面试题2
2014/12/06 面试题
致1500米运动员广播稿
2014/02/07 职场文书
简单租房协议书
2014/04/09 职场文书
大学新生军训自我鉴定范文
2014/09/13 职场文书
班主任师德师风自我剖析材料
2014/10/02 职场文书
区域经理岗位职责
2015/02/02 职场文书
Win11黑色桌面背景怎么办?Win11黑色壁纸解决方法汇总
2022/04/05 数码科技