// Copyright 2009 Olivier Gillet.
//
// Author: Olivier Gillet (ol.gillet@gmail.com)
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
// -----------------------------------------------------------------------------
//
// Fast 16-bit pseudo random number generator.
#ifndef AVRLIB_RANDOM_H_
#define AVRLIB_RANDOM_H_
#include "avrlib/base.h"
namespace avrlib {
class Random {
public:
static void Update() {
// Galois LFSR with feedback polynomial = x^16 + x^14 + x^13 + x^11.
// Period: 65535.
rng_state_ = (rng_state_ >> 1) ^ (-(rng_state_ & 1) & 0xb400);
}
static inline uint16_t state() { return rng_state_; }
static inline void Seed(uint16_t seed) {
rng_state_ = seed;
}
static inline uint8_t state_msb() {
return static_cast(rng_state_ >> 8);
}
static inline uint8_t GetByte() {
Update();
return state_msb();
}
static inline uint16_t GetWord() {
Update();
return state();
}
private:
static uint16_t rng_state_;
DISALLOW_COPY_AND_ASSIGN(Random);
};
} // namespace avrlib
#endif // AVRLIB_RANDOM_H_