我是靠谱客的博主 悦耳西装,最近开发中收集的这篇文章主要介绍用C语言程序生成符合正态分布的随机数列,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

2007-10-05 11:33

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

一般有两种算法:   
   算法一产生12个(0,1)平均分布的随机函数,用大数定理可以模拟出正态分布。   
   算法二用到了数学中的雅可比变换,直接生成正态分布,但此算法在计算很大规模的数时   
   会出现溢出错误。   
   测试程序:   
   #include    <math.h>   
   #include    <stdio.h>   
   #include    <conio.h>   
   #include    <stdlib.h>   
   #include    <time.h>   
    
   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("%lft",_sta(mu,sigma));   
   printf("Algorithm    2:n");   
   for(i=0;i<10;i++)   
   printf("%lft",_sta2(mu,sigma));   
   return    0;   
    
   }

最后

以上就是悦耳西装为你收集整理的用C语言程序生成符合正态分布的随机数列的全部内容,希望文章能够帮你解决用C语言程序生成符合正态分布的随机数列所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部