blob: 00f2e474a540ad52462c4d591f739c5457e5dfa2 (
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
|
#include "int-hash.hpp"
#include <bit>
namespace floormat {
size_t int_hash(uint32_t x) noexcept
{
if constexpr(sizeof(size_t) == 4)
{
// by Chris Wellons <https://nullprogram.com/blog/2018/07/31/>
x ^= x >> 15;
x *= 0x2c1b3c6dU;
x ^= x >> 12;
x *= 0x297a2d39U;
x ^= x >> 15;
return x;
}
else
return int_hash(uint64_t(x));
}
size_t int_hash(uint64_t x) noexcept
{
// NASAM by Pelle Evensen <https://mostlymangling.blogspot.com/2020/01/nasam-not-another-strange-acronym-mixer.html>
x ^= std::rotr(x, 25) ^ std::rotr(x, 47);
x *= 0x9E6C63D0676A9A99UL;
x ^= x >> 23 ^ x >> 51;
x *= 0x9E6D62D06F6A9A9BUL;
x ^= x >> 23 ^ x >> 51;
return x;
}
} // namespace floormat
|