Skip to content

Instantly share code, notes, and snippets.

@garrydzeng
Last active June 30, 2016 06:02
jump consistent hash
// http://arxiv.org/ftp/arxiv/papers/1406/1406.2294.pdf
int32_t JumpConsistentHash(uint64_t key, int32_t num_buckets) {
int64_t b = -1, j = 0;
while (j < num_buckets) {
b = j;
key = key * 2862933555777941757ULL + 1;
j = (b + 1) * (double(1LL << 31) / double((key >> 33) + 1));
}
return b;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment