Module xxh3

NIF bindings for XXH3 hash functions implemented in Rust.

Description

NIF bindings for XXH3 hash functions implemented in Rust

XXH3 is a new speed-optimized hash algorithm of the xxHash family of non-cryptographic hash functions, featuring:

Speed analysis methodology is explained here:

https://fastcompression.blogspot.com/2019/03/presenting-xxh3.html

Data Types

xxh3_ref()

abstract datatype: xxh3_ref()

Function Index

digest/1Computes hash for streamed data.
hash128/1Returns 128-bit hash for the given Data.
hash128/2Returns 128-bit hash for the given Data with Seed value.
hash128_with_secret/2Returns 128-bit hash for the given Data with a custom Secret.
hash64/1Returns 64-bit hash for the given Data.
hash64/2Returns 64-bit hash for the given Data with Seed value.
hash64_with_secret/2Returns 64-bit hash for the given Data with a custom Secret.
new/0Creates a new 64-bit hasher with default secret.
new/1Creates a new 64-bit hasher with the given Seed.
new_with_secret/1Creates a new 64-bit hasher with the given Secret.
reset/1Resets hasher state.
update/2Updates hasher state with the given chunk of data.

Function Details

digest/1

digest(Resource::xxh3_ref()) -> non_neg_integer()

Computes hash for streamed data.

hash128/1

hash128(Data::binary()) -> non_neg_integer()

Returns 128-bit hash for the given Data.

This is default 128-bit variant, using default secret and default seed of 0.

hash128/2

hash128(Data::binary(), Seed::non_neg_integer()) -> non_neg_integer()

Returns 128-bit hash for the given Data with Seed value.

See hash64/2 for more details.

hash128_with_secret/2

hash128_with_secret(Data::binary(), Secret::binary()) -> non_neg_integer()

Returns 128-bit hash for the given Data with a custom Secret.

See hash64_with_secret/2 for more details.

hash64/1

hash64(Data::binary()) -> non_neg_integer()

Returns 64-bit hash for the given Data.

This is default 64-bit variant, using default secret and default seed of 0. It's the fastest variant.

hash64/2

hash64(Data::binary(), Seed::non_neg_integer()) -> non_neg_integer()

Returns 64-bit hash for the given Data with Seed value.

This variant generates a custom secret on the fly based on default secret altered using the Seed value. While this operation is decently fast, note that it's not completely free.

hash64_with_secret/2

hash64_with_secret(Data::binary(), Secret::binary()) -> non_neg_integer()

Returns 64-bit hash for the given Data with a custom Secret.

It's possible to provide any binary as a "secret" to generate the hash. This makes it more difficult for an external actor to prepare an intentional collision. The main condition is that Secret size *must* be large enough (>= 136 bytes). However, the quality of produced hash values depends on secret's entropy. Technically, the secret must look like a bunch of random bytes. Avoid "trivial" or structured data such as repeated sequences or a text document.

new/0

new() -> xxh3_ref()

Creates a new 64-bit hasher with default secret.

You can stream data to the returned object using update/2, and calculate intermediate hash values using digest/1.

new/1

new(Seed::non_neg_integer()) -> xxh3_ref()

Creates a new 64-bit hasher with the given Seed.

new_with_secret/1

new_with_secret(Secret::binary()) -> xxh3_ref()

Creates a new 64-bit hasher with the given Secret.

Secret must be a binary of size 192 bytes.

reset/1

reset(Resource::xxh3_ref()) -> ok

Resets hasher state.

update/2

update(Resource::xxh3_ref(), Data::binary()) -> ok

Updates hasher state with the given chunk of data.


Generated by EDoc