I have a function rand_double() which generates a random floating-point value using a static function variable with type std::mt19937. Several threads may use this function concurrently.
#include <random>
auto random_double(double min, double max) {
static std::mt19937 generator{std::random_device{}()}; // Forgot to seed it, thanks @user4581301
return std::uniform_real_distribution<>{min, max}(generator);
}
My first question is, is the above code as-is thread safe? I know that since C++11 the initialization of static function variables is always thread-safe, but how about the concurrent use of generator?
To generate a random number, the std::uniform_real_distribution calls operator() of the argument generator.
In case of mersenne twister the operator has the side effect:
"The state of the engine is advanced by one position"
which is not (by any indicator) considered a thread-safe operation.
You can use it as thread_local which would have the intended effect i.e. static in each specific thread:
auto random_double(double min, double max) {
thread_local std::mt19937 generator(std::random_device{}());
return std::uniform_real_distribution<>{min, max}(generator);
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With