PHP数学函数实践五:获取随机浮点数
今天将继续给大家带来PHP数学函数实践系列的内容,那么在上一篇文章《PHP数学函数实践四:将浮点数从零舍入到指定的小数位数》中给大家介绍了怎么将将浮点数从零舍入到指定的小数位数,有需要的朋友可以学习了解一下~
本文的主题内容则是教大家怎么编写一个 PHP 函数来获取随机浮点数。
首先给大家简单介绍一下什么是浮点数,浮点数也叫双精度数或实数,在PHP中可以用以下任何语法定义:
下面我就直接介绍获取随机浮点数的实现方法:
PHP代码示例如下:
$end_num) return false; return mt_rand($st_num*$mul,$end_num*$mul)/$mul; } echo rand_float()."
"; echo rand_float(0.6)."
"; echo rand_float(0.5,0.6)."
"; echo rand_float(0,20)."
"; echo rand_float(0,3,2)."
"; echo rand_float(0,2,20)."
"; ?>
输出结果是:
0.353804 0.715058 0.598421 13.484704 0.5 1.4
刷新运行效果如下:
如上所示,我们可以获取随机浮点数了。
这里给大家介绍一个函数mt_rand
函数:
mt_rand() 函数使用 Mersenne Twister 算法生成随机整数。
该函数是产生随机值的更好选择,返回结果的速度是 rand() 函数的 4 倍;如果您想要一个介于 10 和 100 之间(包括 10 和 100)的随机整数,请使用 mt_rand (10,100)。
语法是:
mt_rand(); or mt_rand(min,max);
返回值是介于 min(或 0)与 max(或 mt_getrandmax())之间(包括边界值)的随机整数。如果 max < min 则返回 FALSE。
注:浮点数的精度 浮点数的精度有限。尽管取决于系统,PHP 通常使用 IEEE 754 双精度格式,则由于取整而导致的最大相对误差为 1.11e-16。非基本数学运算可能会给出更大误差,并且要考虑到进行复合运算时的误差传递。 此外,以十进制能够精确表示的有理数如 0.1 或 0.7,无论有多少尾数都不能被内部所使用的二进制精确表示,因此不能在不丢失一点点精度的情况下转换为二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999999991118...。 所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。
以上就是PHP数学函数实践五:获取随机浮点数的详细内容,更多请关注毛票票其它相关文章!