- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在标准库的至少一个实现中,第一次调用 std::uniform_int_distribution<>
不返回随机值,而是返回分布的最小值。也就是说,给定代码:
default_random_engine engine( any_seed() );
uniform_int_distribution< int > distribution( smaller, larger );
auto x = distribution( engine );
assert( x == smaller );
... x
实际上会是 smaller
对于 any_seed()
的任何值, smaller
, 或 larger
.
要在家一起玩,您可以尝试 code sample在 gcc 4.8.1 中演示了这个问题。
我相信这是不正确的行为?如果这是正确的行为,为什么随机分布会返回这个明显非随机的值?
最佳答案
这就是uniform_int_distribution
如果可能结果的范围小于 rng 产生的数字范围,则将随机位映射到数字:
const __uctype __uerange = __urange + 1; // __urange can be zero
const __uctype __scaling = __urngrange / __uerange;
const __uctype __past = __uerange * __scaling;
do
__ret = __uctype(__urng()) - __urngmin;
while (__ret >= __past);
__ret /= __scaling;
哪里__urange
是larger - smaller
和 __urngrange
是 rng 可以返回的最大值和最小值之间的差值。 (代码来自 libstdc++ 6.1 中的 bits/uniform_int_dist.h)
在我们的例子中,rng default_random_engine
是 minstd_rand0
, 产生 __scaling == 195225785
对于您测试的 [0,10] 范围。因此,如果 rng() < 195225785
,分布将返回 0。
第一个数字a minstd_rand0
返回是
(16807 * seed) % 2147483647
(其中 seed == 0
被调整为 1
顺便说一句)。因此我们可以看到 minstd_rand0
产生的第一个值用小于 11615 的数字播种将产生 0 与 uniform_int_distribution< int > distribution( 0, 10 );
你用过。 (修改我的错误。;))
您提到了较大种子会消失的问题:一旦种子变得足够大以实际使 mod 操作执行某些操作,我们就不能简单地将整个范围的值按除法分配给相同的输出,因此结果将看起来更好。
没有。您总是选择较小的随机 32 位种子,从而引入了明显的偏差。结果中出现的这种偏见并不令人惊讶或邪恶。对于随机种子,即使是你的 minstd_rand0
将产生一个相当均匀随机的第一个值。 (尽管之后的数字序列的统计质量不高。)
情况1:您想要统计质量高的随机数。
为此,您可以使用更好的 rng,例如 mt19937
并播种其整个状态空间。对于 Mersenne Twister,这是 624 个 32 位整数。 (作为引用,here 是我尝试通过答案中的一些有用建议正确地做到这一点。)
情况 2:您确实只想使用那些小种子。
我们仍然可以从中得到不错的结果。问题是伪随机数生成器通常“有点持续”地依赖于它们的种子。为了解决这个问题,我们丢弃了足够多的数字,让最初相似的输出序列发散。所以如果你的种子必须很小,你可以像这样初始化你的 rng:
std::mt19937 rng(smallSeed);
rng.discard(700000);
为此使用像 Mersenne Twister 这样好的 rng 是至关重要的。我不知道有什么方法可以从播种不良的种子中获得体面的值(value) minstd_rand0
,例如参见 this train-wreck .即使播种得当,mt19937
的统计特性远远优于。
您有时会听到的对大状态空间或缓慢生成的担忧在嵌入式世界之外通常是无关紧要的。根据boost和 cacert.at , MT 甚至比 minstd_rand0
快得多.
虽然您的结果肉眼看起来不错,但您仍然需要使用丢弃技巧。在我的系统上用时不到一毫秒,而且您不会经常播种 rng,所以没有理由不这样做。
请注意,我无法准确估计我们需要的丢弃物数量,我从 this answer 中获取了该值, 它链接 this paper为理性。我现在没有时间解决这个问题。
关于C++ uniform_int_distribution 总是在第一次调用时返回 min(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40020657/
我正在尝试模拟 Max-Min 和 Min-Min 调度算法,并在模拟中自己编写代码。但是不太了解如何在代码中实现它们的工作方式。 例如,在 FCFS 算法中我使用了 3 个服务器 (vms),每个服
有人可以帮我实现这个功能吗?此功能位于相机应用程序内部,该应用程序使用过滤算法来检测颜色变化等方面的差异。语法对我来说非常困难。我不知道如何处理参数中的指针、最小和最大变量语法、什么是增量等?有人可以
我遇到如图所示的表数据情况,我想从每个唯一成员中选择 min(code) 和 secondary_min(code) 。 即期望的输出看起来像 member | min(code) | s
我有一个查询,选择每小时的最小值: SELECT MIN(price), HOUR(timestamp), DATE(timestamp) FROM `scan` GROUP BY DATE(time
#include int min(int pArray[], int nrOfArrayElements) { min = pArray[0]; for (int i = 1; i
generate(vec.begin(), vec.end(), [=](){return static_cast(static_cast(ran()) /RAND_MAX*(max-min)+min
当 min 已经被定义为宏时,如何调用 std::min? 最佳答案 (std::min)(x,y) min 周围的括号防止宏扩展。这适用于所有函数宏。 关于c++ - 当 min 被定义为宏时如何调
我正在尝试对(几个)SQL 数据库中的现有数据负载进行一些转换分析。 数据结构本身非常简单。它只是一个 Actor 列表(比如 user_id)和他们所做的事情的名称。它看起来像这样(还有其他数据,但
我正在尝试根据浏览器的最小高度和最小宽度更改我页面上的 CSS,所以我正在使用它: @media (min-height: 500px), (min-width: 580px) { /* CSS
我有两张 table 。第一个表显示 id_product 和 Product_price_value。下面我将向您展示一个示例(在我的数据库中有很多行) 表:主产品 ID_product: prod
我有两个表:商品和价格(一对多) 每个项目都有一个默认价格,但是这个价格可以在第二个表中被覆盖(在某些情况下)。 首先,我在获取所有项目并预先计算最低价格 - 默认价格与其覆盖当前价格(如果有的话?)
我使用以下命令用 pandas 读取了此 Excel 工作表(仅“DATEHEUREMAX”列): xdata = read_excel('Data.xlsx', 'Data', usecols=['
我想了解min-max堆删除的过程是如何工作的,我已经搜索了它的伪代码但一无所获,而且我似乎不能在这里询问伪代码。所以这是我的问题 谁能展示“删除最小元素 7”的逻辑,至少让我知道伪代码“感觉如何”?
将 std::min 传递给函数不会编译。我将 std::min 的 libcpp 声明复制到我的源文件中并且它有效。 std 版本有什么问题? clang 和 gcc 也是如此。在 Godbolt
请看这个例子:http://jsfiddle.net/vrgT3/5/ 我用 overflow: auto; 创建了一个 250x250px 父 div,因此当内容溢出框时会出现滚动条。我设置了蓝色背
假设我有 4 个变量 a、b、x、y和一个约束 min(a,b) > min(x,y)。 我如何在 pulp python 中表示这个程序? 最佳答案 好的。所以,我发布(删除)的第一个答案有点仓促,
我刚刚经历了 THIS fiddle 和代码如下所示: 现在,当我使用 View 框并将值更改为 viewbox="100 100 225 225" 时它具有执行以下操作的效果
我有 minSdkVersion 16,我想搜索正确的支持库以便使用方法 setActionBar()(在 api 级别 21 中引入)。 我应该使用哪个 appcompat 版本?当然,我不想使用旧
bootstrap.min.css 和 bootstrap.min.js 有什么区别?为什么需要包含 bootstrap.min.js? 和 最佳答案 它们都是完整 Bootstrap 样式 (C
我是一名优秀的程序员,十分优秀!