正态分布的随机数发生器 in C#

转载 2006年06月08日 17:04:00

来自:http://dev.csdn.net/author/Solstice/d99caee900e4400780d3177ac64402d2.html

Box 和 Muller 在 1958 年给出了由均匀分布的随机变量生成正态分布的随机变量的算法。设 U1, U2 是区间 (0, 1) 上均匀分布的随机变量,且相互独立。

 

主要参考《Numerical Recipes in C++ 2/e》p.292~p.294 和《Simulation Modeling and Analysis 3/e》p.465~p.466。

Box 和 Muller 在 1958 年给出了由均匀分布的随机变量生成正态分布的随机变量的算法。设 U1, U2 是区间 (0, 1) 上均匀分布的随机变量,且相互独立。令

X1 = sqrt(-2*log(U1)) * cos(2*PI*U2);
X2 = sqrt(-2*log(U1)) * sin(2*PI*U2);


那么 X1, X2 服从 N(0,1) 分布,且相互独立。等于说我们用两个独立的 U(0,1) 随机数得到了两个独立的 N(0,1)随机数。

Marsaglia 和 Bray 在 1964 年提出了一种改进算法,避免使用三角函数。以下的实现代码用的就是这种改进算法。



// 
// Gaussian Random Number Generator class
// ref. ``Numerical Recipes in C++ 2/e'', p.293 ~ p.294
//
  public class GaussianRNG
  {
    int iset;
    double gset;
    Random r1, r2;
   
    public GaussianRNG()
    {
      r1 = new Random(unchecked((int)DateTime.Now.Ticks));
      r2 = new Random(~unchecked((int)DateTime.Now.Ticks));
      iset = 0;
    }
   
    public double Next()
    {
      double fac, rsq, v1, v2;   
      if (iset == 0) {
        do {
          v1 = 2.0 * r1.NextDouble() - 1.0;
          v2 = 2.0 * r2.NextDouble() - 1.0;
          rsq = v1*v1 + v2*v2;
        } while (rsq >= 1.0 || rsq == 0.0);
       
        fac = Math.Sqrt(-2.0*Math.Log(rsq)/rsq);
        gset = v1*fac;
        iset = 1;
        return v2*fac;
      } else {
        iset = 0;
        return gset;
      }
    }
  }

 

使用 C / C++ 产生符合正态分布的随机数

使用 C / C++ 产生符合正态分布的随机数利用有box 和 muller 提供的,在 knuth的网上讨论过的方法 (比较常用的方法)目的:Box-Muller,一般是要得到服从正态分布的随机数,...
  • struggleofbird_gao
  • struggleofbird_gao
  • 2017年04月14日 09:28
  • 1569

C语言产生满足正态分布的随机数

C语言中可以通过rand函数生成满足均匀分布的随机数,但是生成满足正太分布的随机数就没有那么简单了,下面对常用的几种方法进行总结并用C++编程实现。 方法一:由均匀分布的随机数来产生   ...
  • Kevin_Samuel
  • Kevin_Samuel
  • 2013年06月22日 12:43
  • 18850

C#产生正态分布、泊松分布、指数分布、负指数分布随机数(原创)

http://blog.sina.com.cn/s/blog_76c31b8e0100qskf.html 在编程过程中,由于数据仿真模拟的需要,我们经常需要产生一些随机数,在C#中,产生一般...
  • mituan1234567
  • mituan1234567
  • 2015年07月20日 18:56
  • 1364

C#产生正态分布、泊松分布、指数分布、负指数分布随机数(原创)

http://blog.sina.com.cn/s/blog_76c31b8e0100qskf.html 在编程过程中,由于数据仿真模拟的需要,我们经常需要产生一些随机数,在C#中,产生一般...
  • By__myself
  • By__myself
  • 2017年07月05日 17:35
  • 188

C#Random得随机数求均值、方差、正态分布

最近在做中小学试卷分析系统,其中数据的分析让自己很头疼,整个系统采用B/S架构。在分析试卷难度梯度的时候需要用到正态分布,自己做了一些,也查阅了一些资料,终于掌握了将一组数据分析检验,最后生成正态分布...
  • pplsunny
  • pplsunny
  • 2012年07月13日 08:06
  • 1664

正态分布发生器和方差产生模拟器

#include #include #include #include #include using namespace boost; using namespace std; // ...
  • kamaliang
  • kamaliang
  • 2011年09月02日 15:23
  • 1035

二维联合正态分布伪随机数生成算法的研究与实现

  • 2011年09月14日 16:25
  • 322KB
  • 下载

Matlab正态分布随机数

  • 2011年10月18日 12:08
  • 627B
  • 下载

C语言程序 产生服从正态分布、瑞利分布、泊松分布的随机数

  • 2014年10月27日 23:11
  • 3.41MB
  • 下载

正态分布随机数

  • 2015年04月12日 16:49
  • 49B
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:正态分布的随机数发生器 in C#
举报原因:
原因补充:

(最多只允许输入30个字)