|
- // 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 <http://www.gnu.org/licenses/>.
- //
- // -----------------------------------------------------------------------------
- //
- // 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<uint8_t>(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_
|