我要指出的是C++ 11通過模板類實際上提供許多梅森歇後語:
template <class UIntType,
size_t word_size,
size_t state_size,
size_t shift_size,
size_t mask_bits,
UIntType xor_mask,
size_t tempering_u,
UIntType tempering_d,
size_t tempering_s,
UIntType tempering_b,
size_t tempering_t,
UIntType tempering_c,
size_t tempering_l,
UIntType initialization_multiplier>
class mersenne_twister_engine;
如果任何人有膽量來探討這些操縱桿和旋鈕.. 當然這裏有兩個標準實例:
using mt19937
= mersenne_twister_engine<uint_fast32_t,
32,
624,
397,
31,
0x9908b0df,
11,
0xffffffff,
7,
0x9d2c5680,
15,
0xefc60000,
18,
1812433253>;
和64位版本:
using mt19937_64
= mersenne_twister_engine<uint_fast64_t,
64,
312,
156,
31,
0xb5026f5aa96619e9,
29,
0x5555555555555555,
17,
0x71d67fffeda60000,
37,
0xfff7eee000000000,
43,
6364136223846793005>;
我認爲這將是很好的用於檢查的RNG的質量,使人們可以嘗試新的實例提供了一個工具箱。
這裏是模板PARMS的比較:
32,624,397,31, 0x9908b0df,11, 0xffffffff,7 , 0x9d2c5680,15, 0xefc60000,18,1812433253 <- std::mt19937
64,312,156,31,0xb5026f5aa96619e9,29,0x5555555555555555,17,0x71d67fffeda60000,37,0xfff7eee000000000,43,6364136223846793005 <- std::mt19937_64
w ,n ,m ,r ,a ,u ,d ,s ,b ,t ,c ,l ,f
32,624,397,31, 0x9908b0df,11, ,7 , 0x9d2c5680,15, 0xefc60000,18, <- paper
與感謝@NathanOliver。
如果您看看Boost.Random中的[header](http://www.boost.org/doc/libs/release/boost/random/mersenne_twister.hpp),它們表示*整數的播種是在2005年4月更改爲解決[弱點](http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/MT2002/emt19937ar.html)*。難道你是在比較改變之前發表的論文的結果嗎? – Praetorian
@Praetorian - 呃,我不確定,但我不這麼認爲。我沒有使用Boost;相反,我通過'libstdC++'使用GNU的實現。 – jww
它使用http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/MT2002/CODES/mt19937ar.c。 IOW,什麼@Praetorian鏈接到。 –