X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/43593083f5e507b563bddc7d8d9c6022a9d7fab4..86d34ae9f0559e524d3e0f12f6003ec700cb9bb5:/src/xbt/random.cpp diff --git a/src/xbt/random.cpp b/src/xbt/random.cpp index 004418eadd..7deb41e704 100644 --- a/src/xbt/random.cpp +++ b/src/xbt/random.cpp @@ -19,28 +19,24 @@ namespace simgrid { namespace xbt { namespace random { -bool Random::read_state(std::string filename) +bool Random::read_state(const std::string& filename) { std::ifstream file(filename); - if (file) { - file >> mt19937_gen; - return true; - } else { - XBT_WARN("Could not open %s and thus not save the RNG state.", filename.c_str()); - return false; - } + file >> mt19937_gen; + file.close(); + if (file.fail()) + XBT_WARN("Could not save the RNG state to file %s.", filename.c_str()); + return not file.fail(); } -bool Random::write_state(std::string filename) +bool Random::write_state(const std::string& filename) const { std::ofstream file(filename); - if (file) { - file << mt19937_gen; - return false; - } else { - XBT_WARN("Could not open %s and thus not read the RNG state.", filename.c_str()); - return false; - } + file << mt19937_gen; + file.close(); + if (file.fail()) + XBT_WARN("Could not read the RNG state from file %s.", filename.c_str()); + return not file.fail(); } int StdRandom::uniform_int(int min, int max) @@ -77,7 +73,7 @@ int XbtRandom::uniform_int(int min, int max) do { value = mt19937_gen(); } while (value >= decltype(mt19937_gen)::max() - decltype(mt19937_gen)::max() % range); - return value % range + min; + return static_cast(value % range + min); } double XbtRandom::uniform_real(double min, double max) @@ -88,7 +84,7 @@ double XbtRandom::uniform_real(double min, double max) do { numerator = mt19937_gen() - decltype(mt19937_gen)::min(); } while (numerator == divisor); - return min + (max - min) * numerator / divisor; + return min + (max - min) * static_cast(numerator) / divisor; } double XbtRandom::exponential(double lambda) @@ -123,12 +119,12 @@ void set_mersenne_seed(int seed) default_random->set_seed(seed); } -bool read_mersenne_state(std::string filename) +bool read_mersenne_state(const std::string& filename) { return default_random->read_state(filename); } -bool write_mersenne_state(std::string filename) +bool write_mersenne_state(const std::string& filename) { return default_random->write_state(filename); }