- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试生成一个合成地震数据库,其中震级($M$)在 $[M, M+\delta_M]$ 范围内的事件数量($N$)如下:
$\log_{10}(N) = a - bM$
其中 $a$ 和 $b$ 是常量。
我正在尝试使用 random
模块在 Python 中执行此操作。我知道我可以(或者至少我认为我可以 - 因为我还没有尝试过)使用 random.expovariate
但我认为我可以使用 random.random
转换如:
-math.log10(random.random()))
我对 2,000,000 个样本运行了此程序,然后将其分装到 0.1 个箱子中并在对数刻度上绘制。
红线显示了用于生成合成样本的理论分布。
我不担心 x=4.5 以上的变化。这是由于点数少和自然随机性。我要问的是 x=0 附近的点的非常小的(在这个尺度上)变化。我根据理论(蓝点)绘制了合成点的变化:
随着 x 的减少,事件的数量呈指数增加,因此与理论值的差异应该减少——而不是增加。而x=0处的点是相反意义。
为了尝试找出我的问题所在,我编写了代码,以非常精细的步骤生成从 0 到 1 的数字。然后每个数字都经过上面提到的函数。结果(上图中的蓝点)是纯线性的,与理论值完全吻合。这说明我的转换函数和代码没问题。
所以上图中 twp 点集之间的唯一区别是,蓝色点是通过调用随机函数 2,000,000 次生成的(结果然后转换为幅度并合并),而对于红色点,我已经在 0 和 1 之间采取了 2,000,000 步(然后将结果转换为大小并使用相同的代码装箱)。
所以我认为这在某种程度上与随机数生成器有关?
如有指点,将不胜感激。谢谢。
[添加]按照@Arty 的建议将调用从 random.random 更改为 random.uniform(0,1)
并且错误现在对称分布并且具有预期的幅度。已将 +- 1 标准偏差添加到图中。
显然 random()
和 uniform(0,1)
做的事情略有不同。
我使用 random.random
、random.uniform(0,1)
、np.random.random
缩减代码并计算合成数据code> 和 np.random.uniform(0, 1)
2,000,000 点。
对结果进行分箱并绘制观察到的数字和预期数字之间的差异(如下)。
还添加了 +-1 标准偏差限制。这些数字都是对称分布的,并且大小正确,表明所有随机生成器都工作正常。
我的结论是,在更改/优化代码的过程中,我引入了一个问题,但现在已经消失了。我非常想找到那个错误,这样我就不会再犯了!
令我惊讶的是,我原来的、不正确的代码可以正确执行,以至于它生成了一个看起来很真实的合成,只有一些难以检测的小异常。
感谢大家的帮助,并向那些我不同意的人道歉,他们说问题不在于随机数生成器!
最佳答案
最初我以为您可能遇到了一些数值分析问题。然而,在 python 中尝试了一百万个样本,我得到以下观察结果:
>>> T = int(1e6)
>>> xs = [ -math.log10(random.random()) for i in range(T)]
>>> len([x for x in xs if 0 <= x < 0.1])
205614
>>> len([x for x in xs if 0.1 <= x < 0.2])
163736
>>> len([x for x in xs if 0.2 <= x < 0.3])
129627
>>> len([x for x in xs if 0.3 <= x < 0.4])
103413
>>> len([x for x in xs if 0.4 <= x < 0.5])
81734
如果 X = -log_10(x) 并且 x 均匀分布在 [0, 1) 上,那么我们应该有
P(M <= X < M + d) = P(-M-d < log_10(x) <= -M) = 10^(-M) - 10^(-M-d)
而上面的数字基本完全符合这些概率,例如
1 - 10^(-0.1) = 0.205672
这与我们在上面的一百万次试验中观察到的 205614 次非常吻合。
对于上面的 python 代码,你得到的结果与我得到的结果不同吗?
关于python - 将 random.random uniform 转换为指数分布不会产生正确的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64675958/
尝试使用集成到 QTCreator 的表单编辑器,但即使我将插件放入 QtCreator.app/Contents/MacOS/designer 也不会显示。不过,相同的 dylib 文件确实适用于独
在此代码示例中。 “this.method2();”之后会读到什么?在返回returnedValue之前会跳转到method2()吗? public int method1(int returnedV
我的项目有通过gradle配置的依赖项。我想添加以下依赖项: compile group: 'org.restlet.jse', name: 'org.restlet.ext.apispark', v
我将把我们基于 Windows 的客户管理软件移植到基于 Web 的软件。我发现 polymer 可能是一种选择。 但是,对于我们的使用,我们找不到 polymer 组件具有表格 View 、下拉菜单
我的项目文件夹 Project 中有一个文件夹,比如 ED 文件夹,当我在 Eclipse 中指定在哪里查找我写入的文件时 File file = new File("ED/text.txt"); e
这是奇怪的事情,这个有效: $('#box').css({"backgroundPosition": "0px 250px"}); 但这不起作用,它只是不改变位置: $('#box').animate
这个问题在这里已经有了答案: Why does OR 0 round numbers in Javascript? (3 个答案) 关闭 5 年前。 Mozilla JavaScript Guide
这个问题在这里已经有了答案: Is the function strcmpi in the C standard libary of ISO? (3 个答案) 关闭 8 年前。 我有一个问题,为什么
我目前使用的是共享主机方案,我不确定它使用的是哪个版本的 MySQL,但它似乎不支持 DATETIMEOFFSET 类型。 是否存在支持 DATETIMEOFFSET 的 MySQL 版本?或者有计划
研究 Seam 3,我发现 Seam Solder 允许将 @Named 注释应用于包 - 在这种情况下,该包中的所有 bean 都将自动命名,就好像它们符合条件一样@Named 他们自己。我没有看到
我知道 .append 偶尔会增加数组的容量并形成数组的新副本,但 .removeLast 会逆转这种情况并减少容量通过复制到一个新的更小的数组来改变数组? 最佳答案 否(或者至少如果是,则它是一个错
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
noexcept 函数说明符是否旨在 boost 性能,因为生成的对象中可能没有记录异常的代码,因此应尽可能将其添加到函数声明和定义中?我首先想到了可调用对象的包装器,其中 noexcept 可能会产
我正在使用 Angularjs 1.3.7,刚刚发现 Promise.all 在成功响应后不会更新 angularjs View ,而 $q.all 会。由于 Promises 包含在 native
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我正在编写一个玩具(物理)矢量库,并且遇到了 GHC 坚持认为函数应该具有 Integer 的问题。是他们的类型。我希望向量乘以向量以及标量(仅使用 * ),虽然这可以通过仅使用 Vector 来实现
PHP 的 mail() 函数发送邮件正常,但 Swiftmailer 的 Swift_MailTransport 不起作用! 这有效: mail('user@example.com', 'test
我尝试通过 php 脚本转储我的数据,但没有命令行。所以我用 this script 创建了我的 .sql 文件然后我尝试使用我的脚本: $link = mysql_connect($host, $u
使用 python 2.6.4 中的 sqlite3 标准库,以下查询在 sqlite3 命令行上运行良好: select segmentid, node_t, start, number,title
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我是一名优秀的程序员,十分优秀!