我是靠谱客的博主 合适蛋挞,最近开发中收集的这篇文章主要介绍关于真随机数生成器,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

有关如何产生随机数的理论有许多,如果要详细地讨论,需要厚厚的一本书的篇幅。 

有限状态机不能产生真正的随机数的,所以在现在的计算机中并没有一个真正的随机数生成算法,现有的随机数生成算法生产的随机数只不过因为重复的周期比较大,可以做到使产生的数字重复率很低,这样看起来好象是真正的随机数,一般称作叫伪随机数发生器。 

真正的随机数是使用物理现象产生的:比如掷钱币、骰子、转轮、使用电子元件的噪音、核裂变等等。这样的随机数发生器叫做物理性随机数发生器,它们的缺点是技术要求比较高。真随机数生产效率没有伪随机数高,还有就是"信息熵的信息量如果很有限的话,就不是一定是真的随机数了。

还有人质疑真正的随机数的存在,这是哲学问题,不在此涉及。 

查了下现有的真随机数生成器,比如PuTTYgen的随机数是让用户移动鼠标达到一定的长度,之后把鼠标的运动轨迹转化为种子;Intel通过电阻和振荡器来生成热噪声作为信息熵资源;Unix/Linuxdev/random/dev/urandom采用硬件噪音生成随机数;(待补充) 

基于特定Intel芯片组中random number generator(RNG)单元的真随机数生成器.Intel 815E芯片组的个人电脑上安装Intel Security Driver(ISD),可以通过编程读取寄存器获取RNG中的随机数

有人在BBS上提到:RSA的书上介绍过一种随机数发生器,根据的是劣质内存芯片工作在高温下,其数据是不可预测的,读取这里面的数据,就会得到难以预测的随机数。有采用这种技术制作随机数发生器板卡。 

关于Linux系统的真随机数生成器在《Linux内核设计与实现》一书的附录B中有详细介绍 
Linux
1.3.30版就在内核提供了真随机数生成器,至少是理论上能产生真随机数,它利用机器的噪音生成随机数,噪音源包括各种硬件运行时速,用户和计算机交互时速。比如击键的间隔时间、鼠标移动速度、特定中断的时间间隔和块IO请求的响应时间等。 

此外还有提供真随机数的网站,如: 
1
http://random.irb.hr/ 是一个免费为学术和科研机构提供真随机数字服务的网站。全名是Quantum Random Bit Generator Service (QRBGS),由克罗地亚的计算机科学家开发。其随机性依赖于半导体光子发散量子物理过程中内在的随机性,光子通过光电效应进行检测。这些随机检测到的光子都是相互独立的。 
可以通过C/C++库、Web ServiceMathmatic/Matlab插件等多种方式访问。将来会提供基于SSL的安全访问。 
它甚至还有个小小的Erlang的客户端访问程序 
http://code.google.com/p/qrbgerl/ 


2.
还有http://random.org/,从1998年开始就在Internet上提供真随机数服务了,它用大气噪音生成真随机数 



有人还提到 
Java可以使用java.security.SecureRandom 产生真随机数(待查); 
Linux
系统有/dev/random,/dev/urandom向用户提供真随机数; 
Windows
系统有CryptGenRandom 函數生成真随机数(待查) 

在《数字追凶 numb3rs》第6季中有一集是通过预测彩票所采用的伪随机数算法进行彩gfw骗的。 

2010
年,德国研究人员开发出一种产生真随机数的新方法,他们希望能改进互联网安全。 
随机数是计算机和互联网安全的重要组成部分,网站和浏览器利用一把会话钥匙加密两者之间发送的数据。伪随机数可以预测和破解,研究人员一直在研究能产生真正的、无法预测的随机数方法。德国的研究团队现在开发出一种真随机数发生器,它使用的计算机内存双态触发器作为随机的一个额外层,触发器可随机的在10状态中切换,在切换之前,触发器处于行为无法预测的亚稳态。在亚稳态结束时,内存中的内容为完全随机。研究人员对一个触发器单元阵列的实验显示,这种方法产生的随机数比传统方法随机20倍。 

经典物理学不存在真正的随机性,而量子世界从本质上讲就是真正随机的,是不可预测的。根据发表在20104月最新一期《自然》杂志上的报告,比利时物理学家S. Pironio和同事利用远距离的幽灵般作用创造出了真随机数 

他们利用了纠缠粒子的随机性和非局域性属性。研究人员首先在理论上发现,一个贝尔不等式的破坏证明新的随机性的产生,它独立于任何实现细节。为了阐释该方法,他们随后进行了一个实验,在该实验中,正如用他们创建的理论工具所证实的那样,产生了42个新的随机位。研究人员称,这项研究可用于设计出真正的无法预测随机数生成器。 
http://developers.solidot.org/article.pl?sid=10/02/23/0645203 
http://www.sciencedaily.com/releases/2010/02/100222082529.htm?utm_source=feedburner&utm_medium=feed&utm_campaign=Feed:+sciencedaily+(ScienceDaily:+Latest+Science+News) 


2011
年,加拿大渥太华的物理学家Ben Sussman利用激光脉冲和钻石创造了真随机数。用真随机数编码的信息将难以被黑客破解。 
Sussman
的实验室使用持续几万亿分之一秒的激光脉冲照射钻石,激光进入和出来的方向发生了变化。Sussman称改变与量子真空涨落的相互作用有关,量子力学与大多数物理学法则不同,不可能知道真正发生了什么。他认为这可以用于创造真正的随机数。 

2012
年,史上最快的随机数生成器:从真空中的亚原子噪音获取随机数 
量子力学告诉我们亚原子对会持续自发的产生和湮灭,即使是在真空里也一样。通过监听真空内亚原子粒子量子涨落产生的噪音,澳大利亚国立大学的科学家们建造了世界上最快的随机数发生器。研究小组开发了可以通过激光监听真空中随机噪音的工具并以此产生真正的随机数。 

随机数生成网页 


http://article.yeeyan.org/view/219269/266017 

参考: 
http://www.cnblogs.com/hehehu/archive/2005/08/23/221125.html 
http://bbs.chinaunix.net/viewthread.php?tid=1054170&extra=&page=1

最后

以上就是合适蛋挞为你收集整理的关于真随机数生成器的全部内容,希望文章能够帮你解决关于真随机数生成器所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(52)

评论列表共有 0 条评论

立即
投稿
返回
顶部