File: random.hpp

package info (click to toggle)
higan 098-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 11,904 kB
  • ctags: 13,286
  • sloc: cpp: 108,285; ansic: 778; makefile: 32; sh: 18
file content (40 lines) | stat: -rw-r--r-- 914 bytes parent folder | download
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
#pragma once

#include <nall/serializer.hpp>
#include <nall/stdint.hpp>

namespace nall {

struct RandomNumberGenerator {
  virtual auto seed(uint64_t) -> void = 0;
  virtual auto operator()() -> uint64_t = 0;
  virtual auto serialize(serializer&) -> void = 0;
};

//Galois LFSR using CRC64 polynomials
struct LinearFeedbackShiftRegisterGenerator : RandomNumberGenerator {
  auto seed(uint64_t seed) -> void {
    lfsr = seed;
    for(unsigned n = 0; n < 8; n++) operator()();
  }

  auto operator()() -> uint64_t {
    return lfsr = (lfsr >> 1) ^ (-(lfsr & 1) & crc64jones);
  }

  auto serialize(serializer& s) -> void {
    s.integer(lfsr);
  }

private:
  static const uint64_t crc64ecma  = 0x42f0e1eba9ea3693;
  static const uint64_t crc64jones = 0xad93d23594c935a9;
  uint64_t lfsr = crc64ecma;
};

inline auto random() -> uint64_t {
  static LinearFeedbackShiftRegisterGenerator lfsr;
  return lfsr();
}

}