乘同余法原理_利用混合乘同余法产生(0,1)均匀分布随机数

一、

概念

混合同余法

用一常数与已产生的伪随机数之积的同余式做递推公式

,

产生均匀伪随机数的方法。

即:

第一步:递推式

其中:

M=2^k,k>2

整数;

A=1(mod4),

为正整数

,

初值

x

*

0

为非负整数。

第二步:

可以证明,

是周期为

2k

的伪随机数。

1

、混合同余法(

0

1

)均匀分布的随机数

L=60,

k=2,c=1,n=5,l=60,

x

*

0

=1

公式原理:

见上第一第二步。

程序:

clear

clc

k=8;

c=1;

n=5;

x=1;

M=2^k;

A=2^n+1;

store=[ ];

for i=1:60

ee=x/M;

store(i)=ee;

x=mod(A*x+c,M);

end

plot(1:60,store)

title('

混合同余法产生随机数

')

store=

0.00390625000000000

0.132812500000000

0.386718750000000

0.765625000000000

0.269531250000000

0.898437500000000

0.652343750000000

0.531250000000000

0.535156250000000

0.664062500000000

0.917968750000000

0.296875000000000

0.800781250000000

0.429687500000000

0.183593750000000

0.0625000000000000

0.0664062500000000

0.195312500000000

0.449218750000000

0.828125000000000

0.332031250000000

0.960937500000000

0.714843750000000

0.593750000000000

0.597656250000000

0.726562500000000

0.980468750000000

0.359375000000000

0.863281250000000

0.492187500000000

3

,

2

,

1

),

(m

od

1

i

M

c

Ax

x

i

i

3

4

2

,

1

2

n

A

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值