13、随机数生成器的测试与评估

随机数生成器的测试与评估

1. 随机数源与测试的初步探讨

在随机数生成和测试的领域中,不同的随机数源有着各自的特点和问题。例如,如果从HotBits生成至少与RANDOM.ORG样本数量相当的样本,理论上应该能得到相似的结果。但这也提醒我们,使用强大的随机数测试套件来判定小文件的随机性是需要谨慎的。

以TV数据集为例,它存在明显的问题。部分测试失败可能是由于文件大小较小,仅有不到700万个32位样本,但这可能并非全部原因。该数据集是由调至空频道的CRT电视的数码照片生成的。虽然电视显示的底层噪声信号具有高度随机性,但将图像转换为字节流的过程显然引入了偏差。图像最初是1500×1500像素,为避免引入人为值,采用最近邻采样法将其重采样为500×500像素。即便在这个分辨率下,所选像素的相邻像素很可能与其非常相似。尽管尝试从图像的其他区域提取样本以引入空间成分,但这种方法仍不够完善,存在偏差,导致在统计测试中表现不佳。而且,该数据集在经典随机性测试中失败了一半。这是一个典型案例,实际上,在其他经过更精细调整的真随机数生成器中也发现了细微的偏差。

2. dieharder测试程序的使用

dieharder测试程序是统计学家和数学家用于严格测试伪随机数生成器极限的工具。虽然这里只是对其进行了基础层面的安装和使用,但它能帮助我们判断是否应该使用某个生成器,并提供关于生成器“好坏”的一些指标。

与真正的随机数据(如RANDOM.ORG的比特数据)相比,一些生成器表现出色。增强型xorshift生成器、KISS生成器、Mersenne Twister、CMWC生成器和新的Middle Weyl生成器都给出了优秀的结果。具体使用哪种生成器取决于实际应用

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值