- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
在 JavaScript 中获取 [0, n) 范围内的随机整数的标准方法——或任何其他仅提供返回 [0,1) 范围内的 float 的 random() 函数的语言——是使用Math.floor(Math.random() * n)
。
假设我们对有理数集进行运算,那么这背后的数学就很简单了。问题是:由于 IEEE-754 float 的所有复杂性,最终的分布真的是均匀的吗?
考虑到一个 float 和下一个更高的 float 之间的差距随着它们变大而增加,我认为这应该引入某种偏向于较小数字的偏差。
最佳答案
不,对于 n
的大多数值,结果分布不会完全均匀。对于较小的值,它会非常接近均匀,以至于您很难从均匀分布中检测出任何差异,但随着 n
变大,偏差会变得很明显。
为了说明,这里有一些 Python 代码(不是 JavaScript,抱歉,但原理是一样的):
from collections import Counter
from random import random
def badrand(n):
return int(random() * n)
print(Counter(badrand(6755399441055744) % 3 for _ in range(10000000)))
这将生成 [0, 6755399441055744)
范围内的 1000 万个随机整数,将这些整数中的每一个减去模 3,并计算余数为 0、1 或 2 的次数。如果我们均匀地生成这些整数,我们希望余数模 3 大致均匀分布,因此我们希望计数相似。
这是在我的机器上运行它的示例结果:
Counter({1: 3751915, 0: 3334643, 2: 2913442})
也就是说,1
的余数 显着 比 0
更有可能出现,而 0
又比 更有可能出现2
的余数。这里的差异方式太大,无法用随机变化来解释。
那么到底出了什么问题呢? Python 的random()
函数质量比较高,基于Mersenne Twister。 ,所以我们不太可能看到由基本随机数生成器引起的统计问题。发生的事情是 random()
生成 2^53(大致)等可能结果之一 - 每个结果都是 x/2^53
形式的数字,表示某个整数x
在 [0, 2^53)
范围内。现在在 badrand
调用中,我们有效地将这些结果映射到 6755399441055744
可能的输出。现在这个值不是随机选择的(哈!);它正好是 2^53 的 3/4。这意味着在可能的最均匀分布下,2/3 可能的 badrand
输出值恰好被 2^53 个可能的 random()
输出值之一击中,而另外 1/3 被 2^53 个可能的 random()
输出值中的 两个 击中。也就是说,某些潜在输出的发生概率是其他输出的两倍。所以我们离制服还有很长的路要走。
您将在 JavaScript 中看到相同的效果。对于 Chrome,似乎 there are only 2^32 distinct results来自 Math.random()
,因此您应该能够找到类似上面的 n
小于(但接近)2^32 的效果。
当然,同样的效果也适用于小的n
:如果n = 5
,那么因为5
不是2^32
我们无法将所有 2^32
可能的 Math.random()
结果完美均匀地分布在 5 个期望结果之间:我们最好希望的是 5 个结果中的 4 个出现在 858993459 个可能的 random()
结果中,而第五个出现在 858993460 个 random()
结果中.但这种分布将非常接近均匀,以至于几乎不可能找到任何统计测试来告诉你不同的结果。因此,出于实际目的,使用较小的 n
应该是安全的。
http://bugs.python.org/issue9025 上有一个相关的 Python 错误可能很有趣.通过放弃计算这些数字的 int(random() * n)
方法,Python 3 解决了该错误。错误依旧remains不过在 Python 2 中。
关于javascript - 使用浮点源均匀分布整数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32360671/
语境 我正在将一个旧的 php 电子商务网站变成一个用 gatsby.js 构建的静态网站。 我将所有产品元数据放入单独的 .json 文件(每个产品一个),并且我能够使用 json 和文件转换器插件
我曾经能够使用三指向上滚动在源/标题之间切换。自从升级到 Lion 后,我只进行常规滚动。有没有办法恢复该功能? Aka,当我像以前那样向上/向下滚动时,它不会跳到对应的位置。 更新 Apple 在
我有一个包含复选框输入的克隆元素。当克隆的元素未被选中时,我需要也取消选中源元素。有没有办法在 jQuery 中做到这一点?或者我是否以错误的方式处理这个问题(即使用clone())?我应该提到我的问
我有一个类,其中有两个 JSpinner 对象,x 和 y。我有一个更改监听器,它已添加到两者中。有人可以告诉我如何实现我的更改监听器,以便监听器可以区分两个对象之间的区别。例如伪代码: if(sou
我正在编写涉及 for 循环的代码,该循环在每个索引处进行计算。 这些计算中的最小值存储在一个变量中,我在程序末尾使用 MPI_Allreduce 来确定所有进程的全局最小值。 但是,我需要一种方法来
我需要在一个 Android 项目中创建一个 map View ,我从服务器获取自定义 map 图 block PNG。有人知道实现此类功能的简单许可 API 吗? 最佳答案 我使用了 OsmDroi
因为我必须创建一个可以更改图像 (src/background-url) 的函数。我想知道如何识别标签以及它是使用 src 还是 url 来访问图像。 让我们说 早些时候我写了一个可以
当我使用源 map 浏览器 https://github.com/danvk/source-map-explorer要检查捆绑包中的内容,我得到以下输出: D:\projects\angular\mT
我正在为客户将 Windev 应用程序移植到 Objective-C。出于显而易见的原因,使用以前的源代码会更简单。 不幸的是,它是加密的,我需要 EDI 才能看到它;完整版的 Windev 太贵了(
我有一个简单的视频播放器,它使用 WPF MediaElement 播放一系列视频。这些视频一起形成一个围绕静止图像移动的连续电影。在每个视频结束时,运动会卡住在当前播放视频的最后一帧。当我按下一个按
我需要更改 openlayer 的图层源(使用 open weather api)。目前我正在使用以下代码但没有成功。 let layer = this.map.getLayers().getArra
我正在尝试在 /dev/random 的机器上运行代码不会很快填满,我正在尝试使用的 Java 程序因缺少随机数而挂起。/dev/urandom产生“不太好”的随机数,但不会阻塞,对于这种情况,我宁愿
我需要 Yocto 项目的源代码包。我已经拥有整个项目的所有资源,但它们还包括开发工具。 我想有一种方法来生成将为目标图像构建的所有包的(修补的)源。因此,例如,如果目标图像包含 busybox,我想
如何对入侵者隐藏 iFrame src 假设我正在流式传输我的网络摄像头或我的电脑屏幕,这是 iframe 代码: 并且我不希望它在大多数浏览器上显示页面源中的流 URL 和检查功能! 这意
是否可以进入 Qt 源,例如qmainwindow.cpp,在 Qt Creator 中?目前我正在看到反汇编,但最好能看到源代码。 最佳答案 当然!但您可能必须首先: 转到 $QT_HOME/qt
我正在尝试创建一个包含很少动漫剧集的简单网站。我有一个关于 javascript 的问题。如何通过单击我的链接之一来更改视频源?我明白,我必须使用事件监听器,只需更改 取决于我点击的链接,但我不太擅长
我有一个带有 BindingSouce 的 DevExpress GridControl。我想清除 BindingSource 并用新数据填充它。我这样做: var list = new List()
当单击提交输入按钮时,我尝试将其他参数(选定复选框的列表)传递到服务器处理的 DataTables 表#my_table: 这可能意味着我必须将 my_table.sAjaxSource 设置为后端脚
(好吧,别对我大喊大叫,这里已经很晚了:)) 我正在研究 delta diff 工具(命令行工具或组件,只要我可以从 Delphi 2010 调用它们就可以了) 我有这个项目,我将文件上传到服务器,我
我需要解析 Yahoo Weather RSS feed 中的某个位置,例如 http://weather.yahooapis.com/forecastrss?w=44418&u=c例如,获取最高、最
我是一名优秀的程序员,十分优秀!