X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=include%2Fmurmur.h;h=1d79652a53a4d4d3e09ce21fc877038cfb8f53c9;hp=84d713580015d474a5c2d3a035b7f8cf3c9b4013;hb=329b5ab58cde015f4faec1879d3106f635294dd6;hpb=f3a053a46bbb4ba460bcff0920b93dfc8263e02e diff --git a/include/murmur.h b/include/murmur.h index 84d7135..1d79652 100644 --- a/include/murmur.h +++ b/include/murmur.h @@ -64,5 +64,42 @@ static inline unsigned int murmur32 (const char *key, int len) static inline unsigned int murmur32_8b (uint64_t key) { - return murmur32((char *)&key, 8); + // 'm' and 'r' are mixing constants generated offline. + // They're not really 'magic', they just happen to work well. + + const unsigned int m = 0x5bd1e995; + const int r = 24; + + // Initialize the hash to a 'random' value + unsigned int h = 8; + + const unsigned char *data = (const unsigned char *)key; + + uint32_t k1 = *(uint32_t *)&data; + data += 4; + uint32_t k2 = *(uint32_t *)&data; + + k1 *= m; + k1 ^= k1 >> r; + k1 *= m; + + k2 *= m; + k2 ^= k2 >> r; + k2 *= m; + + // Mix 4 bytes at a time into the hash + + h *= m; + h ^= k1; + h *= m; + h ^= k2; + + // Do a few final mixes of the hash to ensure the last few + // bytes are well-incorporated. + + h ^= h >> 13; + h *= m; + h ^= h >> 15; + + return h; }