| 1 | // Copyright (c) Microsoft Corporation. All rights reserved. |
|---|---|
| 2 | // Licensed under the MIT license. |
| 3 | |
| 4 | #pragma once |
| 5 | |
| 6 | #include <cstdint> |
| 7 | #include <cstring> |
| 8 | #include <stdexcept> |
| 9 | #include <string> |
| 10 | |
| 11 | namespace FASTER { |
| 12 | namespace core { |
| 13 | |
| 14 | class Utility { |
| 15 | public: |
| 16 | static inline uint64_t Rotr64(uint64_t x, std::size_t n) { |
| 17 | return (((x) >> n) | ((x) << (64 - n))); |
| 18 | } |
| 19 | |
| 20 | static inline uint64_t GetHashCode(uint64_t input) { |
| 21 | uint64_t local_rand = input; |
| 22 | uint64_t local_rand_hash = 8; |
| 23 | local_rand_hash = 40343 * local_rand_hash + ((local_rand) & 0xFFFF); |
| 24 | local_rand_hash = 40343 * local_rand_hash + ((local_rand >> 16) & 0xFFFF); |
| 25 | local_rand_hash = 40343 * local_rand_hash + ((local_rand >> 32) & 0xFFFF); |
| 26 | local_rand_hash = 40343 * local_rand_hash + (local_rand >> 48); |
| 27 | local_rand_hash = 40343 * local_rand_hash; |
| 28 | return Rotr64(local_rand_hash, 43); |
| 29 | //Func<long, long> hash = |
| 30 | // e => 40343 * (40343 * (40343 * (40343 * (40343 * 8 + (long)((e) & 0xFFFF)) + (long)((e >> 16) & 0xFFFF)) + (long)((e >> 32) & 0xFFFF)) + (long)(e >> 48)); |
| 31 | } |
| 32 | |
| 33 | static inline uint64_t HashBytes(const uint16_t* str, size_t len) { |
| 34 | // 40343 is a "magic constant" that works well, |
| 35 | // 38299 is another good value. |
| 36 | // Both are primes and have a good distribution of bits. |
| 37 | const uint64_t kMagicNum = 40343; |
| 38 | uint64_t hashState = len; |
| 39 | |
| 40 | for(size_t idx = 0; idx < len; ++idx) { |
| 41 | hashState = kMagicNum * hashState + str[idx]; |
| 42 | } |
| 43 | |
| 44 | // The final scrambling helps with short keys that vary only on the high order bits. |
| 45 | // Low order bits are not always well distributed so shift them to the high end, where they'll |
| 46 | // form part of the 14-bit tag. |
| 47 | return Rotr64(kMagicNum * hashState, 6); |
| 48 | } |
| 49 | |
| 50 | static constexpr inline bool IsPowerOfTwo(uint64_t x) { |
| 51 | return (x > 0) && ((x & (x - 1)) == 0); |
| 52 | } |
| 53 | }; |
| 54 | |
| 55 | } |
| 56 | } // namespace FASTER::core |
| 57 |