C语言生成正态随机变量,用C语言程序生成符合正态分布的随机数列

2007-10-05 11:33

如何用C语言程序生成符合正态分布的随机数列?

一般有两种算法:       算法一产生12个(0,1)平均分布的随机函数,用大数定理可以模拟出正态分布。       算法二用到了数学中的雅可比变换,直接生成正态分布,但此算法在计算很大规模的数时       会出现溢出错误。       测试程序:       #include           #include           #include           #include           #include                double    _random(void)       {         int    a;         double    r;              a=rand()%32767;         r=(a+0.00)/32767.00;              return    r;            }            double    _sta(double    mu,double    sigma)       {         int    i;         double    r,sum=0.0;              if(sigma<=0.0)    {    printf("Sigma<=0.0    in    _sta!");    exit(1);    }         for(i=1;i<=12;i++)         sum    =    sum    +    _random();         r=(sum-6.00)*sigma+mu;              return    r;            }            double    _sta2(double    mu,double    sigma)       {         double    r1,r2;              r1=_random();         r2=_random();              return    sqrt(-2*log(r1))*cos(2*M_PI*r2)*sigma+mu    ;            }                 int    main()       {       int    i;       double    mu,sigma;            srand(    (unsigned)time(    NULL    )    );       mu=0.0;       sigma=1.0;       printf("Algorithm    1:\n");       for(i=0;i<10;i++)       printf("%lf\t",_sta(mu,sigma));       printf("Algorithm    2:\n");       for(i=0;i<10;i++)       printf("%lf\t",_sta2(mu,sigma));       return    0;            }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值