[英]C++: Performance for drawing random boolean values
我正在用绘制随机布尔数字
std::mt19937 rng;
std::uniform_int_distribution<int> dis(0, 1);
在极端情况下,绘制这些数字可能会占用我进程的CPU时间的40%。 有什么办法可以使速度更快?
我会摆脱uniform_int_distribution
。
一次调用std::mt19937::operator()
(即执行rng()
)将为您提供32个随机位,您可以一一使用。
基准测试表明,此方法快23倍。
您可能对@HolyBlackCat答案感到满意,但是对于采样这样的值,C ++中提供了Bernoulli发行支持。
沿线
std::mt19937 rng{1234567};
std::bernoulli_distribution bd{0.5};
std::cout << bd(rng) << '\n';
std::cout << bd(rng) << '\n';
std::cout << bd(rng) << '\n';
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.