From d83f250ea0a902285ea7b02bcec554ba84aefd5d Mon Sep 17 00:00:00 2001 From: Reini Urban Date: Sat, 14 Dec 2024 16:25:47 +0100 Subject: [PATCH] add aesni-hash-peterrk from smhasher3 --- CMakeLists.txt | 2 +- Hashes.cpp | 2 + Hashes.h | 1 + README.md | 1 + aesnihash-peterrk.hpp | 189 +++++ doc/aesni-hash-peterrk.txt | 1328 ++++++++++++++++++++++++++++++++++++ doc/epyc.html | 8 + doc/i7.html | 8 + doc/ryzen3.html | 8 + doc/table.html | 8 + main.cpp | 2 +- testspeed-i7.sh | 10 +- testspeed.sh | 2 +- 13 files changed, 1561 insertions(+), 8 deletions(-) create mode 100644 aesnihash-peterrk.hpp create mode 100644 doc/aesni-hash-peterrk.txt diff --git a/CMakeLists.txt b/CMakeLists.txt index 9c93f857..86e34305 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -700,7 +700,6 @@ add_library( beamsplitter.cpp discohash_512.cpp xxhash.c - ${GX_SRC} metrohash/metrohash64.cpp metrohash/metrohash128.cpp cmetrohash64.c @@ -711,6 +710,7 @@ add_library( # ${FHTW_OBJ} ${T1HA_SRC} ${SHA_SRC} + ${GX_SRC} mum.cc jody_hash32.c jody_hash64.c diff --git a/Hashes.cpp b/Hashes.cpp index b9aac7e2..1c75dc07 100644 --- a/Hashes.cpp +++ b/Hashes.cpp @@ -1365,3 +1365,5 @@ void polymur_test ( const void *key, int len, uint32_t seed, void *out) { *(uint64_t*)out = polymur_hash((const uint8_t*)key, (size_t)len, &g_polymurhashparams, (uint64_t)seed); } + +#include "aesnihash-peterrk.hpp" diff --git a/Hashes.h b/Hashes.h index d3617db4..872c9cb7 100644 --- a/Hashes.h +++ b/Hashes.h @@ -539,6 +539,7 @@ inline void t1ha0_ia32aes_noavx_test(const void * key, int len, uint32_t seed, v // objsize 0-39d: 925 *(uint64_t*)out = t1ha0_ia32aes_noavx(key, len, seed); } +void aesnihash_peterrk(const void * in, int len0, uint32_t seed, void * out); #endif #if defined(__AVX__) inline void t1ha0_ia32aes_avx1_test(const void * key, int len, uint32_t seed, void * out) diff --git a/README.md b/README.md index dd5a48b7..330e06dd 100644 --- a/README.md +++ b/README.md @@ -128,6 +128,7 @@ SMhasher | [t1ha2_stream](doc/t1ha2_stream.txt) | 13673.22 | 81.12 | 263.88 (3) |1665 | Sparse, Permutation, LongNeighbors | | [t1ha2_stream128](doc/t1ha2_stream128.txt) | 13913.43 | 94.60 | 296.15 (4) |1665 | Sparse, Permutation, LongNeighbors | | [aesnihash](doc/aesnihash.txt) | 5365.60 | 57.21 | 255.87 (3) |1209 | fails many tests, machine-specific (x64 AES-NI) | +| [aesni-hash-peterrk](doc/aesni-hash-peterrk.txt)| 29107.73 | 28.86 | 217.57 (1) | | fails many tests, machine-specific (x64 AES-NI) | | [falkhash](doc/falkhash.txt) | 52401.48 | 122.70 | 316.79 (4) | 264 | Sparse, LongNeighbors, machine-specific (x64 AES-NI) | | [MeowHash](doc/MeowHash.txt) | 29969.81 | 64.90 | 273.79 (8) |1764 | Sparse, invertible, machine-specific (x64 AES-NI) | | [MeowHash64low](doc/MeowHash64low.txt) | 29438.45 | 63.76 | 269.41 (4) |1764 | Sparse, invertible, machine-specific (x64 AES-NI) | diff --git a/aesnihash-peterrk.hpp b/aesnihash-peterrk.hpp new file mode 100644 index 00000000..531e977b --- /dev/null +++ b/aesnihash-peterrk.hpp @@ -0,0 +1,189 @@ +/* + * aesnihash from the PageBloomFilter project + * Copyright (C) 2023 Frank J. T. Wojcik + * Copyright (C) 2023 Ruan Kunliang + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials provided + * with the distribution. + * + * 3. Neither the name of the copyright holder nor the names of its + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS + * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + */ +#include "Platform.h" + +#if defined(HAVE_AESNI) +#include + +void aesnihash_peterrk(const void * in, int len0, uint32_t seed, void * out) { + auto a = _mm_set1_epi32((uint32_t)seed); + auto b = _mm_set1_epi32((uint32_t)len0); + auto m = _mm_set_epi32(0xdeadbeef, 0xffff0000, 0x01234567, 0x89abcdef); + auto s = _mm_set_epi8(3, 7, 11, 15, 2, 6, 10, 14, 1, 5, 9, 13, 0, 4, 8, 12); + const uint8_t * msg = (const uint8_t *)in; + uint32_t len = (uint32_t)len0; + + bool greed = (((uintptr_t)msg + (len - 1)) & UINT64_C(0xfff)) >= 15; // do not cross page + + if (len > 80) { + auto c = _mm_aesenc_si128(b, m); + auto d = _mm_aesdec_si128(a, m); + a = _mm_aesenc_si128(a, m); + b = _mm_aesdec_si128(b, m); + do { + a = _mm_xor_si128(a, _mm_lddqu_si128((const __m128i *)msg)); + b = _mm_xor_si128(b, _mm_lddqu_si128((const __m128i *)(msg + 16))); + c = _mm_xor_si128(c, _mm_lddqu_si128((const __m128i *)(msg + 32))); + d = _mm_xor_si128(d, _mm_lddqu_si128((const __m128i *)(msg + 48))); + a = _mm_shuffle_epi8(_mm_aesenc_si128(a, m), s); + b = _mm_shuffle_epi8(_mm_aesdec_si128(b, m), s); + c = _mm_shuffle_epi8(_mm_aesenc_si128(c, m), s); + d = _mm_shuffle_epi8(_mm_aesdec_si128(d, m), s); + msg += 64; + len -= 64; + } while (len > 80); + c = _mm_aesenc_si128(a, c); + d = _mm_aesdec_si128(b, d); + a = _mm_aesenc_si128(c, d); + b = _mm_aesdec_si128(d, c); + } + + auto mix = [&a, &b, m, s]( __m128i x ) { + a = _mm_aesenc_si128(x, a); + a = _mm_aesenc_si128(a, m); + b = _mm_shuffle_epi8(_mm_xor_si128(x, b) , s); + b = _mm_shuffle_epi8(_mm_aesdec_si128(b, m), s); + }; + + while (len >= 16) { + mix(_mm_lddqu_si128((const __m128i *)msg)); + msg += 16; + len -= 16; + } + + if (greed) { +#define GREEDILY_READ(n, addr) \ + _mm_bsrli_si128(_mm_bslli_si128(_mm_lddqu_si128((const __m128i*)addr), (16-(n))), (16-(n))) + + switch (len) { + case 15: mix(GREEDILY_READ(15, msg)); break; + case 14: mix(GREEDILY_READ(14, msg)); break; + case 13: mix(GREEDILY_READ(13, msg)); break; + case 12: mix(GREEDILY_READ(12, msg)); break; + case 11: mix(GREEDILY_READ(11, msg)); break; + case 10: mix(GREEDILY_READ(10, msg)); break; + case 9: mix(GREEDILY_READ(9, msg)); break; + case 8: mix((__m128i)_mm_load_sd((const double *)msg)); break; + case 7: mix(GREEDILY_READ(7, msg)); break; + case 6: mix(GREEDILY_READ(6, msg)); break; + case 5: mix(GREEDILY_READ(5, msg)); break; + case 4: mix((__m128i)_mm_load_ss((const float *)msg)); break; + case 3: mix(GREEDILY_READ(3, msg)); break; + case 2: mix(GREEDILY_READ(2, msg)); break; + case 1: mix(GREEDILY_READ(1, msg)); break; + case 0: + default: // try to keep m & s from register spilling + a = _mm_add_epi8(a, s); + b = _mm_add_epi8(b, m); + } + #undef GREEDILY_READ + } else { + uint64_t x = 0; + switch (len) { + case 15: + x |= ((uint64_t)msg[14]) << 48U; //FALLTHROUGH + case 14: + x |= ((uint64_t)msg[13]) << 40U; //FALLTHROUGH + case 13: + x |= ((uint64_t)msg[12]) << 32U; //FALLTHROUGH + case 12: + x |= *(const uint32_t *)(msg + 8); + mix(_mm_set_epi64x(x, *(const uint64_t *)msg)); + break; + case 11: + x |= ((uint32_t)msg[10]) << 16U; //FALLTHROUGH + case 10: + x |= ((uint32_t)msg[ 9]) << 8U; //FALLTHROUGH + case 9: + x |= msg[8]; //FALLTHROUGH + case 8: + mix(_mm_set_epi64x(x, *(const uint64_t *)msg)); + break; + case 7: + x |= ((uint64_t)msg[6]) << 48U; //FALLTHROUGH + case 6: + x |= ((uint64_t)msg[5]) << 40U; //FALLTHROUGH + case 5: + x |= ((uint64_t)msg[4]) << 32U; //FALLTHROUGH + case 4: + x |= *(const uint32_t *)msg; + mix(_mm_set_epi64x(0, x)); + break; + case 3: + x |= ((uint32_t)msg[2]) << 16U; //FALLTHROUGH + case 2: + x |= ((uint32_t)msg[1]) << 8U; //FALLTHROUGH + case 1: + x |= msg[0]; + mix(_mm_set_epi64x(0, x)); + break; + case 0: + default: // try to keep m & s from register spilling + a = _mm_add_epi8(a, s); + b = _mm_add_epi8(b, m); + } + } + + _mm_storeu_si128((__m128i *)out, _mm_aesenc_si128(a, b)); +} + +#endif + +#ifdef smhasher3 +//------------------------------------------------------------ +REGISTER_FAMILY(aesnihash_peterrk, + $.src_url = "https://github.com/PeterRK/PageBloomFilter/blob/main/src/aesni-hash.h", + $.src_status = HashFamilyInfo::SRC_ACTIVE + ); + +REGISTER_HASH(aesnihash_peterrk, + $.desc = "AESNI Hash 128-bit for x64-only by PeterRK", + $.impl = "aesni", + $.hash_flags = + FLAG_HASH_AES_BASED | + FLAG_HASH_SMALL_SEED | + FLAG_HASH_ENDIAN_INDEPENDENT, + $.impl_flags = + FLAG_IMPL_READ_PAST_EOB | + FLAG_IMPL_CANONICAL_BOTH | + FLAG_IMPL_LICENSE_BSD, + $.bits = 128, + $.verification_LE = 0xF06DA1B1, + $.verification_BE = 0xF06DA1B1, + $.hashfn_native = aesnihash_peterrk, + $.hashfn_bswap = aesnihash_peterrk + ); +#endif diff --git a/doc/aesni-hash-peterrk.txt b/doc/aesni-hash-peterrk.txt new file mode 100644 index 00000000..b78aa4c7 --- /dev/null +++ b/doc/aesni-hash-peterrk.txt @@ -0,0 +1,1328 @@ +------------------------------------------------------------------------------- +--- Testing aesni-hash-peterrk "PeterRK's seeded aesnihash with aesenc, 128-bit for x64" GOOD + +[[[ Sanity Tests ]]] + +Verification value 0xF06DA1B1 ....... PASS +Running sanity check 1 .......... PASS +Running AppendedZeroesTest .......... PASS + +[[[ Speed Tests ]]] + +Bulk speed test - 262144-byte keys +Alignment 7 - 10.350 bytes/cycle - 29611.89 MiB/sec @ 3 ghz +Alignment 6 - 10.352 bytes/cycle - 29617.42 MiB/sec @ 3 ghz +Alignment 5 - 10.392 bytes/cycle - 29730.63 MiB/sec @ 3 ghz +Alignment 4 - 10.484 bytes/cycle - 29994.98 MiB/sec @ 3 ghz +Alignment 3 - 10.507 bytes/cycle - 30060.60 MiB/sec @ 3 ghz +Alignment 2 - 10.463 bytes/cycle - 29934.78 MiB/sec @ 3 ghz +Alignment 1 - 10.511 bytes/cycle - 30073.33 MiB/sec @ 3 ghz +Alignment 0 - 10.055 bytes/cycle - 28766.40 MiB/sec @ 3 ghz +Average - 10.389 bytes/cycle - 29723.75 MiB/sec @ 3 ghz + +Small key speed test - 1-byte keys - 27.00 cycles/hash +Small key speed test - 2-byte keys - 28.00 cycles/hash +Small key speed test - 3-byte keys - 27.00 cycles/hash +Small key speed test - 4-byte keys - 25.00 cycles/hash +Small key speed test - 5-byte keys - 28.00 cycles/hash +Small key speed test - 6-byte keys - 27.00 cycles/hash +Small key speed test - 7-byte keys - 27.00 cycles/hash +Small key speed test - 8-byte keys - 25.00 cycles/hash +Small key speed test - 9-byte keys - 28.00 cycles/hash +Small key speed test - 10-byte keys - 27.00 cycles/hash +Small key speed test - 11-byte keys - 27.00 cycles/hash +Small key speed test - 12-byte keys - 28.00 cycles/hash +Small key speed test - 13-byte keys - 27.00 cycles/hash +Small key speed test - 14-byte keys - 27.00 cycles/hash +Small key speed test - 15-byte keys - 27.00 cycles/hash +Small key speed test - 16-byte keys - 26.55 cycles/hash +Small key speed test - 17-byte keys - 33.00 cycles/hash +Small key speed test - 18-byte keys - 34.00 cycles/hash +Small key speed test - 19-byte keys - 33.00 cycles/hash +Small key speed test - 20-byte keys - 32.99 cycles/hash +Small key speed test - 21-byte keys - 33.25 cycles/hash +Small key speed test - 22-byte keys - 32.47 cycles/hash +Small key speed test - 23-byte keys - 32.43 cycles/hash +Small key speed test - 24-byte keys - 32.00 cycles/hash +Small key speed test - 25-byte keys - 33.31 cycles/hash +Small key speed test - 26-byte keys - 32.46 cycles/hash +Small key speed test - 27-byte keys - 32.53 cycles/hash +Small key speed test - 28-byte keys - 33.00 cycles/hash +Small key speed test - 29-byte keys - 32.53 cycles/hash +Small key speed test - 30-byte keys - 32.59 cycles/hash +Small key speed test - 31-byte keys - 32.59 cycles/hash +Small key speed test - 32-byte keys - 34.00 cycles/hash +Average 29.929 cycles/hash +Average, weighted by key length freq. 29.653 cycles/hash (using 93.0% of top-7m Tranco DNS names dataset) +Average, weighted by key length freq. 27.111 cycles/hash (using 27.1% of startup-1M UMASH trace dataset) + +[[[ 'Hashmap' Speed Tests ]]] + +std::unordered_map +Init std HashMapTest: 430.467 cycles/op (104334 inserts, 1% deletions) +Running std HashMapTest: 333.602 cycles/op (2.3 stdv) + +greg7mdp/parallel-hashmap +Init fast HashMapTest: 279.581 cycles/op (104334 inserts, 1% deletions) +Running fast HashMapTest: 221.610 cycles/op (1.3 stdv) ....... PASS + +[[[ Avalanche Tests ]]] + +Testing 24-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.852667% +Testing 32-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.722000% +Testing 40-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.766667% +Testing 48-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.760667% +Testing 56-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.792000% +Testing 64-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.676000% +Testing 72-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.703333% +Testing 80-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.698667% +Testing 96-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.748000% +Testing 112-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.733333% +Testing 128-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.696667% +Testing 160-bit keys -> 128-bit hashes, 300000 reps.......... worst bias is 0.796667% + +[[[ Keyset 'Sparse' Tests ]]] + +Keyset 'Sparse' - 16-bit keys with up to 9 bits set - 50643 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 0.3, actual 0 (0.00x) +Testing collisions (high 19-25 bits) - Worst is 23 bits: 158/152 (1.04x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 0.3, actual 0 (0.00x) +Testing collisions (low 19-25 bits) - Worst is 25 bits: 43/38 (1.13x) +Testing distribution - Worst bias is the 13-bit window at bit 14 - 0.630% + +Keyset 'Sparse' - 24-bit keys with up to 8 bits set - 1271626 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 188.2, actual 182 (0.97x) +Testing collisions (high 24-35 bits) - Worst is 34 bits: 48/47 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 188.2, actual 186 (0.99x) (-2) +Testing collisions (low 24-35 bits) - Worst is 35 bits: 31/23 (1.32x) +Testing distribution - Worst bias is the 17-bit window at bit 84 - 0.104% + +Keyset 'Sparse' - 32-bit keys with up to 7 bits set - 4514873 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 2372.2, actual 2409 (1.02x) (37) +Testing collisions (high 25-38 bits) - Worst is 36 bits: 161/148 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 2372.2, actual 2443 (1.03x) (71) +Testing collisions (low 25-38 bits) - Worst is 37 bits: 81/74 (1.09x) +Testing distribution - Worst bias is the 19-bit window at bit 18 - 0.062% + +Keyset 'Sparse' - 40-bit keys with up to 6 bits set - 4598479 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 2460.8, actual 2463 (1.00x) (3) +Testing collisions (high 25-38 bits) - Worst is 29 bits: 19745/19637 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 2460.8, actual 2426 (0.99x) (-34) +Testing collisions (low 25-38 bits) - Worst is 37 bits: 86/76 (1.12x) +Testing distribution - Worst bias is the 19-bit window at bit 12 - 0.075% + +Keyset 'Sparse' - 48-bit keys with up to 6 bits set - 14196869 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 23437.8, actual 23495 (1.00x) (58) +Testing collisions (high 27-42 bits) - Worst is 37 bits: 770/733 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 23437.8, actual 23529 (1.00x) (92) +Testing collisions (low 27-42 bits) - Worst is 40 bits: 120/91 (1.31x) +Testing distribution - Worst bias is the 20-bit window at bit 38 - 0.019% + +Keyset 'Sparse' - 56-bit keys with up to 5 bits set - 4216423 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 2069.0, actual 2125 (1.03x) (57) +Testing collisions (high 25-38 bits) - Worst is 38 bits: 41/32 (1.27x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 2069.0, actual 2105 (1.02x) (37) +Testing collisions (low 25-38 bits) - Worst is 34 bits: 562/517 (1.09x) +Testing distribution - Worst bias is the 19-bit window at bit 46 - 0.059% + +Keyset 'Sparse' - 64-bit keys with up to 5 bits set - 8303633 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8021.7, actual 7922 (0.99x) (-99) +Testing collisions (high 26-40 bits) - Worst is 27 bits: 252332/251643 (1.00x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8021.7, actual 8046 (1.00x) (25) +Testing collisions (low 26-40 bits) - Worst is 39 bits: 71/62 (1.13x) +Testing distribution - Worst bias is the 20-bit window at bit 95 - 0.053% + +Keyset 'Sparse' - 72-bit keys with up to 5 bits set - 15082603 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 26451.8, actual 26464 (1.00x) (13) +Testing collisions (high 27-42 bits) - Worst is 41 bits: 57/51 (1.10x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 26451.8, actual 26640 (1.01x) (189) +Testing collisions (low 27-42 bits) - Worst is 42 bits: 31/25 (1.20x) +Testing distribution - Worst bias is the 20-bit window at bit 63 - 0.022% + +Keyset 'Sparse' - 96-bit keys with up to 4 bits set - 3469497 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 1401.0, actual 1360 (0.97x) +Testing collisions (high 25-38 bits) - Worst is 30 bits: 5642/5599 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 1401.0, actual 1432 (1.02x) (32) +Testing collisions (low 25-38 bits) - Worst is 37 bits: 52/43 (1.19x) +Testing distribution - Worst bias is the 19-bit window at bit 116 - 0.066% + +Keyset 'Sparse' - 160-bit keys with up to 4 bits set - 26977161 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 84546.1, actual 84311 (1.00x) (-235) +Testing collisions (high 28-44 bits) - Worst is 44 bits: 21/20 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 84546.1, actual 84558 (1.00x) (12) +Testing collisions (low 28-44 bits) - Worst is 40 bits: 343/330 (1.04x) +Testing distribution - Worst bias is the 20-bit window at bit 76 - 0.011% + +Keyset 'Sparse' - 256-bit keys with up to 3 bits set - 2796417 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 910.2, actual 955 (1.05x) (45) +Testing collisions (high 25-37 bits) - Worst is 33 bits: 507/455 (1.11x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 910.2, actual 961 (1.06x) (51) +Testing collisions (low 25-37 bits) - Worst is 33 bits: 489/455 (1.07x) +Testing distribution - Worst bias is the 19-bit window at bit 97 - 0.089% + + +[[[ Keyset 'Permutation' Tests ]]] + +Combination Lowbits Tests: +Keyset 'Combination' - up to 7 blocks from a set of 8 - 2396744 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 668.6, actual 671 (1.00x) (3) +Testing collisions (high 24-37 bits) - Worst is 33 bits: 354/334 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 668.6, actual 698 (1.04x) (30) +Testing collisions (low 24-37 bits) - Worst is 36 bits: 46/41 (1.10x) +Testing distribution - Worst bias is the 18-bit window at bit 119 - 0.064% + + +Combination Highbits Tests +Keyset 'Combination' - up to 7 blocks from a set of 8 - 2396744 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 668.6, actual 671 (1.00x) (3) +Testing collisions (high 24-37 bits) - Worst is 37 bits: 23/20 (1.10x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 668.6, actual 684 (1.02x) (16) +Testing collisions (low 24-37 bits) - Worst is 36 bits: 51/41 (1.22x) +Testing distribution - Worst bias is the 18-bit window at bit 100 - 0.089% + + +Combination Hi-Lo Tests: +Keyset 'Combination' - up to 6 blocks from a set of 15 - 12204240 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 17322.9, actual 17069 (0.99x) (-253) +Testing collisions (high 27-41 bits) - Worst is 40 bits: 81/67 (1.20x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 17322.9, actual 17289 (1.00x) (-33) +Testing collisions (low 27-41 bits) - Worst is 41 bits: 43/33 (1.27x) +Testing distribution - Worst bias is the 20-bit window at bit 9 - 0.026% + + +Combination 0x80000000 Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 8 (1.00x) (1) +Testing collisions (high 21-30 bits) - Worst is 30 bits: 38/31 (1.19x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (low 21-30 bits) - Worst is 30 bits: 38/31 (1.19x) +Testing distribution - Worst bias is the 15-bit window at bit 21 - 0.227% + + +Combination 0x00000001 Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (high 21-30 bits) - Worst is 26 bits: 539/511 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 13 (1.63x) (6) +Testing collisions (low 21-30 bits) - Worst is 30 bits: 38/31 (1.19x) +Testing distribution - Worst bias is the 15-bit window at bit 56 - 0.245% + + +Combination 0x8000000000000000 Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 6 (0.75x) +Testing collisions (high 21-30 bits) - Worst is 22 bits: 8217/8023 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 12 (1.50x) (5) +Testing collisions (low 21-30 bits) - Worst is 30 bits: 36/31 (1.13x) +Testing distribution - Worst bias is the 15-bit window at bit 79 - 0.230% + + +Combination 0x0000000000000001 Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (high 21-30 bits) - Worst is 22 bits: 8049/8023 (1.00x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 9 (1.13x) (2) +Testing collisions (low 21-30 bits) - Worst is 29 bits: 75/63 (1.17x) +Testing distribution - Worst bias is the 15-bit window at bit 53 - 0.293% + + +Combination 16-bytes [0-1] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (high 21-30 bits) - Worst is 28 bits: 140/127 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 10 (1.25x) (3) +Testing collisions (low 21-30 bits) - Worst is 28 bits: 152/127 (1.19x) +Testing distribution - Worst bias is the 15-bit window at bit 110 - 0.271% + + +Combination 16-bytes [0-last] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 4 (0.50x) +Testing collisions (high 21-30 bits) - Worst is 25 bits: 1043/1021 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 9 (1.13x) (2) +Testing collisions (low 21-30 bits) - Worst is 24 bits: 2082/2037 (1.02x) +Testing distribution - Worst bias is the 15-bit window at bit 82 - 0.337% + + +Combination 32-bytes [0-1] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 8 (1.00x) (1) +Testing collisions (high 21-30 bits) - Worst is 30 bits: 38/31 (1.19x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 10 (1.25x) (3) +Testing collisions (low 21-30 bits) - Worst is 30 bits: 43/31 (1.34x) +Testing distribution - Worst bias is the 15-bit window at bit 119 - 0.279% + + +Combination 32-bytes [0-last] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (high 21-30 bits) - Worst is 30 bits: 33/31 (1.03x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 9 (1.13x) (2) +Testing collisions (low 21-30 bits) - Worst is 29 bits: 67/63 (1.05x) +Testing distribution - Worst bias is the 15-bit window at bit 18 - 0.264% + + +Combination 64-bytes [0-1] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 10 (1.25x) (3) +Testing collisions (high 21-30 bits) - Worst is 30 bits: 40/31 (1.25x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 8 (1.00x) (1) +Testing collisions (low 21-30 bits) - Worst is 29 bits: 71/63 (1.11x) +Testing distribution - Worst bias is the 15-bit window at bit 63 - 0.212% + + +Combination 64-bytes [0-last] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (high 21-30 bits) - Worst is 27 bits: 262/255 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 9 (1.13x) (2) +Testing collisions (low 21-30 bits) - Worst is 23 bits: 4135/4053 (1.02x) +Testing distribution - Worst bias is the 15-bit window at bit 15 - 0.279% + + +Combination 128-bytes [0-1] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 6 (0.75x) +Testing collisions (high 21-30 bits) - Worst is 29 bits: 76/63 (1.19x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 6 (0.75x) +Testing collisions (low 21-30 bits) - Worst is 30 bits: 35/31 (1.09x) +Testing distribution - Worst bias is the 14-bit window at bit 58 - 0.229% + + +Combination 128-bytes [0-last] Tests: +Keyset 'Combination' - up to 17 blocks from a set of 2 - 262142 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 8.0, actual 9 (1.13x) (2) +Testing collisions (high 21-30 bits) - Worst is 29 bits: 76/63 (1.19x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 8.0, actual 7 (0.88x) +Testing collisions (low 21-30 bits) - Worst is 28 bits: 128/127 (1.00x) +Testing distribution - Worst bias is the 15-bit window at bit 56 - 0.138% + + +[[[ Keyset 'Window' Tests ]]] + +Keyset 'Window' - 32-bit key, 25-bit window - 32 tests, 33554432 keys per test +Window at 0 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 1 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 2 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 3 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 4 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 5 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 6 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 7 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 8 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 9 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 10 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 11 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 12 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 13 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 14 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 15 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 16 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 17 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 18 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 19 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 20 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 21 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 22 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 23 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 24 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 25 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 26 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 27 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 28 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 29 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 30 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 31 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Window at 32 - Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) + +[[[ Keyset 'Cyclic' Tests ]]] + +Keyset 'Cyclic' - 8 cycles of 16 bytes - 1000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 116.4, actual 110 (0.94x) +Testing collisions (high 23-34 bits) - Worst is 30 bits: 480/465 (1.03x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 116.4, actual 130 (1.12x) (14) +Testing collisions (low 23-34 bits) - Worst is 32 bits: 130/116 (1.12x) +Testing distribution - Worst bias is the 17-bit window at bit 97 - 0.162% + +Keyset 'Cyclic' - 8 cycles of 17 bytes - 1000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 116.4, actual 123 (1.06x) (7) +Testing collisions (high 23-34 bits) - Worst is 33 bits: 72/58 (1.24x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 116.4, actual 142 (1.22x) (26) +Testing collisions (low 23-34 bits) - Worst is 32 bits: 142/116 (1.22x) +Testing distribution - Worst bias is the 17-bit window at bit 88 - 0.111% + +Keyset 'Cyclic' - 8 cycles of 18 bytes - 1000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 116.4, actual 150 (1.29x) (34) +Testing collisions (high 23-34 bits) - Worst is 34 bits: 47/29 (1.61x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 116.4, actual 125 (1.07x) (9) +Testing collisions (low 23-34 bits) - Worst is 34 bits: 36/29 (1.24x) +Testing distribution - Worst bias is the 17-bit window at bit 11 - 0.168% + +Keyset 'Cyclic' - 8 cycles of 19 bytes - 1000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 116.4, actual 121 (1.04x) (5) +Testing collisions (high 23-34 bits) - Worst is 31 bits: 261/232 (1.12x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 116.4, actual 117 (1.01x) (1) +Testing collisions (low 23-34 bits) - Worst is 33 bits: 67/58 (1.15x) +Testing distribution - Worst bias is the 17-bit window at bit 53 - 0.126% + +Keyset 'Cyclic' - 8 cycles of 20 bytes - 1000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 116.4, actual 123 (1.06x) (7) +Testing collisions (high 23-34 bits) - Worst is 32 bits: 123/116 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 116.4, actual 121 (1.04x) (5) +Testing collisions (low 23-34 bits) - Worst is 34 bits: 35/29 (1.20x) +Testing distribution - Worst bias is the 17-bit window at bit 45 - 0.136% + +Keyset 'Cyclic' - 8 cycles of 24 bytes - 1000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 116.4, actual 111 (0.95x) +Testing collisions (high 23-34 bits) - Worst is 34 bits: 33/29 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 116.4, actual 97 (0.83x) +Testing collisions (low 23-34 bits) - Worst is 27 bits: 3787/3716 (1.02x) +Testing distribution - Worst bias is the 17-bit window at bit 61 - 0.130% + + +[[[ Keyset 'TwoBytes' Tests ]]] + +Keyset 'TwoBytes' - up-to-4-byte keys, 652545 total keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 49.6, actual 46 (0.93x) +Testing collisions (high 23-33 bits) - Worst is 33 bits: 26/24 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 49.6, actual 30 (0.61x) +Testing collisions (low 23-33 bits) - Worst is 26 bits: 3205/3162 (1.01x) +Testing distribution - Worst bias is the 16-bit window at bit 7 - 0.183% + +Keyset 'TwoBytes' - up-to-8-byte keys, 5471025 total keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 3483.1, actual 3525 (1.01x) (42) +Testing collisions (high 26-39 bits) - Worst is 37 bits: 139/108 (1.28x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 3483.1, actual 3345 (0.96x) +Testing collisions (low 26-39 bits) - Worst is 36 bits: 231/217 (1.06x) +Testing distribution - Worst bias is the 20-bit window at bit 117 - 0.061% + +Keyset 'TwoBytes' - up-to-12-byte keys, 18616785 total keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 40289.5, actual 40086 (0.99x) (-203) +Testing collisions (high 27-42 bits) - Worst is 40 bits: 171/157 (1.08x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 40289.5, actual 39822 (0.99x) (-467) +Testing collisions (low 27-42 bits) - Worst is 39 bits: 329/315 (1.04x) +Testing distribution - Worst bias is the 20-bit window at bit 95 - 0.019% + + +[[[ Keyset 'Text' Tests ]]] + +Keyset 'Text' - keys of form "FooXXXXBar" - 14776336 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 25389.0, actual 25556 (1.01x) (167) +Testing collisions (high 27-42 bits) - Worst is 40 bits: 104/99 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 25389.0, actual 25207 (0.99x) (-182) +Testing collisions (low 27-42 bits) - Worst is 41 bits: 51/49 (1.03x) +Testing distribution - Worst bias is the 20-bit window at bit 106 - 0.026% + +Keyset 'Text' - keys of form "FooBarXXXX" - 14776336 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 25389.0, actual 25426 (1.00x) (37) +Testing collisions (high 27-42 bits) - Worst is 42 bits: 28/24 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 25389.0, actual 25340 (1.00x) (-49) +Testing collisions (low 27-42 bits) - Worst is 38 bits: 404/397 (1.02x) +Testing distribution - Worst bias is the 20-bit window at bit 92 - 0.023% + +Keyset 'Text' - keys of form "XXXXFooBar" - 14776336 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 25389.0, actual 25291 (1.00x) (-98) +Testing collisions (high 27-42 bits) - Worst is 41 bits: 56/49 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 25389.0, actual 25260 (0.99x) (-129) +Testing collisions (low 27-42 bits) - Worst is 39 bits: 200/198 (1.01x) +Testing distribution - Worst bias is the 20-bit window at bit 30 - 0.024% + +Keyset 'Words' - 4000000 random keys of len 6-16 from alnum charset +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 1862.1, actual 1907 (1.02x) (45) +Testing collisions (high 25-38 bits) - Worst is 38 bits: 33/29 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 1862.1, actual 1877 (1.01x) (15) +Testing collisions (low 25-38 bits) - Worst is 38 bits: 39/29 (1.34x) +Testing distribution - Worst bias is the 19-bit window at bit 67 - 0.080% + +Keyset 'Words' - 4000000 random keys of len 6-16 from password charset +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 1862.1, actual 1908 (1.02x) (46) +Testing collisions (high 25-38 bits) - Worst is 32 bits: 1908/1862 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 1862.1, actual 1927 (1.03x) (65) +Testing collisions (low 25-38 bits) - Worst is 35 bits: 253/232 (1.09x) +Testing distribution - Worst bias is the 19-bit window at bit 109 - 0.082% + +Keyset 'Words' - 104334 dict words +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 1.3, actual 2 (1.58x) (1) +Testing collisions (high 20-28 bits) - Worst is 28 bits: 30/20 (1.48x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 1.3, actual 3 (2.37x) (2) ! +Testing collisions (low 20-28 bits) - Worst is 28 bits: 25/20 (1.23x) +Testing distribution - Worst bias is the 14-bit window at bit 111 - 0.436% + + +[[[ Keyset 'Zeroes' Tests ]]] + +Keyset 'Zeroes' - 204800 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 4.9, actual 3 (0.61x) +Testing collisions (high 21-29 bits) - Worst is 28 bits: 87/78 (1.11x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 4.9, actual 3 (0.61x) +Testing collisions (low 21-29 bits) - Worst is 29 bits: 48/39 (1.23x) +Testing distribution - Worst bias is the 15-bit window at bit 95 - 0.302% + + +[[[ Keyset 'Seed' Tests ]]] + +Keyset 'Seed' - 5000000 keys +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 2909.3, actual 2885 (0.99x) (-24) +Testing collisions (high 26-39 bits) - Worst is 34 bits: 755/727 (1.04x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 2909.3, actual 2910 (1.00x) (1) +Testing collisions (low 26-39 bits) - Worst is 39 bits: 27/22 (1.19x) +Testing distribution - Worst bias is the 19-bit window at bit 25 - 0.078% + + +[[[ Keyset 'PerlinNoise' Tests ]]] + +Testing 16777216 coordinates (L2) : +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 32725.4, actual 32609 (1.00x) (-116) +Testing collisions (high 27-42 bits) - Worst is 41 bits: 68/63 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 32725.4, actual 32740 (1.00x) (15) +Testing collisions (low 27-42 bits) - Worst is 41 bits: 72/63 (1.13x) + +Testing AV variant, 128 count with 4 spacing, 4-12: +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 1116.2, actual 1056 (0.95x) +Testing collisions (high 25-37 bits) - Worst is 37 bits: 39/34 (1.12x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 1116.2, actual 1092 (0.98x) +Testing collisions (low 25-37 bits) - Worst is 37 bits: 41/34 (1.18x) + + +[[[ Diff 'Differential' Tests ]]] + +Testing 8303632 up-to-5-bit differentials in 64-bit keys -> 128 bit hashes. +1000 reps, 8303632000 total tests, expecting 0.00 random collisions.......... +0 total collisions, of which 0 single collisions were ignored + +Testing 11017632 up-to-4-bit differentials in 128-bit keys -> 128 bit hashes. +1000 reps, 11017632000 total tests, expecting 0.00 random collisions.......... +0 total collisions, of which 0 single collisions were ignored + +Testing 2796416 up-to-3-bit differentials in 256-bit keys -> 128 bit hashes. +1000 reps, 2796416000 total tests, expecting 0.00 random collisions.......... +0 total collisions, of which 0 single collisions were ignored + + +[[[ DiffDist 'Differential Distribution' Tests ]]] + +Testing bit 0 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 495 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 141/127 (1.10x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 548 (1.07x) (37) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 39/31 (1.22x) +Testing distribution - Worst bias is the 18-bit window at bit 114 - 0.091% + +Testing bit 1 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 574 (1.12x) (63) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 44/31 (1.38x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 481 (0.94x) +Testing collisions (low 24-36 bits) - Worst is 28 bits: 8224/8170 (1.01x) +Testing distribution - Worst bias is the 18-bit window at bit 126 - 0.076% + +Testing bit 2 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 483 (0.94x) +Testing collisions (high 24-36 bits) - Worst is 28 bits: 8158/8170 (1.00x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 490 (0.96x) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 33/31 (1.03x) +Testing distribution - Worst bias is the 17-bit window at bit 69 - 0.091% + +Testing bit 3 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 507 (0.99x) (-4) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 146/127 (1.14x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 545 (1.06x) (34) +Testing collisions (low 24-36 bits) - Worst is 33 bits: 279/255 (1.09x) +Testing distribution - Worst bias is the 18-bit window at bit 45 - 0.087% + +Testing bit 4 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 488 (0.95x) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 136/127 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 474 (0.93x) +Testing collisions (low 24-36 bits) - Worst is 30 bits: 2041/2046 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 66 - 0.085% + +Testing bit 5 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 534 (1.04x) (23) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 146/127 (1.14x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 490 (0.96x) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 68/63 (1.06x) +Testing distribution - Worst bias is the 18-bit window at bit 61 - 0.091% + +Testing bit 6 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 475 (0.93x) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 37/31 (1.16x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 473 (0.92x) +Testing collisions (low 24-36 bits) - Worst is 25 bits: 64399/64191 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 115 - 0.122% + +Testing bit 7 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 532 (1.04x) (21) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 149/127 (1.16x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 506 (0.99x) (-5) +Testing collisions (low 24-36 bits) - Worst is 24 bits: 126046/125777 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 13 - 0.084% + +Testing bit 8 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 518 (1.01x) (7) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 34/31 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 473 (0.92x) +Testing collisions (low 24-36 bits) - Worst is 30 bits: 2069/2046 (1.01x) +Testing distribution - Worst bias is the 18-bit window at bit 8 - 0.081% + +Testing bit 9 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 489 (0.96x) +Testing collisions (high 24-36 bits) - Worst is 30 bits: 2080/2046 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 527 (1.03x) (16) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 36/31 (1.13x) +Testing distribution - Worst bias is the 18-bit window at bit 58 - 0.078% + +Testing bit 10 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 532 (1.04x) (21) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 135/127 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 524 (1.02x) (13) +Testing collisions (low 24-36 bits) - Worst is 33 bits: 263/255 (1.03x) +Testing distribution - Worst bias is the 18-bit window at bit 59 - 0.085% + +Testing bit 11 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 512 (1.00x) (1) +Testing collisions (high 24-36 bits) - Worst is 30 bits: 2142/2046 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 525 (1.03x) (14) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 40/31 (1.25x) +Testing distribution - Worst bias is the 18-bit window at bit 12 - 0.079% + +Testing bit 12 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 545 (1.06x) (34) +Testing collisions (high 24-36 bits) - Worst is 32 bits: 545/511 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 506 (0.99x) (-5) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 35/31 (1.09x) +Testing distribution - Worst bias is the 18-bit window at bit 123 - 0.098% + +Testing bit 13 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 498 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 49/31 (1.53x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 468 (0.91x) +Testing collisions (low 24-36 bits) - Worst is 24 bits: 125668/125777 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 15 - 0.073% + +Testing bit 14 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 475 (0.93x) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 37/31 (1.16x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (low 24-36 bits) - Worst is 31 bits: 1061/1023 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 50 - 0.109% + +Testing bit 15 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 514 (1.00x) (3) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 36/31 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 504 (0.98x) (-7) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 68/63 (1.06x) +Testing distribution - Worst bias is the 18-bit window at bit 42 - 0.076% + +Testing bit 16 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 516 (1.01x) (5) +Testing collisions (high 24-36 bits) - Worst is 32 bits: 516/511 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 496 (0.97x) +Testing collisions (low 24-36 bits) - Worst is 34 bits: 137/127 (1.07x) +Testing distribution - Worst bias is the 18-bit window at bit 60 - 0.081% + +Testing bit 17 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 530 (1.04x) (19) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 80/63 (1.25x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 476 (0.93x) +Testing collisions (low 24-36 bits) - Worst is 34 bits: 131/127 (1.02x) +Testing distribution - Worst bias is the 17-bit window at bit 13 - 0.075% + +Testing bit 18 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 531 (1.04x) (20) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 154/127 (1.20x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 461 (0.90x) +Testing collisions (low 24-36 bits) - Worst is 24 bits: 125773/125777 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 112 - 0.067% + +Testing bit 19 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 526 (1.03x) (15) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 142/127 (1.11x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 499 (0.97x) +Testing collisions (low 24-36 bits) - Worst is 29 bits: 4199/4090 (1.03x) +Testing distribution - Worst bias is the 18-bit window at bit 8 - 0.078% + +Testing bit 20 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 505 (0.99x) (-6) +Testing collisions (high 24-36 bits) - Worst is 33 bits: 262/255 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 524 (1.02x) (13) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 40/31 (1.25x) +Testing distribution - Worst bias is the 18-bit window at bit 112 - 0.077% + +Testing bit 21 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 500 (0.98x) +Testing collisions (high 24-36 bits) - Worst is 27 bits: 16371/16298 (1.00x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 532 (1.04x) (21) +Testing collisions (low 24-36 bits) - Worst is 32 bits: 532/511 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 23 - 0.098% + +Testing bit 22 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 513 (1.00x) (2) +Testing collisions (high 24-36 bits) - Worst is 30 bits: 2136/2046 (1.04x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 503 (0.98x) (-8) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 69/63 (1.08x) +Testing distribution - Worst bias is the 18-bit window at bit 93 - 0.108% + +Testing bit 23 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 514 (1.00x) (3) +Testing collisions (high 24-36 bits) - Worst is 28 bits: 8214/8170 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 478 (0.93x) +Testing collisions (low 24-36 bits) - Worst is 29 bits: 4097/4090 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 14 - 0.098% + +Testing bit 24 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 543 (1.06x) (32) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 86/63 (1.34x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 501 (0.98x) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 67/63 (1.05x) +Testing distribution - Worst bias is the 18-bit window at bit 31 - 0.087% + +Testing bit 25 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 517 (1.01x) (6) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 35/31 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (low 24-36 bits) - Worst is 31 bits: 1053/1023 (1.03x) +Testing distribution - Worst bias is the 18-bit window at bit 86 - 0.101% + +Testing bit 26 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 524 (1.02x) (13) +Testing collisions (high 24-36 bits) - Worst is 33 bits: 274/255 (1.07x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 516 (1.01x) (5) +Testing collisions (low 24-36 bits) - Worst is 33 bits: 267/255 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 29 - 0.078% + +Testing bit 27 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 501 (0.98x) +Testing collisions (high 24-36 bits) - Worst is 29 bits: 4186/4090 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 491 (0.96x) +Testing collisions (low 24-36 bits) - Worst is 25 bits: 64485/64191 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 19 - 0.065% + +Testing bit 28 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 504 (0.98x) (-7) +Testing collisions (high 24-36 bits) - Worst is 29 bits: 4184/4090 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 538 (1.05x) (27) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 71/63 (1.11x) +Testing distribution - Worst bias is the 18-bit window at bit 68 - 0.086% + +Testing bit 29 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 531 (1.04x) (20) +Testing collisions (high 24-36 bits) - Worst is 33 bits: 271/255 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (low 24-36 bits) - Worst is 31 bits: 1062/1023 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 40 - 0.105% + +Testing bit 30 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 500 (0.98x) +Testing collisions (high 24-36 bits) - Worst is 29 bits: 4166/4090 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 532 (1.04x) (21) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 37/31 (1.16x) +Testing distribution - Worst bias is the 18-bit window at bit 2 - 0.084% + +Testing bit 31 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 531 (1.04x) (20) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 67/63 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 536 (1.05x) (25) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 45/31 (1.41x) +Testing distribution - Worst bias is the 18-bit window at bit 31 - 0.121% + +Testing bit 32 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 567 (1.11x) (56) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 150/127 (1.17x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 512 (1.00x) (1) +Testing collisions (low 24-36 bits) - Worst is 29 bits: 4143/4090 (1.01x) +Testing distribution - Worst bias is the 18-bit window at bit 39 - 0.098% + +Testing bit 33 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 510 (1.00x) (-1) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 40/31 (1.25x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 472 (0.92x) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 36/31 (1.13x) +Testing distribution - Worst bias is the 18-bit window at bit 72 - 0.076% + +Testing bit 34 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 482 (0.94x) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 129/127 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 534 (1.04x) (23) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 37/31 (1.16x) +Testing distribution - Worst bias is the 18-bit window at bit 63 - 0.086% + +Testing bit 35 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 466 (0.91x) +Testing collisions (high 24-36 bits) - Worst is 27 bits: 16520/16298 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 529 (1.03x) (18) +Testing collisions (low 24-36 bits) - Worst is 31 bits: 1070/1023 (1.05x) +Testing distribution - Worst bias is the 18-bit window at bit 82 - 0.100% + +Testing bit 36 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 527 (1.03x) (16) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 35/31 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 38/31 (1.19x) +Testing distribution - Worst bias is the 18-bit window at bit 78 - 0.080% + +Testing bit 37 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 549 (1.07x) (38) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 38/31 (1.19x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 532 (1.04x) (21) +Testing collisions (low 24-36 bits) - Worst is 32 bits: 532/511 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 60 - 0.072% + +Testing bit 38 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 510 (1.00x) (-1) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 34/31 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 482 (0.94x) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 75/63 (1.17x) +Testing distribution - Worst bias is the 18-bit window at bit 102 - 0.070% + +Testing bit 39 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 512 (1.00x) (1) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 70/63 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 533 (1.04x) (22) +Testing collisions (low 24-36 bits) - Worst is 32 bits: 533/511 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 30 - 0.081% + +Testing bit 40 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 509 (0.99x) (-2) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 70/63 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 540 (1.05x) (29) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 36/31 (1.13x) +Testing distribution - Worst bias is the 18-bit window at bit 52 - 0.070% + +Testing bit 41 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 495 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 40/31 (1.25x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 537 (1.05x) (26) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 43/31 (1.34x) +Testing distribution - Worst bias is the 18-bit window at bit 100 - 0.086% + +Testing bit 42 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 511 (1.00x) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 35/31 (1.09x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 518 (1.01x) (7) +Testing collisions (low 24-36 bits) - Worst is 34 bits: 144/127 (1.13x) +Testing distribution - Worst bias is the 18-bit window at bit 105 - 0.114% + +Testing bit 43 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 488 (0.95x) +Testing collisions (high 24-36 bits) - Worst is 27 bits: 16329/16298 (1.00x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 524 (1.02x) (13) +Testing collisions (low 24-36 bits) - Worst is 31 bits: 1053/1023 (1.03x) +Testing distribution - Worst bias is the 18-bit window at bit 45 - 0.106% + +Testing bit 44 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 517 (1.01x) (6) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 66/63 (1.03x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 43/31 (1.34x) +Testing distribution - Worst bias is the 18-bit window at bit 114 - 0.069% + +Testing bit 45 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 524 (1.02x) (13) +Testing collisions (high 24-36 bits) - Worst is 32 bits: 524/511 (1.02x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (low 24-36 bits) - Worst is 34 bits: 133/127 (1.04x) +Testing distribution - Worst bias is the 18-bit window at bit 115 - 0.064% + +Testing bit 46 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 550 (1.07x) (39) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 43/31 (1.34x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 516 (1.01x) (5) +Testing collisions (low 24-36 bits) - Worst is 33 bits: 274/255 (1.07x) +Testing distribution - Worst bias is the 18-bit window at bit 12 - 0.083% + +Testing bit 47 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 507 (0.99x) (-4) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 33/31 (1.03x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 526 (1.03x) (15) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 36/31 (1.13x) +Testing distribution - Worst bias is the 18-bit window at bit 40 - 0.083% + +Testing bit 48 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 499 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 33 bits: 264/255 (1.03x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 504 (0.98x) (-7) +Testing collisions (low 24-36 bits) - Worst is 26 bits: 32535/32429 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 76 - 0.085% + +Testing bit 49 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 504 (0.98x) (-7) +Testing collisions (high 24-36 bits) - Worst is 24 bits: 125586/125777 (1.00x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 503 (0.98x) (-8) +Testing collisions (low 24-36 bits) - Worst is 29 bits: 4166/4090 (1.02x) +Testing distribution - Worst bias is the 18-bit window at bit 31 - 0.071% + +Testing bit 50 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 477 (0.93x) +Testing collisions (high 24-36 bits) - Worst is 26 bits: 32606/32429 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 488 (0.95x) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 35/31 (1.09x) +Testing distribution - Worst bias is the 18-bit window at bit 40 - 0.076% + +Testing bit 51 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 522 (1.02x) (11) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 69/63 (1.08x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 512 (1.00x) (1) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 42/31 (1.31x) +Testing distribution - Worst bias is the 18-bit window at bit 127 - 0.070% + +Testing bit 52 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 539 (1.05x) (28) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 44/31 (1.38x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 492 (0.96x) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 34/31 (1.06x) +Testing distribution - Worst bias is the 18-bit window at bit 95 - 0.084% + +Testing bit 53 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 498 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 36/31 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 470 (0.92x) +Testing collisions (low 24-36 bits) - Worst is 28 bits: 8178/8170 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 27 - 0.107% + +Testing bit 54 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 515 (1.01x) (4) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 75/63 (1.17x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 465 (0.91x) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 33/31 (1.03x) +Testing distribution - Worst bias is the 18-bit window at bit 112 - 0.079% + +Testing bit 55 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 515 (1.01x) (4) +Testing collisions (high 24-36 bits) - Worst is 32 bits: 515/511 (1.01x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 509 (0.99x) (-2) +Testing collisions (low 24-36 bits) - Worst is 31 bits: 1049/1023 (1.02x) +Testing distribution - Worst bias is the 18-bit window at bit 89 - 0.093% + +Testing bit 56 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 514 (1.00x) (3) +Testing collisions (high 24-36 bits) - Worst is 33 bits: 271/255 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 524 (1.02x) (13) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 78/63 (1.22x) +Testing distribution - Worst bias is the 18-bit window at bit 66 - 0.091% + +Testing bit 57 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 551 (1.08x) (40) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 72/63 (1.13x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 494 (0.97x) +Testing collisions (low 24-36 bits) - Worst is 29 bits: 4171/4090 (1.02x) +Testing distribution - Worst bias is the 18-bit window at bit 35 - 0.097% + +Testing bit 58 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 519 (1.01x) (8) +Testing collisions (high 24-36 bits) - Worst is 33 bits: 271/255 (1.06x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 522 (1.02x) (11) +Testing collisions (low 24-36 bits) - Worst is 33 bits: 281/255 (1.10x) +Testing distribution - Worst bias is the 18-bit window at bit 43 - 0.069% + +Testing bit 59 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 492 (0.96x) +Testing collisions (high 24-36 bits) - Worst is 35 bits: 67/63 (1.05x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 493 (0.96x) +Testing collisions (low 24-36 bits) - Worst is 36 bits: 37/31 (1.16x) +Testing distribution - Worst bias is the 18-bit window at bit 33 - 0.095% + +Testing bit 60 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 511 (1.00x) +Testing collisions (high 24-36 bits) - Worst is 31 bits: 1062/1023 (1.04x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 541 (1.06x) (30) +Testing collisions (low 24-36 bits) - Worst is 32 bits: 541/511 (1.06x) +Testing distribution - Worst bias is the 18-bit window at bit 117 - 0.081% + +Testing bit 61 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 535 (1.05x) (24) +Testing collisions (high 24-36 bits) - Worst is 36 bits: 42/31 (1.31x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 501 (0.98x) +Testing collisions (low 24-36 bits) - Worst is 34 bits: 139/127 (1.09x) +Testing distribution - Worst bias is the 18-bit window at bit 33 - 0.113% + +Testing bit 62 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 497 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 34 bits: 149/127 (1.16x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 469 (0.92x) +Testing collisions (low 24-36 bits) - Worst is 27 bits: 16327/16298 (1.00x) +Testing distribution - Worst bias is the 18-bit window at bit 110 - 0.081% + +Testing bit 63 +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 511.9, actual 497 (0.97x) +Testing collisions (high 24-36 bits) - Worst is 30 bits: 2101/2046 (1.03x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 511.9, actual 525 (1.03x) (14) +Testing collisions (low 24-36 bits) - Worst is 35 bits: 77/63 (1.20x) +Testing distribution - Worst bias is the 18-bit window at bit 44 - 0.104% + + +[[[ MomentChi2 Tests ]]] + +Analyze hashes produced from a serie of linearly increasing numbers of 32-bit, using a step of 2 ... +Target values to approximate : 38918200.000000 - 273633.333333 +8 threads starting... done +Popcount 1 stats : 38919252.565091 - 273648.911325 +Popcount 0 stats : 38918537.305173 - 273641.099761 +MomentChi2 for bits 1 : 2.02435 +MomentChi2 for bits 0 : 0.207893 + +Derivative stats (transition from 2 consecutive values) : +Popcount 1 stats : 38919044.064835 - 273655.103664 +Popcount 0 stats : 38918744.229139 - 273635.880049 +MomentChi2 for deriv b1 : 1.30177 +MomentChi2 for deriv b0 : 0.541206 + + Great + + +[[[ Prng Tests ]]] + +Generating 33554432 random numbers : +Testing collisions (128-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (high 32-bit) - Expected 130731.3, actual 130485 (1.00x) (-246) +Testing collisions (high 28-44 bits) - Worst is 38 bits: 2123/2047 (1.04x) +Testing collisions (low 64-bit) - Expected 0.0, actual 0 (0.00x) +Testing collisions (low 32-bit) - Expected 130731.3, actual 131036 (1.00x) (305) +Testing collisions (low 28-44 bits) - Worst is 42 bits: 137/127 (1.07x) + +[[[ BadSeeds Tests ]]] + +Testing 0 internal secrets: +0x0 PASS + + +Input vcode 0x00000001, Output vcode 0x00000001, Result vcode 0x00000001 +Verification value is 0x00000001 - Testing took 1131.114515 seconds +------------------------------------------------------------------------------- +[[[ BadSeeds Tests ]]] + +Testing 0 internal secrets: +0x0 PASS +Testing the first 0xffffffff seeds ... +8 threads starting... +at 0 at 20000000 at 40000000 at 60000000 at 80000000 at a0000000 at c0000000 at e0000000 0xc1ffffff 0xa1ffffff 0xe1ffffff 0x21ffffff 0x01ffffff 0x61ffffff 0x81ffffff 0x41ffffff 0xc3ffffff 0xe3ffffff 0x83ffffff 0xa3ffffff 0x03ffffff 0x23ffffff 0x63ffffff 0x43ffffff 0xc5ffffff 0xe5ffffff 0x05ffffff 0xa5ffffff 0x85ffffff 0x25ffffff 0x45ffffff 0x65ffffff 0xc7ffffff 0xe7ffffff 0x07ffffff 0x87ffffff 0xa7ffffff 0x27ffffff 0x47ffffff 0x67ffffff 0xc9ffffff 0xe9ffffff 0x09ffffff 0xa9ffffff 0x29ffffff 0x89ffffff 0x69ffffff 0x49ffffff 0xcbffffff 0x0bffffff 0xebffffff 0xabffffff 0x8bffffff 0x2bffffff 0x6bffffff 0x4bffffff 0xcdffffff 0xedffffff 0x0dffffff 0xadffffff 0x2dffffff 0x8dffffff 0x6dffffff 0x4dffffff 0xcfffffff 0x0fffffff 0xefffffff 0xafffffff 0x8fffffff 0x2fffffff 0x4fffffff 0x6fffffff 0xd1ffffff 0x11ffffff 0xf1ffffff 0x91ffffff 0xb1ffffff 0x31ffffff 0x71ffffff 0x51ffffff 0xd3ffffff 0x13ffffff 0xf3ffffff 0x93ffffff 0xb3ffffff 0x33ffffff 0x53ffffff 0x73ffffff 0xd5ffffff 0x15ffffff 0xf5ffffff 0xb5ffffff 0x95ffffff 0x35ffffff 0x55ffffff 0x75ffffff 0xd7ffffff 0x17ffffff 0xf7ffffff 0xb7ffffff 0x97ffffff 0x37ffffff 0x57ffffff 0x77ffffff 0xd9ffffff 0xf9ffffff 0x19ffffff 0xb9ffffff 0x99ffffff 0x39ffffff 0x59ffffff 0x79ffffff 0xdbffffff 0xbbffffff 0x1bffffff 0xfbffffff 0x9bffffff 0x3bffffff 0x5bffffff 0x7bffffff 0xddffffff 0xbdffffff 0x1dffffff 0xfdffffff 0x9dffffff 0x3dffffff 0x5dffffff 0x7dffffff 0xdfffffff 0xbfffffff 0xffffffff 0x1fffffff 0x9fffffff 0x5fffffff 0x3fffffff 0x7fffffff All 8 threads ended +PASS + + diff --git a/doc/epyc.html b/doc/epyc.html index 8b62b5bd..e182d69c 100644 --- a/doc/epyc.html +++ b/doc/epyc.html @@ -1032,6 +1032,14 @@

SMhasher

fails many tests, machine-specific (x64 AES-NI) +aesni-hash-peterrk +28435.27 +28.83 +126.43 (2) + +fails many tests, machine-specific (x64 AES-NI) + + falkhash 66674.45 83.69 diff --git a/doc/i7.html b/doc/i7.html index 31e2ebb4..45a19aae 100644 --- a/doc/i7.html +++ b/doc/i7.html @@ -1032,6 +1032,14 @@

SMhasher

fails many tests, machine-specific (x64 AES-NI) +aesni-hash-peterrk +32644.92 +22.28 +126.19 (3) + +fails many tests, machine-specific (x64 AES-NI) + + falkhash 46580.43 84.93 diff --git a/doc/ryzen3.html b/doc/ryzen3.html index 72c06fe4..b1d74a85 100644 --- a/doc/ryzen3.html +++ b/doc/ryzen3.html @@ -1016,6 +1016,14 @@

SMhasher

fails many tests, machine-specific (x64 AES-NI) +aesni-hash-peterrk +35244.97 +23.99 +481.13 (26) + +fails many tests, machine-specific (x64 AES-NI) + + falkhash 62025.17 128.28 diff --git a/doc/table.html b/doc/table.html index abc95d90..070ef287 100644 --- a/doc/table.html +++ b/doc/table.html @@ -1000,6 +1000,14 @@

SMhasher

fails many tests, machine-specific (x64 AES-NI) +aesni-hash-peterrk +29107.73 +28.86 +217.57 (1) + +fails many tests, machine-specific (x64 AES-NI) + + falkhash 52401.48 122.70 diff --git a/main.cpp b/main.cpp index 149ccd00..b846e6a6 100644 --- a/main.cpp +++ b/main.cpp @@ -385,7 +385,7 @@ HashInfo g_hashes[] = #if defined(HAVE_SSE2) && defined(HAVE_AESNI) && !defined(_MSC_VER) { aesnihash_test, 64, 0xA68E0D42, "aesnihash", "majek's seeded aesnihash with aesenc, 64-bit for x64", POOR, {0x70736575} }, - +{ aesnihash_peterrk, 128, 0xF06DA1B1, "aesni-hash-peterrk", "PeterRK's seeded aesnihash with aesenc, 128-bit for x64", GOOD, {} }, { aesni128_test, 128, 0xF06DA1B1, "aesni", "aesni 128bit", GOOD,{} }, { aesni64_test, 64, 0x3AA1A480, "aesni-low","aesni 64bit", GOOD,{} }, #endif diff --git a/testspeed-i7.sh b/testspeed-i7.sh index 484f5d55..ceb902de 100755 --- a/testspeed-i7.sh +++ b/testspeed-i7.sh @@ -2,10 +2,10 @@ make -C build ./start-bench.sh if [ -z "$1" ]; then - test -f log.speed-i7-6820 && mv log.speed-i7-6820 log.speed-i7-6820.bak + test -f log.speed-i7 && mv log.speed-i7 log.speed-i7.bak (for g in `build/SMHasher --listnames`; do \ - build/SMHasher --test=Speed,Hashmap $g 2>&1; done) | tee log.speed-i7-6820 - ./speed.pl -h=doc/i7 log.speed-i7-6820 + build/SMHasher --test=Speed,Hashmap $g 2>&1; done) | tee log.speed-i7 + ./speed.pl -h=doc/i7 log.speed-i7 else for g in `build/SMHasher --listnames`; do for p in $@; do @@ -13,7 +13,7 @@ else build/SMHasher --test=Speed,Hashmap $g 2>&1 fi done - done | tee "log.speed-i7-6820-$1" - ./speed.pl -h=doc/i7 "log.speed-i7-6820-$1" + done | tee "log.speed-i7-$1" + ./speed.pl -h=doc/i7 "log.speed-i7-$1" fi ./stop-bench.sh diff --git a/testspeed.sh b/testspeed.sh index afcb7bde..0878cdd3 100755 --- a/testspeed.sh +++ b/testspeed.sh @@ -1,6 +1,6 @@ #!/bin/bash hname="`hostname`" -if [ x$hname = xe495 ]; then +if [ x$hname = xe495-reini ] || [ x$hname = xe495 ]; then ./testspeed-ryzen3.sh $@ exit fi