This repository has been archived by the owner on Oct 11, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 50
/
random.h
executable file
·63 lines (50 loc) · 1.65 KB
/
random.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// Copyright 2009 Emilie Gillet.
//
// Author: Emilie Gillet ([email protected])
//
// 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_