CRandomGenerator.cpp 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * CRandomGenerator.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "CRandomGenerator.h"
  12. VCMI_LIB_NAMESPACE_BEGIN
  13. CRandomGenerator::CRandomGenerator()
  14. {
  15. logRng->trace("CRandomGenerator constructed");
  16. resetSeed();
  17. }
  18. CRandomGenerator::CRandomGenerator(int seed)
  19. {
  20. logRng->trace("CRandomGenerator constructed (%d)", seed);
  21. setSeed(seed);
  22. }
  23. void CRandomGenerator::setSeed(int seed)
  24. {
  25. logRng->trace("CRandomGenerator::setSeed (%d)", seed);
  26. rand.seed(seed);
  27. }
  28. void CRandomGenerator::resetSeed()
  29. {
  30. logRng->trace("CRandomGenerator::resetSeed");
  31. boost::hash<std::string> stringHash;
  32. auto threadIdHash = stringHash(boost::lexical_cast<std::string>(std::this_thread::get_id()));
  33. setSeed(static_cast<int>(threadIdHash * std::time(nullptr)));
  34. }
  35. int CRandomGenerator::nextInt(int upper)
  36. {
  37. logRng->trace("CRandomGenerator::nextInt (%d)", upper);
  38. return nextInt(0, upper);
  39. }
  40. int64_t CRandomGenerator::nextInt64(int64_t upper)
  41. {
  42. logRng->trace("CRandomGenerator::nextInt64 (%d)", upper);
  43. return nextInt64(0, upper);
  44. }
  45. int CRandomGenerator::nextInt(int lower, int upper)
  46. {
  47. logRng->trace("CRandomGenerator::nextInt64 (%d, %d)", lower, upper);
  48. if (lower > upper)
  49. throw std::runtime_error("Invalid range provided: " + std::to_string(lower) + " ... " + std::to_string(upper));
  50. return TIntDist(lower, upper)(rand);
  51. }
  52. int CRandomGenerator::nextInt()
  53. {
  54. logRng->trace("CRandomGenerator::nextInt64");
  55. return TIntDist()(rand);
  56. }
  57. int CRandomGenerator::nextBinomialInt(int coinsCount, double coinChance)
  58. {
  59. logRng->trace("CRandomGenerator::nextBinomialInt (%d, %f)", coinsCount, coinChance);
  60. std::binomial_distribution<> distribution(coinsCount, coinChance);
  61. return distribution(rand);
  62. }
  63. int64_t CRandomGenerator::nextInt64(int64_t lower, int64_t upper)
  64. {
  65. logRng->trace("CRandomGenerator::nextInt64 (%d, %d)", lower, upper);
  66. if (lower > upper)
  67. throw std::runtime_error("Invalid range provided: " + std::to_string(lower) + " ... " + std::to_string(upper));
  68. return TInt64Dist(lower, upper)(rand);
  69. }
  70. double CRandomGenerator::nextDouble(double upper)
  71. {
  72. logRng->trace("CRandomGenerator::nextDouble (%f)", upper);
  73. return nextDouble(0, upper);
  74. }
  75. double CRandomGenerator::nextDouble(double lower, double upper)
  76. {
  77. logRng->trace("CRandomGenerator::nextDouble (%f, %f)", lower, upper);
  78. if(lower > upper)
  79. throw std::runtime_error("Invalid range provided: " + std::to_string(lower) + " ... " + std::to_string(upper));
  80. return TRealDist(lower, upper)(rand);
  81. }
  82. CRandomGenerator & CRandomGenerator::getDefault()
  83. {
  84. static thread_local CRandomGenerator defaultRand;
  85. return defaultRand;
  86. }
  87. VCMI_LIB_NAMESPACE_END