2015-04-22 15:58:55 +00:00
|
|
|
#ifndef OPENMW_COMPONENTS_MISC_RNG_H
|
|
|
|
#define OPENMW_COMPONENTS_MISC_RNG_H
|
2015-03-15 01:07:47 +00:00
|
|
|
|
|
|
|
#include <cassert>
|
2018-04-08 20:10:14 +00:00
|
|
|
#include <random>
|
2015-03-15 01:07:47 +00:00
|
|
|
|
|
|
|
namespace Misc
|
|
|
|
{
|
|
|
|
|
|
|
|
/*
|
|
|
|
Provides central implementation of the RNG logic
|
|
|
|
*/
|
|
|
|
class Rng
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2018-04-08 20:10:14 +00:00
|
|
|
/// create a RNG
|
|
|
|
static std::mt19937 generator;
|
|
|
|
|
2015-03-15 01:07:47 +00:00
|
|
|
/// seed the RNG
|
|
|
|
static void init();
|
|
|
|
|
|
|
|
/// return value in range [0.0f, 1.0f) <- note open upper range.
|
|
|
|
static float rollProbability();
|
|
|
|
|
|
|
|
/// return value in range [0.0f, 1.0f] <- note closed upper range.
|
|
|
|
static float rollClosedProbability();
|
|
|
|
|
|
|
|
/// return value in range [0, max) <- note open upper range.
|
|
|
|
static int rollDice(int max);
|
|
|
|
|
|
|
|
/// return value in range [0, 99]
|
|
|
|
static int roll0to99() { return rollDice(100); }
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|