"stats_rand_gen_normal()" 的替代方法。
<?php
/**
* 基于“Box–Muller 变换”的随机偏差生成器。
*
* @ref https://en.wikipedia.org/wiki/Box%E2%80%93Muller_transform
*
* @param float|int $av 平均值/均值
* @param float|int $sd 标准差
* @return float
*/
if (! function_exists('stats_rand_gen_normal')) {
function stats_rand_gen_normal($av, $sd): float
{
$x = mt_rand() / mt_getrandmax();
$y = mt_rand() / mt_getrandmax();
return sqrt(-2 * log($x)) * cos(2 * pi() * $y) * $sd + $av;
}
}
?>