| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 | 
							- /*
 
-  * CRandomGenerator.cpp, part of VCMI engine
 
-  *
 
-  * Authors: listed in file AUTHORS in main folder
 
-  *
 
-  * License: GNU General Public License v2.0 or later
 
-  * Full text of license available in license.txt file, in main folder
 
-  *
 
-  */
 
- #include "StdInc.h"
 
- #include "CRandomGenerator.h"
 
- VCMI_LIB_NAMESPACE_BEGIN
 
- CRandomGenerator::CRandomGenerator()
 
- {
 
- 	logRng->trace("CRandomGenerator constructed");
 
- 	resetSeed();
 
- }
 
- CRandomGenerator::CRandomGenerator(int seed)
 
- {
 
- 	logRng->trace("CRandomGenerator constructed (%d)", seed);
 
- 	setSeed(seed);
 
- }
 
- void CRandomGenerator::setSeed(int seed)
 
- {
 
- 	logRng->trace("CRandomGenerator::setSeed (%d)", seed);
 
- 	rand.seed(seed);
 
- }
 
- void CRandomGenerator::resetSeed()
 
- {
 
- 	logRng->trace("CRandomGenerator::resetSeed");
 
- 	boost::hash<std::string> stringHash;
 
- 	auto threadIdHash = stringHash(boost::lexical_cast<std::string>(std::this_thread::get_id()));
 
- 	setSeed(static_cast<int>(threadIdHash * std::time(nullptr)));
 
- }
 
- int CRandomGenerator::nextInt(int upper)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextInt (%d)", upper);
 
- 	return nextInt(0, upper);
 
- }
 
- int64_t CRandomGenerator::nextInt64(int64_t upper)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextInt64 (%d)", upper);
 
- 	return nextInt64(0, upper);
 
- }
 
- int CRandomGenerator::nextInt(int lower, int upper)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextInt64 (%d, %d)", lower, upper);
 
- 	if (lower > upper)
 
- 		throw std::runtime_error("Invalid range provided: " + std::to_string(lower) + " ... " + std::to_string(upper));
 
- 	return TIntDist(lower, upper)(rand);
 
- }
 
- int CRandomGenerator::nextInt()
 
- {
 
- 	logRng->trace("CRandomGenerator::nextInt64");
 
- 	return TIntDist()(rand);
 
- }
 
- int CRandomGenerator::nextBinomialInt(int coinsCount, double coinChance)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextBinomialInt (%d, %f)", coinsCount, coinChance);
 
- 	std::binomial_distribution<> distribution(coinsCount, coinChance);
 
- 	return distribution(rand);
 
- }
 
- int64_t CRandomGenerator::nextInt64(int64_t lower, int64_t upper)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextInt64 (%d, %d)", lower, upper);
 
- 	if (lower > upper)
 
- 		throw std::runtime_error("Invalid range provided: " + std::to_string(lower) + " ... " + std::to_string(upper));
 
- 	return TInt64Dist(lower, upper)(rand);
 
- }
 
- double CRandomGenerator::nextDouble(double upper)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextDouble (%f)", upper);
 
- 	return nextDouble(0, upper);
 
- }
 
- double CRandomGenerator::nextDouble(double lower, double upper)
 
- {
 
- 	logRng->trace("CRandomGenerator::nextDouble (%f, %f)", lower, upper);
 
- 	if(lower > upper)
 
- 		throw std::runtime_error("Invalid range provided: " + std::to_string(lower) + " ... " + std::to_string(upper));
 
- 	return TRealDist(lower, upper)(rand);
 
- }
 
- CRandomGenerator & CRandomGenerator::getDefault()
 
- {
 
- 	static thread_local CRandomGenerator defaultRand;
 
- 	return defaultRand;
 
- }
 
- VCMI_LIB_NAMESPACE_END
 
 
  |