[发明专利]一种随机数生成方法和装置有效

专利信息
申请号: 201110136989.5 申请日: 2011-05-25
公开(公告)号: CN102799413A 公开(公告)日: 2012-11-28
发明(设计)人: 李云洲;丁国鹏;张艳;赵熠飞;肖立民;许希斌 申请(专利权)人: 清华大学
主分类号: G06F7/58 分类号: G06F7/58
代理公司: 北京润泽恒知识产权代理有限公司 11319 代理人: 苏培华
地址: 100084*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 随机数 生成 方法 装置
【权利要求书】:

1.一种随机数生成方法,其特征在于:

步骤101、计算随机种子的平方数,并将平方后得到的数高位补零得到2n位平方数K2n;其中,n为输出随机数的最大位数,n为偶数;

步骤102、将所述2n位平方数K2n按顺序分割成2n/m个m位数;其中,mod(n,m)=0,m≠n;

步骤103、从所述2n/m个m位数中选择n/m个进行组合生成一个n位新随机数On并输出;

以及步骤104,

当新随机数On中最高位和最低位使用的m位数均不为零时,将其作为新随机种子;

当新随机数On中最高位和最低位使用的m位数中存在至少一个为零时,在未被步骤103选中的n/m个m位数中,找出非零的m位数,替换新随机数中为零的最高位和/或最低位m位数,得到新随机种子。

2.如权利要求1所述的随机数生成方法,其特征在于:

还包括步骤100,获取初始随机种子,输出随机数的最大位数n,n为偶数,其中初始随机种子不等于10N,N≥0。

3.如权利要求1所述的随机数生成方法,其特征在于:

所述随机数的最大位数n,由随机数的取值范围和精度要求确定。

4.如权利要求1所述的随机数生成方法,其特征在于:

将所述新随机数On放缩至符合随机数的取值范围和精度要求后输出。

5.如权利要求1所述的随机数生成方法,其特征在于:

从所述2n/m个m位数中选择n/m个进行组合时,选择正中间的n/m个进行组合,或者选择奇数项的n/m个进行组合。

6.如权利要求1所述的随机数生成方法,其特征在于:

所述的参数m使用事先预置的默认值。

7.如权利要求1所述的随机数生成方法,其特征在于:

所述的参数m值根据所述的n值和2n位平方数K2n确定,具体过程包括:根据所述n值确定m位数可能的个数i,记作:m1,...mi,运算得到参数m值。

8.一种随机数生成装置,其特征在于:

运算器,用于计算随机种子的平方数,并将平方后得到的数高位补零得到2n位平方数K2n;其中,n为输出随机数的最大位数,n为偶数;

分隔器,用于将所述2n位平方数K2n按顺序分割成2n/m个m位数;其中,mod(n,m)=0,m≠n;

组合单元,用于从所述2n/m个m位数中选择n/m个进行组合生成一个n位新随机数On并输出;

以及随机种子产生器,用于当新随机数On中最高位和最低位使用的m位数均不为零时,将其作为新随机种子;当新随机数On中最高位和最低位使用的m位数中存在至少一个为零时,在未被步骤103选中的n/m个m位数中,找出非零的m位数,替换新随机数中为零的最高位和/或最低位m位数,得到新随机种子。

9.如权利要求8所述的随机数生成装置,其特征在于:

所述的组合单元包括放缩单元,所述的放缩单元用于将所述新随机数On放缩至符合随机数的取值范围和精度要求后输出。

10.如权利要求8所述的随机数生成装置,其特征在于:

还包括控制器,用于确定参数m值,具体确定过程包括:根据所述n值确定m位数可能的个数i,记作:m1,...mi,运算

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于清华大学,未经清华大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201110136989.5/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top