<一>首先,我们需要包含头文件#include <boost/random.hpp>
<二>其次,我们需要一个伪随机数发生器(generator)。语句
boost::mt19937 gen;
声明了一个mt19937类型的伪随机数发生器gen
boost 一共提供了17种类型伪随机发生器供使用者选择,它们是:
minstd_rand, rand48, lrand48, ecuyer1988, kreutzer1986, hellekalek1995, mt11213b, mt19937, lagged_fibonacci 607, lagged_fibonacci1279, lagged_fibonacci2281, lagged_fibonacci3217, lagged_fibonacci4423, lagged_fibonacci9689, lagged_fibonacci19937, lagged_fibonacci23209, lagged_fibonacci44497
到底是使用哪一个,需要在性能、质量和内存之间进行权衡。一般的应用的话,boost文档推荐使用mt19937。
<三> 然后,我们需要一个分布函数
由伪随机数发生器生成的伪随机数一般是一个很大区间上的均匀分布(如[1,2^99999999])。而要产生我们想要的分布的随机数,还要对其做某些变换。比如语句boost::uniform_int<> dist(1, 6); 就是为了得到我们想要的分布:{1 2 3 4 5 6 }上的均匀分布。
boost random library提供了如下的分布函数:
uniform_smallint ------ 一个整数集上的离散均匀分布
uniform_int ------ 一个整数集上的离散均匀分布
uniform_01 ------ [0, 1)上的连续均匀分布
uniform_real ------ [ min, max)上的连续均匀分布