blob: 2b2af9c790acba8bdd507ef84ceea9086b7dd02c (
plain)
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
|
/*
* Copyright 2023 jacqueline <me@jacqueline.id.au>
*
* SPDX-License-Identifier: GPL-3.0-only
*/
#include "random.hpp"
#include <cstdint>
#include "esp_random.h"
#include "komihash.h"
namespace util {
IRandom* sRandom = new Random();
Random::Random() {
esp_fill_random(&seed1_, sizeof(seed1_));
seed2_ = seed1_;
// komirand needs four iterations to properly self-start.
for (int i = 0; i < 4; i++) {
Next();
}
}
auto Random::Next() -> std::uint64_t {
return komirand(&seed1_, &seed2_);
}
auto Random::RangeInclusive(std::uint64_t lower,
std::uint64_t upper) -> std::uint64_t {
return (Next() % (upper - lower + 1)) + lower;
}
} // namespace util
|