2010-08-09 13:28:56 +00:00
|
|
|
#ifndef NALL_RANDOM_HPP
|
|
|
|
#define NALL_RANDOM_HPP
|
|
|
|
|
|
|
|
namespace nall {
|
|
|
|
//pseudo-random number generator
|
|
|
|
inline unsigned prng() {
|
|
|
|
static unsigned n = 0;
|
|
|
|
return n = (n >> 1) ^ (((n & 1) - 1) & 0xedb88320);
|
|
|
|
}
|
|
|
|
|
2011-03-20 13:57:55 +00:00
|
|
|
struct random_lfsr {
|
|
|
|
inline void seed(unsigned seed__) {
|
|
|
|
seed_ = seed__;
|
|
|
|
}
|
|
|
|
|
2010-08-09 13:28:56 +00:00
|
|
|
inline unsigned operator()() {
|
2011-03-20 13:57:55 +00:00
|
|
|
return seed_ = (seed_ >> 1) ^ (((seed_ & 1) - 1) & 0xedb88320);
|
2010-08-09 13:28:56 +00:00
|
|
|
}
|
2011-03-20 13:57:55 +00:00
|
|
|
|
|
|
|
random_lfsr() : seed_(0) {
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
unsigned seed_;
|
2010-08-09 13:28:56 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|