Hash values
type Hash = Nat32
Hash values represent a string of hash bits, packed into a Nat32
.
let length : Nat
The hash length, always 31.
func bit(h : Hash, pos : Nat) : Bool
Project a given bit from the bit vector.
func equal(ha : Hash, hb : Hash) : Bool
Test if two hashes are equal
func hash(n : Nat) : Hash
Computes a hash from the least significant 32-bits of n
, ignoring other bits.
@deprecated For large Nat
values consider using a bespoke hash function that considers all of the argument's bits.
func debugPrintBits(bits : Hash)
@deprecated This function will be removed in future.
func debugPrintBitsRev(bits : Hash)
@deprecated This function will be removed in future.
func hashNat8(key : [Hash]) : Hash
Jenkin's one at a time:
https://en.wikipedia.org/wiki/Jenkins_hash_function#one_at_a_time
The input type should actually be [Nat8]
.
Note: Be sure to explode each Nat8
of a Nat32
into its own Nat32
, and to shift into lower 8 bits.
@deprecated This function may be removed or changed in future.