mirror of
https://github.com/twitter/the-algorithm.git
synced 2024-12-22 10:11:52 +01:00
Merge ca2cc4c12f
into 72eda9a24f
This commit is contained in:
commit
3b02af76eb
@ -1,18 +1,21 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#ifdef __cplusplus
|
|
||||||
|
#include <cstdint>
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
namespace twml {
|
namespace twml {
|
||||||
|
|
||||||
inline int64_t mixDiscreteIdAndValue(int64_t key, int64_t value) {
|
inline int64_t mixDiscreteIdAndValue(int64_t key, int64_t value) {
|
||||||
key ^= ((17LL + value) * 2654435761LL);
|
key ^= ((17LL + value) * 2654435761LL);
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int64_t mixStringIdAndValue(int64_t key, int32_t str_len, const uint8_t *str) {
|
inline int64_t mixStringIdAndValue(int64_t key, int32_t str_len, const uint8_t* str) {
|
||||||
int32_t hash = 0;
|
const uint8_t* end = str + str_len;
|
||||||
for (int32_t i = 0; i < str_len; i++) {
|
while (str != end) {
|
||||||
hash = (31 * hash) + (int32_t)str[i];
|
key = (key * 31) + *str++;
|
||||||
}
|
}
|
||||||
return key ^ hash;
|
return key;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
#endif
|
} // namespace twml
|
||||||
|
Loading…
Reference in New Issue
Block a user