GNU C库中PRNG的周期是什么
What is the periodicity of the PRNG in GNU C Library?
有关于gcc的g++中随机数生成器的周期性的文献吗(如果我们不重新播种函数)?我想我可以自己进行测试,但最好能获得经过充分验证的研究。
提前感谢您的帮助。
//编辑
我只是想补充一点,我已经搜索了很多,有多个引擎,但我没有找到任何具体的东西。我只阅读了关于周期性受到表示种子所需比特数限制的一般评论。(所以我想,考虑到srand通常是随时间调用的,周期性可能不超过10^12左右。但在我开始实现我的算法之前,更明确的东西会非常有帮助。)
在rand(3)手册页中搜索时,我发现了以下内容:
中rand()和srand()的版本Linux C库使用相同的随机数生成器为random()和srandom()
所以我看了一下随机的手册页,下面是你的答案:
这个随机数的周期发电机非常大,大约16*((2**31)-1)
这对于教学来说是非常有用的,因为你想发展自己的PRNG。但是,我不建议您在开发应用程序时使用此PRNG。你应该更喜欢Neil Butterworth建议的BoostRandom的实现(MT19937是一个很好的默认PRNG,对于大多数应用程序来说已经足够了)。
最后,如果你想了解更多关于PRNG的信息,我建议你阅读这两篇科学文章,很好地调查PRNG。
用于随机高性能计算的随机流的实际分布 ,David RC Hill,在国际高性能计算与仿真会议(HPCS)上,2010
伪随机数生成器 ,Pierre L'Ecuyer,在量化金融百科全书中量化金融百科全书,2008
srand/rand函数有点坏。由于您正在使用C++,我强烈建议您使用boost随机数库。它是一个只有头的库,所以您不需要构建任何东西。这里有一个如何使用它的例子。
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- cin和cout对象的生命周期是什么?C++
- 提供一个不确定的生命周期bool在线程之间共享的最简单的方法是什么?
- 作为事件接收器使用的CCmdTarget的正确生命周期管理是什么?
- GNU C库中PRNG的周期是什么