生成正态分布及泊松分布的随机数

先回忆一下概率论的东西:

1.中心极限定理

2. 二项分布的极限分布

    当二项分布的参数P很小时,泊松分布对二项分布的近似要好于正 态分布 而当p较大时,用泊松分布去逼近二项分布效果不好,相比之下,用正态分布来近似计算二项分布的值所得结果不错.当然,很明显地,如果p比较大,同时n的值很大,泊松分布的计算就很不方便,此时, 根据中心极限定理,用正态分布去逼近二项分布就是很自然的选择了。

利用中心极限定理生成符合正态分布的随机量:

根据独立同分布的中心极限定理,有:


这里,其实只要取n=12(这里,亦即生成12个0-1上的随机数序列)就会有比较好的效果。 经验证,用该种方法生成生的随机数序列同样能比较好的符合正态分布特性。

      由于生成的都是标准正态分布,所以,当需要生成N(a,b)的正态分布随机量时,根据正态分布的线性变换特性,只要用x=sqrt(b)*x0+a即可。(其中,x0表示生成的符合N(0,1)分布的正态随机变量。)

代码如下:

public double Norm_rand(double miu, double sigma2){
  double N = 12;
  double x=0,temp=N;
  do{
     x=0;
     for(inti=0;i<N;i++)
       x=x+(Math.random());
     x=(x-temp/2)/(Math.sqrt(temp/12));
     x=miu+x*Math.sqrt(sigma2);
   }while(x<=0);         //在此我把小于0的数排除掉了
   return x;
 }
  泊松分布随机数的产生,代码如下:

public double P_rand(double Lamda){     // 泊松分布
   double x=0,b=1,c=Math.exp(-Lamda),u; 
   do {
     u=Math.random();
     b *=u;
     if(b>=c)
       x++;
   }while(b>=c);
   return x;
 }

参考: 1     2   

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值