正态分布的随机数发生器 in C#
来源:互联网 发布:安全软件拦截 编辑:程序博客网 时间:2024/05/16 12:43
主要参考《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;
}
}
}
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=178666
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器 in C#
- 正态分布的随机数发生器
- LaTeX 中插入中英双语目录
- CC2e 术语:construction 译成“构建”还是“构筑”?
- JPEG 学习笔记
- 《Word排版艺术》读后感——兼谈与LaTeX的比较
- 《代码大全(第2版)》中文版上市, 4 天里首印的10,000册销售一空,加急重印。勘误表持续更新中
- 正态分布的随机数发生器 in C#
- 分析函数调用关系图(call graph)的几种方法
- 支付每个勘误 2.56$ 会花 Knuth 多少钱?
- JPEG 学习笔记
- 关于在FPGA上实现AES算法的笔记
- CC2e 术语:把 routine 译为“子程序”的理由
- nmake 的 batch mode (批模式) 推理规则可以用一次命令行调用编译多个文件
- JQuery
- Verilog与C++的类比