博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS随机数生成算法
阅读量:6302 次
发布时间:2019-06-22

本文共 2340 字,大约阅读时间需要 7 分钟。

------------------------------------------

知乎上边淘到的知识,又学到了~

http://www.zhihu.com/question/22818104

------------------------------------------

 

见到这个随机数生成算法好几次了,乍看有点鸡肋本来用Math.random()就可以的事。想不清楚为什么他要用9301,49297,233280这三个数字?其中有道理吗?还是仅是随意选的三个数?但是这个组合貌似流传很广。好多小网站源码里都见到过。

function rnd( seed ){
seed = ( seed * 9301 + 49297 ) % 233280; //为何使用这三个数? return seed / ( 233280.0 );};function rand(number){
today = new Date(); seed = today.getTime(); return Math.ceil( rnd( seed ) * number );};myNum=(rand(5)); Google了一下这3个数字,一些说法也是人云亦云没有找到合理的解释。 例如:
You may ask: 
Why ‘(seed * 9301 + 49297) % 233280‘ ?!
The answer is both simple&complicated: The combination of 9301, 49297 and 233280 provide a very even distributed set of “random” numbers. Please don’t ask WHY – that’s the complicated part, some very smart people figured out those numbers quite some time ago, and I also cannot tell you how they did it.
很聪明的前人算出来的?。。。 ============================================================= 又找到一个页面  好像有列举,但是没能看懂,ACM之类的。。,有人能解释下不?
Simple (bad) Psuedo Random Number Generator (Sic)The low bit typically just toggles between calls.random() {   seed = ( seed * mulitiplier + increment ) % modulus;   return seed;}Table of Good values   Multiplier    Increment     Modulus      25173         13849        65536       9301         49297       233280
=+=+=+=+=+=+=+=+=+=+=+=+==+=+=+=+=+=+=+=+=+=+=+=+= 简陋的分割线 =+=+=+=+=+=+=+=+=+=+=+=+==+=+=+=+=+=+=+=+=+=+=+=+=
here is the answer: 很多人认为这是简单的Magic Number,其实这背后有内在的原因,这三个数字并不是随便乱选出来的。 入门级的选择标准 这种伪随机数生成器叫做线性同余生成器(LCG, Linear Congruential Generator),几乎所有的运行库提供的rand都是采用的LCG,形如: 生成的伪随机数序列最大周期m,范围在0到m-1之间。要达到这个最大周期,必须满足
  • c与m互质
  • a - 1可以被m的所有质因数整除
  • 如果m是4的倍数,a - 1也必须是4的倍数
以上三条被称为Hull-Dobell定理。 作为一个伪随机数生成器,周期不够大是不好意思混的,所以这是要求之一。 可以看到,a=9301, c = 49297, m = 233280这组参数,以上三条全部满足。 进阶级的选择标准 要在伪随机数生成器界混,仅仅入门是不够的。 从工程的角度来讲,的值要(在合理的范围内)足够小,以避免溢出的问题。 从安全(实用)性的角度来讲,还要满足良好的随机性,这一点可以通过Knunth's Spectral Test来评估(见[2]),要通过2,3,4,5以及6维的Spectral Test才行。Spectral Test考察的就是生成的伪随机数序列在超空间的网格结构(lattice structure),当年IBM的RNADU子程序闹出的乌龙,连3维的Spectral Test就不能通过,上图嘲讽下: 其中每个点代表三个连续的RANDU生成的伪随机数值,可以看到所有伪随机数分布在了15个二维平面上。 在这种要求面前,c的值最好:
  • 是质数 (c = 49297就是质数)
  • 接近(\frac{1}{2}-\frac{1}{6}\sqrt{3} )m,(m = 233280时为49297.86460172205)
所以有了这样一些基本的标准,能够选择的参数范围就小了很多,弄个程序跑下Spectral Test,就能得到可选的参数组。 参考资料: [1]  [2] 

转载于:https://www.cnblogs.com/yangtze736-2013-3-6/p/3563954.html

你可能感兴趣的文章
9个offer,12家公司,35场面试,从微软到谷歌,应届计算机毕业生的2012求职之路...
查看>>
lvs fullnat部署手册(三)rs内核加载toa篇
查看>>
C++策略模式
查看>>
我的友情链接
查看>>
oracle表分区详解
查看>>
网络编程中常见结构体
查看>>
SSL/TLS原理详解
查看>>
Docker 自定义SSH服务镜像
查看>>
JavaScript强化教程 —— Cocos2d-JS自动JSB绑定规则修改
查看>>
configure: error: in `/root/httpd-2.2.11/srclib/apr': c
查看>>
CentOS7搭建Kubernetes-dashboard管理服务
查看>>
buildroot下查找外部编译器通过ext-toolchain-wrapper调用的参数
查看>>
MySQL Replication 主主配置详细说明
查看>>
Linux的任务调度
查看>>
在Android studio中添加jar包方法如下
查看>>
iframe 在ie下面总是弹出新窗口解决方法
查看>>
分享10款漂亮实用的CSS3按钮
查看>>
安装nginx 常见错误及 解决方法
查看>>
Gorun8电子商城
查看>>
在之前链表的基础上改良的链表
查看>>