admin管理员组文章数量:1122854
c语言伽马分布随机数,来自Beta分布的随机数,C
我在C中编写了一个模拟,它从特定的概率分布中生成(1,000,000)^ 2个数字,然后用它们做一些事情.到目前为止,我已经使用了指数,正态,伽玛,均匀和泊松分布.以下是其中一个的代码:
#include
...main...
srand(time(NULL)) ;
seed = rand();
boost::random::mt19937 igen(seed) ;
boost::random::variate_generator<:random::mt19937 boost::random::normal_distribution> >
norm_dist(igen, boost::random::normal_distribution<>(mu,sigma)) ;
现在我需要为Beta发行版运行它.到目前为止,我所做的所有发行都需要10-15个小时. Beta发行版不在boost / random包中,所以我不得不使用boost / math / distributions包.我发现this page on StackOverflow提出了一个解决方案.这是(复制粘贴):
#include
using namespace boost::math;
double alpha, beta, randFromUnif;
//parameters and the random value on (0,1) you drew
beta_distribution<> dist(alpha, beta);
double randFromDist = quantile(dist, randFromUnif);
我复制了它并且它起作用了.我的模拟的运行时间估计是线性的并且可以准确地预测.他们说这将持续25天.我看到两种可能性:
1.提出的方法不如我之前用于其他分发的方法
2. Beta分布很难从中生成随机数
请记住,我对C编码的理解很少,所以我问的问题可能很愚蠢.我不能等待一个月完成这个模拟,所以我能做些什么来改善它?也许使用我正在使用的初始方法并修改它以使用boost / math / distributions包?我甚至不知道这是否可能.
另一条可能有用的信息是,我需要生成的所有(1,000,000)^ 2个数字的参数相同.我之所以这样说是因为Beta发行版确实有一个讨厌的PDF,也许参数修复的知识可以某种方式用于简化过程?只是随机猜测.
本文标签: c语言伽马分布随机数来自Beta分布的随机数c
版权声明:本文标题:c语言伽马分布随机数,来自Beta分布的随机数,C 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/biancheng/1701402044a393321.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论