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 相关文章推荐
php5 图片验证码实现代码
Dec 11 PHP
ajax php传递和接收变量实现思路及代码
Dec 19 PHP
CodeIgniter框架中_remap()使用方法2例
Mar 10 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(六)
Jun 23 PHP
PHP获取MySql新增记录ID值的3种方法
Jun 24 PHP
CI框架中通过hook的方式实现简单的权限控制
Jan 07 PHP
PHP中is_dir()函数使用指南
May 08 PHP
php开发时容易忘记的一些技术细节
Feb 03 PHP
Yii2.0 模态弹出框+ajax提交表单
May 22 PHP
Laravel 模型关联基础教程详解
Sep 17 PHP
laravel框架使用阿里云短信发送消息操作示例
Feb 15 PHP
PHP 数组操作详解【遍历、指针、函数等】
May 13 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 excel类 phpExcel使用方法介绍
2010/08/21 PHP
JavaScript在IE和Firefox(火狐)的不兼容问题解决方法小结
2010/04/13 Javascript
Jquery升级新版本后选择器的语法问题
2010/06/02 Javascript
基于jquery的表头固定的若干方法
2011/01/27 Javascript
基于jquery点击自以外任意处,关闭自身的代码
2012/02/10 Javascript
5秒后跳转效果(setInterval/SetTimeOut)
2013/05/03 Javascript
js innerHTML 改变div内容的方法
2013/08/03 Javascript
jquery 实现两级导航菜单附效果图
2014/03/07 Javascript
JavaScript设计模式之单例模式实例
2014/09/24 Javascript
jQuery中scrollTop()方法用法实例
2015/01/16 Javascript
javascript深拷贝(deepClone)详解
2016/08/24 Javascript
[原创]JavaScript语法高亮插件highlight.js用法详解【附highlight.js本站下载】
2016/11/01 Javascript
Vue实现virtual-dom的原理简析
2017/07/10 Javascript
javascript实现电脑和手机版样式切换
2017/11/10 Javascript
JS实现调用本地摄像头功能示例
2018/05/18 Javascript
详解关于element级联选择器数据回显问题
2019/02/20 Javascript
详解ES6 Promise的生命周期和创建
2019/08/18 Javascript
JQuery+drag.js上传图片并且实现图片拖曳
2020/11/18 jQuery
[01:15:12]DOTA2上海特级锦标赛主赛事日 - 1 败者组第一轮#4Newbee VS CDEC
2016/03/03 DOTA
[01:10]为家乡而战!完美世界城市挑战赛全国总决赛花絮
2019/07/25 DOTA
Python实现将doc转化pdf格式文档的方法
2018/01/19 Python
Python对CSV、Excel、txt、dat文件的处理
2018/09/18 Python
对python:threading.Thread类的使用方法详解
2019/01/31 Python
Django web框架使用url path name详解
2019/04/29 Python
python找出因数与质因数的方法
2019/07/25 Python
将自己的数据集制作成TFRecord格式教程
2020/02/17 Python
利用Python制作动态排名图的实现代码
2020/04/09 Python
踩坑:pytorch中eval模式下结果远差于train模式介绍
2020/06/23 Python
Python 抓取数据存储到Redis中的操作
2020/07/16 Python
python 通过pip freeze、dowload打离线包及自动安装的过程详解(适用于保密的离线环境
2020/12/14 Python
数控技术专科生自我评价
2014/01/08 职场文书
会计助理岗位职责
2014/02/17 职场文书
大学英语专业求职信
2014/06/21 职场文书
低碳环保演讲稿
2014/08/28 职场文书
2016学校先进集体事迹材料
2016/02/29 职场文书
创业开店,这样方式更合理
2019/08/26 职场文书