Provided by: libmurmurhash-dev_1.6-1_amd64
NAME
libmurmurhash - non-cryptographic hash functions
SYNOPSIS
#include <murmurhash.h> void lmmh_x86_32(const void *addr, unsigned int len, uint32_t seed, uint32_t out[1]); void lmmh_x86_128(const void *addr, unsigned int len, uint32_t seed, uint32_t out[4]); void lmmh_x64_128(const void *addr, unsigned int len, uint32_t seed, uint64_t out[2]); Deprecated API void MurmurHash3_x86_32(const void *data, int len, uint32_t seed, void *out); void MurmurHash3_x86_128(const void *data, int len, uint32_t seed, void *out); void MurmurHash3_x64_128(const void *data, int len, uint32_t seed, void *out);
DESCRIPTION
LibMurmurHash provides the three variants of MurmurHash3 from the original source. The first parameter addr specifies the beginning of the data to be hashed in memory. The second parameter len gives the number of bytes to be hashed. The third parameter seed can be used to compute an alternative hash on the same data. Pass the location of the hash via the out parameter.
EXAMPLE
Compute the hash of length bytes starting from data and print the 32-bit sized hash value. uint32_t hash; lmmh_x86_32(data, length, 0, &hash); printf("%" PRIx32 "", hash); Do the same, but with a wider hash. uint64_t widehash[2]; lmmh_x64_128(data, length, 0, widehash); printf("%" PRIx64 "%" PRIx64 "", widehash[0], widehash[1]);
AUTHORS
MurmurHash was created by Austin Appleby. PMurHash was written by Shane Day. Fabian Klötzl created libmurmurhash. All code is dedicated to the public domain.
BUGS
The old API is problematic in that a negative length remains unchecked and the output parameter has very specific alignment requirements. Furthermore, the order of bytes in the hash may differ across architectures. Reporting Bugs Please file a bug on GitHub <github.com/kloetzl/libmurmurhash> or send me a mail <fabian- libmurmurhash@kloetzl.info>.