------------------------------------------------------------------------------- --- Testing sha1_32 "SHA1, low 32 bits" GOOD [[[ Sanity Tests ]]] Verification value 0xB3122757 ....... PASS Running sanity check 1 .......... PASS Running AppendedZeroesTest .......... PASS [[[ Speed Tests ]]] Bulk speed test - 262144-byte keys Alignment 7 - 0.198 bytes/cycle - 567.43 MiB/sec @ 3 ghz Alignment 6 - 0.199 bytes/cycle - 568.49 MiB/sec @ 3 ghz Alignment 5 - 0.201 bytes/cycle - 574.59 MiB/sec @ 3 ghz Alignment 4 - 0.201 bytes/cycle - 575.44 MiB/sec @ 3 ghz Alignment 3 - 0.201 bytes/cycle - 575.80 MiB/sec @ 3 ghz Alignment 2 - 0.201 bytes/cycle - 574.90 MiB/sec @ 3 ghz Alignment 1 - 0.201 bytes/cycle - 575.50 MiB/sec @ 3 ghz Alignment 0 - 0.202 bytes/cycle - 577.55 MiB/sec @ 3 ghz Average - 0.201 bytes/cycle - 573.71 MiB/sec @ 3 ghz Small key speed test - 1-byte keys - 877.59 cycles/hash Small key speed test - 2-byte keys - 852.81 cycles/hash Small key speed test - 3-byte keys - 840.47 cycles/hash Small key speed test - 4-byte keys - 848.78 cycles/hash Small key speed test - 5-byte keys - 841.76 cycles/hash Small key speed test - 6-byte keys - 829.37 cycles/hash Small key speed test - 7-byte keys - 810.37 cycles/hash Small key speed test - 8-byte keys - 810.64 cycles/hash Small key speed test - 9-byte keys - 801.61 cycles/hash Small key speed test - 10-byte keys - 784.74 cycles/hash Small key speed test - 11-byte keys - 771.82 cycles/hash Small key speed test - 12-byte keys - 782.93 cycles/hash Small key speed test - 13-byte keys - 777.59 cycles/hash Small key speed test - 14-byte keys - 754.30 cycles/hash Small key speed test - 15-byte keys - 742.14 cycles/hash Small key speed test - 16-byte keys - 752.07 cycles/hash Small key speed test - 17-byte keys - 743.80 cycles/hash Small key speed test - 18-byte keys - 723.07 cycles/hash Small key speed test - 19-byte keys - 717.42 cycles/hash Small key speed test - 20-byte keys - 718.24 cycles/hash Small key speed test - 21-byte keys - 707.08 cycles/hash Small key speed test - 22-byte keys - 677.87 cycles/hash Small key speed test - 23-byte keys - 669.44 cycles/hash Small key speed test - 24-byte keys - 672.72 cycles/hash Small key speed test - 25-byte keys - 665.64 cycles/hash Small key speed test - 26-byte keys - 647.72 cycles/hash Small key speed test - 27-byte keys - 637.28 cycles/hash Small key speed test - 28-byte keys - 694.61 cycles/hash Small key speed test - 29-byte keys - 628.25 cycles/hash Small key speed test - 30-byte keys - 711.92 cycles/hash Small key speed test - 31-byte keys - 622.73 cycles/hash Average 745.703 cycles/hash [[[ 'Hashmap' Speed Tests ]]] std::unordered_map Init std HashMapTest: 1331.295 cycles/op (104334 inserts, 1% deletions) Running std HashMapTest: 1201.543 cycles/op (31.0 stdv) greg7mdp/parallel-hashmap Init fast HashMapTest: 1154.986 cycles/op (104334 inserts, 1% deletions) Running fast HashMapTest: 1064.258 cycles/op (19.1 stdv) ....... PASS [[[ Avalanche Tests ]]] Testing 24-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.584000% Testing 32-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.587333% Testing 40-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.660667% Testing 48-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.667333% Testing 56-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.550000% Testing 64-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.611333% Testing 72-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.623333% Testing 80-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.581333% Testing 96-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.608000% Testing 112-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.690000% Testing 128-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.618000% Testing 160-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.647333% Testing 512-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.670000% Testing 1024-bit keys -> 32-bit hashes, 300000 reps.......... worst bias is 0.806667% [[[ Keyset 'Sparse' Tests ]]] Keyset 'Sparse' - 16-bit keys with up to 9 bits set - 50643 keys Testing collisions ( 32-bit) - Expected 0.3, actual 0 (0.00x) Testing collisions (high 19-25 bits) - Worst is 25 bits: 48/38 (1.26x) Testing collisions (low 19-25 bits) - Worst is 25 bits: 49/38 (1.28x) Testing distribution - Worst bias is the 13-bit window at bit 18 - 0.556% Keyset 'Sparse' - 24-bit keys with up to 8 bits set - 1271626 keys Testing collisions ( 32-bit) - Expected 188.2, actual 187 (0.99x) (-1) Testing distribution - Worst bias is the 17-bit window at bit 21 - 0.069% Keyset 'Sparse' - 32-bit keys with up to 7 bits set - 4514873 keys Testing collisions ( 32-bit) - Expected 2372.2, actual 2381 (1.00x) (9) Testing distribution - Worst bias is the 19-bit window at bit 25 - 0.038% Keyset 'Sparse' - 40-bit keys with up to 6 bits set - 4598479 keys Testing collisions ( 32-bit) - Expected 2460.8, actual 2394 (0.97x) Testing distribution - Worst bias is the 19-bit window at bit 16 - 0.056% Keyset 'Sparse' - 48-bit keys with up to 6 bits set - 14196869 keys Testing collisions ( 32-bit) - Expected 23437.8, actual 23370 (1.00x) (-67) Testing distribution - Worst bias is the 20-bit window at bit 20 - 0.017% Keyset 'Sparse' - 56-bit keys with up to 5 bits set - 4216423 keys Testing collisions ( 32-bit) - Expected 2069.0, actual 2090 (1.01x) (22) Testing distribution - Worst bias is the 19-bit window at bit 5 - 0.025% Keyset 'Sparse' - 64-bit keys with up to 5 bits set - 8303633 keys Testing collisions ( 32-bit) - Expected 8021.7, actual 7981 (0.99x) (-40) Testing distribution - Worst bias is the 20-bit window at bit 14 - 0.039% Keyset 'Sparse' - 72-bit keys with up to 5 bits set - 15082603 keys Testing collisions ( 32-bit) - Expected 26451.8, actual 26499 (1.00x) (48) Testing distribution - Worst bias is the 20-bit window at bit 23 - 0.021% Keyset 'Sparse' - 96-bit keys with up to 4 bits set - 3469497 keys Testing collisions ( 32-bit) - Expected 1401.0, actual 1427 (1.02x) (27) Testing distribution - Worst bias is the 19-bit window at bit 12 - 0.041% Keyset 'Sparse' - 160-bit keys with up to 4 bits set - 26977161 keys Testing collisions ( 32-bit) - Expected 84546.1, actual 84695 (1.00x) (149) Testing distribution - Worst bias is the 20-bit window at bit 24 - 0.010% Keyset 'Sparse' - 256-bit keys with up to 3 bits set - 2796417 keys Testing collisions ( 32-bit) - Expected 910.2, actual 933 (1.03x) (23) Testing distribution - Worst bias is the 19-bit window at bit 20 - 0.092% Keyset 'Sparse' - 512-bit keys with up to 3 bits set - 22370049 keys Testing collisions ( 32-bit) - Expected 58155.4, actual 58243 (1.00x) (88) Testing distribution - Worst bias is the 20-bit window at bit 21 - 0.012% Keyset 'Sparse' - 1024-bit keys with up to 2 bits set - 524801 keys Testing collisions ( 32-bit) - Expected 32.1, actual 32 (1.00x) Testing distribution - Worst bias is the 16-bit window at bit 0 - 0.187% Keyset 'Sparse' - 2048-bit keys with up to 2 bits set - 2098177 keys Testing collisions ( 32-bit) - Expected 512.4, actual 551 (1.08x) (39) Testing distribution - Worst bias is the 18-bit window at bit 17 - 0.075% [[[ Keyset 'Permutation' Tests ]]] Combination Lowbits Tests: Keyset 'Combination' - up to 7 blocks from a set of 8 - 2396744 keys Testing collisions ( 32-bit) - Expected 668.6, actual 609 (0.91x) Testing distribution - Worst bias is the 18-bit window at bit 10 - 0.067% Combination Highbits Tests Keyset 'Combination' - up to 7 blocks from a set of 8 - 2396744 keys Testing collisions ( 32-bit) - Expected 668.6, actual 620 (0.93x) Testing distribution - Worst bias is the 18-bit window at bit 1 - 0.038% Combination Hi-Lo Tests: Keyset 'Combination' - up to 6 blocks from a set of 15 - 12204240 keys Testing collisions ( 32-bit) - Expected 17322.9, actual 17472 (1.01x) (150) Testing distribution - Worst bias is the 20-bit window at bit 3 - 0.017% Combination 0x8000000 Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8314 (1.02x) (128) Testing distribution - Worst bias is the 20-bit window at bit 30 - 0.029% Combination 0x0000001 Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8081 (0.99x) (-105) Testing distribution - Worst bias is the 20-bit window at bit 0 - 0.048% Combination 0x800000000000000 Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8170 (1.00x) (-16) Testing distribution - Worst bias is the 20-bit window at bit 7 - 0.027% Combination 0x000000000000001 Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8315 (1.02x) (129) Testing distribution - Worst bias is the 20-bit window at bit 9 - 0.046% Combination 16-bytes [0-1] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8151 (1.00x) (-35) Testing distribution - Worst bias is the 20-bit window at bit 1 - 0.046% Combination 16-bytes [0-last] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8153 (1.00x) (-33) Testing distribution - Worst bias is the 20-bit window at bit 30 - 0.052% Combination 32-bytes [0-1] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8265 (1.01x) (79) Testing distribution - Worst bias is the 20-bit window at bit 31 - 0.035% Combination 32-bytes [0-last] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8131 (0.99x) (-55) Testing distribution - Worst bias is the 19-bit window at bit 1 - 0.029% Combination 64-bytes [0-1] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8259 (1.01x) (73) Testing distribution - Worst bias is the 20-bit window at bit 7 - 0.035% Combination 64-bytes [0-last] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8223 (1.00x) (37) Testing distribution - Worst bias is the 20-bit window at bit 12 - 0.029% Combination 128-bytes [0-1] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8221 (1.00x) (35) Testing distribution - Worst bias is the 20-bit window at bit 7 - 0.025% Combination 128-bytes [0-last] Tests: Keyset 'Combination' - up to 22 blocks from a set of 2 - 8388606 keys Testing collisions ( 32-bit) - Expected 8186.7, actual 8081 (0.99x) (-105) Testing distribution - Worst bias is the 20-bit window at bit 21 - 0.026% [[[ Keyset 'Window' Tests ]]] Keyset 'Window' - 72-bit key, 20-bit window - 72 tests, 1048576 keys per test Window at 0 - Testing collisions ( 32-bit) - Expected 128.0, actual 128 (1.00x) (1) Window at 1 - Testing collisions ( 32-bit) - Expected 128.0, actual 143 (1.12x) (16) Window at 2 - Testing collisions ( 32-bit) - Expected 128.0, actual 136 (1.06x) (9) Window at 3 - Testing collisions ( 32-bit) - Expected 128.0, actual 130 (1.02x) (3) Window at 4 - Testing collisions ( 32-bit) - Expected 128.0, actual 143 (1.12x) (16) Window at 5 - Testing collisions ( 32-bit) - Expected 128.0, actual 139 (1.09x) (12) Window at 6 - Testing collisions ( 32-bit) - Expected 128.0, actual 148 (1.16x) (21) Window at 7 - Testing collisions ( 32-bit) - Expected 128.0, actual 147 (1.15x) (20) Window at 8 - Testing collisions ( 32-bit) - Expected 128.0, actual 136 (1.06x) (9) Window at 9 - Testing collisions ( 32-bit) - Expected 128.0, actual 134 (1.05x) (7) Window at 10 - Testing collisions ( 32-bit) - Expected 128.0, actual 134 (1.05x) (7) Window at 11 - Testing collisions ( 32-bit) - Expected 128.0, actual 132 (1.03x) (5) Window at 12 - Testing collisions ( 32-bit) - Expected 128.0, actual 124 (0.97x) Window at 13 - Testing collisions ( 32-bit) - Expected 128.0, actual 124 (0.97x) Window at 14 - Testing collisions ( 32-bit) - Expected 128.0, actual 133 (1.04x) (6) Window at 15 - Testing collisions ( 32-bit) - Expected 128.0, actual 133 (1.04x) (6) Window at 16 - Testing collisions ( 32-bit) - Expected 128.0, actual 124 (0.97x) Window at 17 - Testing collisions ( 32-bit) - Expected 128.0, actual 126 (0.98x) (-1) Window at 18 - Testing collisions ( 32-bit) - Expected 128.0, actual 138 (1.08x) (11) Window at 19 - Testing collisions ( 32-bit) - Expected 128.0, actual 123 (0.96x) Window at 20 - Testing collisions ( 32-bit) - Expected 128.0, actual 121 (0.95x) Window at 21 - Testing collisions ( 32-bit) - Expected 128.0, actual 135 (1.05x) (8) Window at 22 - Testing collisions ( 32-bit) - Expected 128.0, actual 139 (1.09x) (12) Window at 23 - Testing collisions ( 32-bit) - Expected 128.0, actual 116 (0.91x) Window at 24 - Testing collisions ( 32-bit) - Expected 128.0, actual 130 (1.02x) (3) Window at 25 - Testing collisions ( 32-bit) - Expected 128.0, actual 152 (1.19x) (25) Window at 26 - Testing collisions ( 32-bit) - Expected 128.0, actual 160 (1.25x) (33) Window at 27 - Testing collisions ( 32-bit) - Expected 128.0, actual 150 (1.17x) (23) Window at 28 - Testing collisions ( 32-bit) - Expected 128.0, actual 141 (1.10x) (14) Window at 29 - Testing collisions ( 32-bit) - Expected 128.0, actual 123 (0.96x) Window at 30 - Testing collisions ( 32-bit) - Expected 128.0, actual 118 (0.92x) Window at 31 - Testing collisions ( 32-bit) - Expected 128.0, actual 121 (0.95x) Window at 32 - Testing collisions ( 32-bit) - Expected 128.0, actual 131 (1.02x) (4) Window at 33 - Testing collisions ( 32-bit) - Expected 128.0, actual 130 (1.02x) (3) Window at 34 - Testing collisions ( 32-bit) - Expected 128.0, actual 126 (0.98x) (-1) Window at 35 - Testing collisions ( 32-bit) - Expected 128.0, actual 145 (1.13x) (18) Window at 36 - Testing collisions ( 32-bit) - Expected 128.0, actual 130 (1.02x) (3) Window at 37 - Testing collisions ( 32-bit) - Expected 128.0, actual 114 (0.89x) Window at 38 - Testing collisions ( 32-bit) - Expected 128.0, actual 133 (1.04x) (6) Window at 39 - Testing collisions ( 32-bit) - Expected 128.0, actual 126 (0.98x) (-1) Window at 40 - Testing collisions ( 32-bit) - Expected 128.0, actual 114 (0.89x) Window at 41 - Testing collisions ( 32-bit) - Expected 128.0, actual 126 (0.98x) (-1) Window at 42 - Testing collisions ( 32-bit) - Expected 128.0, actual 140 (1.09x) (13) Window at 43 - Testing collisions ( 32-bit) - Expected 128.0, actual 135 (1.05x) (8) Window at 44 - Testing collisions ( 32-bit) - Expected 128.0, actual 122 (0.95x) Window at 45 - Testing collisions ( 32-bit) - Expected 128.0, actual 109 (0.85x) Window at 46 - Testing collisions ( 32-bit) - Expected 128.0, actual 121 (0.95x) Window at 47 - Testing collisions ( 32-bit) - Expected 128.0, actual 132 (1.03x) (5) Window at 48 - Testing collisions ( 32-bit) - Expected 128.0, actual 132 (1.03x) (5) Window at 49 - Testing collisions ( 32-bit) - Expected 128.0, actual 130 (1.02x) (3) Window at 50 - Testing collisions ( 32-bit) - Expected 128.0, actual 144 (1.13x) (17) Window at 51 - Testing collisions ( 32-bit) - Expected 128.0, actual 132 (1.03x) (5) Window at 52 - Testing collisions ( 32-bit) - Expected 128.0, actual 135 (1.05x) (8) Window at 53 - Testing collisions ( 32-bit) - Expected 128.0, actual 134 (1.05x) (7) Window at 54 - Testing collisions ( 32-bit) - Expected 128.0, actual 120 (0.94x) Window at 55 - Testing collisions ( 32-bit) - Expected 128.0, actual 123 (0.96x) Window at 56 - Testing collisions ( 32-bit) - Expected 128.0, actual 126 (0.98x) (-1) Window at 57 - Testing collisions ( 32-bit) - Expected 128.0, actual 99 (0.77x) Window at 58 - Testing collisions ( 32-bit) - Expected 128.0, actual 111 (0.87x) Window at 59 - Testing collisions ( 32-bit) - Expected 128.0, actual 148 (1.16x) (21) Window at 60 - Testing collisions ( 32-bit) - Expected 128.0, actual 158 (1.23x) (31) Window at 61 - Testing collisions ( 32-bit) - Expected 128.0, actual 156 (1.22x) (29) Window at 62 - Testing collisions ( 32-bit) - Expected 128.0, actual 154 (1.20x) (27) Window at 63 - Testing collisions ( 32-bit) - Expected 128.0, actual 138 (1.08x) (11) Window at 64 - Testing collisions ( 32-bit) - Expected 128.0, actual 114 (0.89x) Window at 65 - Testing collisions ( 32-bit) - Expected 128.0, actual 114 (0.89x) Window at 66 - Testing collisions ( 32-bit) - Expected 128.0, actual 123 (0.96x) Window at 67 - Testing collisions ( 32-bit) - Expected 128.0, actual 122 (0.95x) Window at 68 - Testing collisions ( 32-bit) - Expected 128.0, actual 136 (1.06x) (9) Window at 69 - Testing collisions ( 32-bit) - Expected 128.0, actual 137 (1.07x) (10) Window at 70 - Testing collisions ( 32-bit) - Expected 128.0, actual 127 (0.99x) Window at 71 - Testing collisions ( 32-bit) - Expected 128.0, actual 127 (0.99x) Window at 72 - Testing collisions ( 32-bit) - Expected 128.0, actual 128 (1.00x) (1) [[[ Keyset 'Cyclic' Tests ]]] Keyset 'Cyclic' - 8 cycles of 4 bytes - 100000 keys Testing collisions ( 32-bit) - Expected 1.2, actual 0 (0.00x) Testing collisions (high 20-27 bits) - Worst is 25 bits: 174/148 (1.17x) Testing collisions (low 20-27 bits) - Worst is 23 bits: 609/593 (1.03x) Testing distribution - Worst bias is the 14-bit window at bit 8 - 0.209% Keyset 'Cyclic' - 8 cycles of 5 bytes - 100000 keys Testing collisions ( 32-bit) - Expected 1.2, actual 1 (0.86x) Testing collisions (high 20-27 bits) - Worst is 27 bits: 42/37 (1.13x) Testing collisions (low 20-27 bits) - Worst is 26 bits: 78/74 (1.05x) Testing distribution - Worst bias is the 14-bit window at bit 0 - 0.444% Keyset 'Cyclic' - 8 cycles of 6 bytes - 100000 keys Testing collisions ( 32-bit) - Expected 1.2, actual 2 (1.72x) (1) Testing collisions (high 20-27 bits) - Worst is 20 bits: 4429/4620 (0.96x) Testing collisions (low 20-27 bits) - Worst is 22 bits: 1194/1182 (1.01x) Testing distribution - Worst bias is the 14-bit window at bit 10 - 0.248% Keyset 'Cyclic' - 8 cycles of 7 bytes - 100000 keys Testing collisions ( 32-bit) - Expected 1.2, actual 1 (0.86x) Testing collisions (high 20-27 bits) - Worst is 26 bits: 92/74 (1.24x) Testing collisions (low 20-27 bits) - Worst is 25 bits: 161/148 (1.08x) Testing distribution - Worst bias is the 14-bit window at bit 29 - 0.286% Keyset 'Cyclic' - 8 cycles of 8 bytes - 100000 keys Testing collisions ( 32-bit) - Expected 1.2, actual 3 (2.58x) (2) ! Testing collisions (high 20-27 bits) - Worst is 26 bits: 86/74 (1.15x) Testing collisions (low 20-27 bits) - Worst is 27 bits: 45/37 (1.21x) Testing distribution - Worst bias is the 14-bit window at bit 28 - 0.376% Keyset 'Cyclic' - 8 cycles of 12 bytes - 100000 keys Testing collisions ( 32-bit) - Expected 1.2, actual 0 (0.00x) Testing collisions (high 20-27 bits) - Worst is 20 bits: 4547/4620 (0.98x) Testing collisions (low 20-27 bits) - Worst is 27 bits: 42/37 (1.13x) Testing distribution - Worst bias is the 14-bit window at bit 30 - 0.549% [[[ Keyset 'TwoBytes' Tests ]]] Keyset 'TwoBytes' - up-to-4-byte keys, 652545 total keys Testing collisions ( 32-bit) - Expected 49.6, actual 55 (1.11x) (6) Testing distribution - Worst bias is the 16-bit window at bit 14 - 0.128% Keyset 'TwoBytes' - up-to-8-byte keys, 5471025 total keys Testing collisions ( 32-bit) - Expected 3483.1, actual 3465 (0.99x) (-18) Testing distribution - Worst bias is the 20-bit window at bit 11 - 0.066% Keyset 'TwoBytes' - up-to-12-byte keys, 18616785 total keys Testing collisions ( 32-bit) - Expected 40289.5, actual 40332 (1.00x) (43) Testing distribution - Worst bias is the 20-bit window at bit 31 - 0.018% Keyset 'TwoBytes' - up-to-16-byte keys, 44251425 total keys Testing collisions ( 32-bit) - Expected 227182.3, actual 227110 (1.00x) (-72) Testing distribution - Worst bias is the 20-bit window at bit 31 - 0.011% Keyset 'TwoBytes' - up-to-20-byte keys, 86536545 total keys Testing collisions ( 32-bit) - Expected 865959.1, actual 866613 (1.00x) (654) Testing distribution - Worst bias is the 20-bit window at bit 31 - 0.006% Keyset 'TwoBytes' - up-to-24-byte keys, 149633745 total keys Testing collisions ( 32-bit) - Expected 2576560.5, actual 2577761 (1.00x) (1201) Testing distribution - Worst bias is the 20-bit window at bit 10 - 0.001% [[[ Keyset 'Text' Tests ]]] Keyset 'Text' - keys of form "FooXXXXBar" - 14776336 keys Testing collisions ( 32-bit) - Expected 25389.0, actual 25197 (0.99x) (-192) Testing distribution - Worst bias is the 20-bit window at bit 22 - 0.019% Keyset 'Text' - keys of form "FooBarXXXX" - 14776336 keys Testing collisions ( 32-bit) - Expected 25389.0, actual 24974 (0.98x) (-415) Testing distribution - Worst bias is the 19-bit window at bit 0 - 0.015% Keyset 'Text' - keys of form "XXXXFooBar" - 14776336 keys Testing collisions ( 32-bit) - Expected 25389.0, actual 25411 (1.00x) (22) Testing distribution - Worst bias is the 20-bit window at bit 16 - 0.018% Keyset 'Words' - 4000000 random keys of len 6-16 from alnum charset Testing collisions ( 32-bit) - Expected 1862.1, actual 1774 (0.95x) Testing distribution - Worst bias is the 19-bit window at bit 10 - 0.044% Keyset 'Words' - 4000000 random keys of len 6-16 from password charset Testing collisions ( 32-bit) - Expected 1862.1, actual 1896 (1.02x) (34) Testing distribution - Worst bias is the 19-bit window at bit 14 - 0.045% Keyset 'Words' - 104334 dict words Testing collisions ( 32-bit) - Expected 1.3, actual 2 (1.58x) (1) Testing collisions (high 20-28 bits) - Worst is 20 bits: 5051/5022 (1.01x) Testing collisions (low 20-28 bits) - Worst is 24 bits: 327/323 (1.01x) Testing distribution - Worst bias is the 14-bit window at bit 30 - 0.477% [[[ Keyset 'Zeroes' Tests ]]] Keyset 'Zeroes' - 204800 keys Testing collisions ( 32-bit) - Expected 4.9, actual 8 (1.64x) (4) Testing collisions (high 21-29 bits) - Worst is 29 bits: 46/39 (1.18x) Testing collisions (low 21-29 bits) - Worst is 29 bits: 57/39 (1.46x) Testing distribution - Worst bias is the 15-bit window at bit 3 - 0.304% [[[ Keyset 'Seed' Tests ]]] Keyset 'Seed' - 5000000 keys Testing collisions ( 32-bit) - Expected 2909.3, actual 2891 (0.99x) (-18) Testing distribution - Worst bias is the 19-bit window at bit 12 - 0.035% [[[ Keyset 'PerlinNoise' Tests ]]] Testing 16777216 coordinates (L2) : Testing collisions ( 32-bit) - Expected 32725.4, actual 32604 (1.00x) (-121) Testing AV variant, 128 count with 4 spacing, 4-12: Testing collisions ( 32-bit) - Expected 1116.2, actual 1063 (0.95x) [[[ Diff 'Differential' Tests ]]] Testing 8303632 up-to-5-bit differentials in 64-bit keys -> 32 bit hashes. 100 reps, 830363200 total tests, expecting 0.19 random collisions.......... 0 total collisions, of which 0 single collisions were ignored Testing 11017632 up-to-4-bit differentials in 128-bit keys -> 32 bit hashes. 100 reps, 1101763200 total tests, expecting 0.26 random collisions.......... 0 total collisions, of which 0 single collisions were ignored Testing 2796416 up-to-3-bit differentials in 256-bit keys -> 32 bit hashes. 100 reps, 279641600 total tests, expecting 0.07 random collisions.......... 0 total collisions, of which 0 single collisions were ignored [[[ DiffDist 'Differential Distribution' Tests ]]] Testing bit 0 Testing collisions ( 32-bit) - Expected 511.9, actual 539 (1.05x) (28) Testing distribution - Worst bias is the 18-bit window at bit 5 - 0.068% Testing bit 1 Testing collisions ( 32-bit) - Expected 511.9, actual 520 (1.02x) (9) Testing distribution - Worst bias is the 18-bit window at bit 26 - 0.066% Testing bit 2 Testing collisions ( 32-bit) - Expected 511.9, actual 529 (1.03x) (18) Testing distribution - Worst bias is the 18-bit window at bit 28 - 0.055% Testing bit 3 Testing collisions ( 32-bit) - Expected 511.9, actual 530 (1.04x) (19) Testing distribution - Worst bias is the 18-bit window at bit 19 - 0.064% Testing bit 4 Testing collisions ( 32-bit) - Expected 511.9, actual 473 (0.92x) Testing distribution - Worst bias is the 18-bit window at bit 12 - 0.102% Testing bit 5 Testing collisions ( 32-bit) - Expected 511.9, actual 521 (1.02x) (10) Testing distribution - Worst bias is the 18-bit window at bit 31 - 0.091% Testing bit 6 Testing collisions ( 32-bit) - Expected 511.9, actual 493 (0.96x) Testing distribution - Worst bias is the 18-bit window at bit 27 - 0.061% Testing bit 7 Testing collisions ( 32-bit) - Expected 511.9, actual 520 (1.02x) (9) Testing distribution - Worst bias is the 18-bit window at bit 31 - 0.067% Testing bit 8 Testing collisions ( 32-bit) - Expected 511.9, actual 483 (0.94x) Testing distribution - Worst bias is the 18-bit window at bit 14 - 0.069% Testing bit 9 Testing collisions ( 32-bit) - Expected 511.9, actual 529 (1.03x) (18) Testing distribution - Worst bias is the 18-bit window at bit 6 - 0.062% Testing bit 10 Testing collisions ( 32-bit) - Expected 511.9, actual 515 (1.01x) (4) Testing distribution - Worst bias is the 18-bit window at bit 12 - 0.092% Testing bit 11 Testing collisions ( 32-bit) - Expected 511.9, actual 490 (0.96x) Testing distribution - Worst bias is the 18-bit window at bit 4 - 0.086% Testing bit 12 Testing collisions ( 32-bit) - Expected 511.9, actual 545 (1.06x) (34) Testing distribution - Worst bias is the 18-bit window at bit 3 - 0.042% Testing bit 13 Testing collisions ( 32-bit) - Expected 511.9, actual 510 (1.00x) (-1) Testing distribution - Worst bias is the 17-bit window at bit 14 - 0.041% Testing bit 14 Testing collisions ( 32-bit) - Expected 511.9, actual 499 (0.97x) Testing distribution - Worst bias is the 18-bit window at bit 24 - 0.041% Testing bit 15 Testing collisions ( 32-bit) - Expected 511.9, actual 541 (1.06x) (30) Testing distribution - Worst bias is the 17-bit window at bit 24 - 0.059% Testing bit 16 Testing collisions ( 32-bit) - Expected 511.9, actual 508 (0.99x) (-3) Testing distribution - Worst bias is the 16-bit window at bit 28 - 0.035% Testing bit 17 Testing collisions ( 32-bit) - Expected 511.9, actual 522 (1.02x) (11) Testing distribution - Worst bias is the 18-bit window at bit 16 - 0.063% Testing bit 18 Testing collisions ( 32-bit) - Expected 511.9, actual 497 (0.97x) Testing distribution - Worst bias is the 18-bit window at bit 27 - 0.066% Testing bit 19 Testing collisions ( 32-bit) - Expected 511.9, actual 490 (0.96x) Testing distribution - Worst bias is the 18-bit window at bit 19 - 0.102% Testing bit 20 Testing collisions ( 32-bit) - Expected 511.9, actual 538 (1.05x) (27) Testing distribution - Worst bias is the 18-bit window at bit 28 - 0.069% Testing bit 21 Testing collisions ( 32-bit) - Expected 511.9, actual 488 (0.95x) Testing distribution - Worst bias is the 18-bit window at bit 16 - 0.078% Testing bit 22 Testing collisions ( 32-bit) - Expected 511.9, actual 490 (0.96x) Testing distribution - Worst bias is the 18-bit window at bit 30 - 0.081% Testing bit 23 Testing collisions ( 32-bit) - Expected 511.9, actual 492 (0.96x) Testing distribution - Worst bias is the 18-bit window at bit 11 - 0.034% Testing bit 24 Testing collisions ( 32-bit) - Expected 511.9, actual 500 (0.98x) Testing distribution - Worst bias is the 18-bit window at bit 11 - 0.064% Testing bit 25 Testing collisions ( 32-bit) - Expected 511.9, actual 509 (0.99x) (-2) Testing distribution - Worst bias is the 18-bit window at bit 22 - 0.094% Testing bit 26 Testing collisions ( 32-bit) - Expected 511.9, actual 521 (1.02x) (10) Testing distribution - Worst bias is the 18-bit window at bit 17 - 0.058% Testing bit 27 Testing collisions ( 32-bit) - Expected 511.9, actual 511 (1.00x) Testing distribution - Worst bias is the 18-bit window at bit 26 - 0.045% Testing bit 28 Testing collisions ( 32-bit) - Expected 511.9, actual 488 (0.95x) Testing distribution - Worst bias is the 18-bit window at bit 23 - 0.113% Testing bit 29 Testing collisions ( 32-bit) - Expected 511.9, actual 511 (1.00x) Testing distribution - Worst bias is the 18-bit window at bit 15 - 0.083% Testing bit 30 Testing collisions ( 32-bit) - Expected 511.9, actual 508 (0.99x) (-3) Testing distribution - Worst bias is the 18-bit window at bit 23 - 0.054% Testing bit 31 Testing collisions ( 32-bit) - Expected 511.9, actual 526 (1.03x) (15) Testing distribution - Worst bias is the 18-bit window at bit 20 - 0.102% Testing bit 32 Testing collisions ( 32-bit) - Expected 511.9, actual 501 (0.98x) Testing distribution - Worst bias is the 17-bit window at bit 20 - 0.067% Testing bit 33 Testing collisions ( 32-bit) - Expected 511.9, actual 519 (1.01x) (8) Testing distribution - Worst bias is the 18-bit window at bit 28 - 0.074% Testing bit 34 Testing collisions ( 32-bit) - Expected 511.9, actual 533 (1.04x) (22) Testing distribution - Worst bias is the 18-bit window at bit 1 - 0.059% Testing bit 35 Testing collisions ( 32-bit) - Expected 511.9, actual 499 (0.97x) Testing distribution - Worst bias is the 18-bit window at bit 12 - 0.060% Testing bit 36 Testing collisions ( 32-bit) - Expected 511.9, actual 484 (0.95x) Testing distribution - Worst bias is the 18-bit window at bit 30 - 0.058% Testing bit 37 Testing collisions ( 32-bit) - Expected 511.9, actual 508 (0.99x) (-3) Testing distribution - Worst bias is the 18-bit window at bit 14 - 0.043% Testing bit 38 Testing collisions ( 32-bit) - Expected 511.9, actual 473 (0.92x) Testing distribution - Worst bias is the 18-bit window at bit 5 - 0.060% Testing bit 39 Testing collisions ( 32-bit) - Expected 511.9, actual 494 (0.97x) Testing distribution - Worst bias is the 18-bit window at bit 7 - 0.085% Testing bit 40 Testing collisions ( 32-bit) - Expected 511.9, actual 501 (0.98x) Testing distribution - Worst bias is the 18-bit window at bit 14 - 0.050% Testing bit 41 Testing collisions ( 32-bit) - Expected 511.9, actual 514 (1.00x) (3) Testing distribution - Worst bias is the 17-bit window at bit 28 - 0.041% Testing bit 42 Testing collisions ( 32-bit) - Expected 511.9, actual 519 (1.01x) (8) Testing distribution - Worst bias is the 18-bit window at bit 23 - 0.063% Testing bit 43 Testing collisions ( 32-bit) - Expected 511.9, actual 502 (0.98x) (-9) Testing distribution - Worst bias is the 18-bit window at bit 6 - 0.081% Testing bit 44 Testing collisions ( 32-bit) - Expected 511.9, actual 488 (0.95x) Testing distribution - Worst bias is the 18-bit window at bit 29 - 0.063% Testing bit 45 Testing collisions ( 32-bit) - Expected 511.9, actual 490 (0.96x) Testing distribution - Worst bias is the 18-bit window at bit 26 - 0.062% Testing bit 46 Testing collisions ( 32-bit) - Expected 511.9, actual 524 (1.02x) (13) Testing distribution - Worst bias is the 18-bit window at bit 13 - 0.075% Testing bit 47 Testing collisions ( 32-bit) - Expected 511.9, actual 519 (1.01x) (8) Testing distribution - Worst bias is the 18-bit window at bit 22 - 0.080% Testing bit 48 Testing collisions ( 32-bit) - Expected 511.9, actual 529 (1.03x) (18) Testing distribution - Worst bias is the 18-bit window at bit 22 - 0.062% Testing bit 49 Testing collisions ( 32-bit) - Expected 511.9, actual 533 (1.04x) (22) Testing distribution - Worst bias is the 18-bit window at bit 1 - 0.057% Testing bit 50 Testing collisions ( 32-bit) - Expected 511.9, actual 515 (1.01x) (4) Testing distribution - Worst bias is the 18-bit window at bit 28 - 0.163% Testing bit 51 Testing collisions ( 32-bit) - Expected 511.9, actual 532 (1.04x) (21) Testing distribution - Worst bias is the 18-bit window at bit 14 - 0.107% Testing bit 52 Testing collisions ( 32-bit) - Expected 511.9, actual 507 (0.99x) (-4) Testing distribution - Worst bias is the 18-bit window at bit 13 - 0.075% Testing bit 53 Testing collisions ( 32-bit) - Expected 511.9, actual 471 (0.92x) Testing distribution - Worst bias is the 18-bit window at bit 28 - 0.083% Testing bit 54 Testing collisions ( 32-bit) - Expected 511.9, actual 517 (1.01x) (6) Testing distribution - Worst bias is the 18-bit window at bit 8 - 0.062% Testing bit 55 Testing collisions ( 32-bit) - Expected 511.9, actual 515 (1.01x) (4) Testing distribution - Worst bias is the 18-bit window at bit 27 - 0.089% Testing bit 56 Testing collisions ( 32-bit) - Expected 511.9, actual 475 (0.93x) Testing distribution - Worst bias is the 18-bit window at bit 3 - 0.087% Testing bit 57 Testing collisions ( 32-bit) - Expected 511.9, actual 500 (0.98x) Testing distribution - Worst bias is the 17-bit window at bit 1 - 0.062% Testing bit 58 Testing collisions ( 32-bit) - Expected 511.9, actual 527 (1.03x) (16) Testing distribution - Worst bias is the 18-bit window at bit 1 - 0.061% Testing bit 59 Testing collisions ( 32-bit) - Expected 511.9, actual 521 (1.02x) (10) Testing distribution - Worst bias is the 18-bit window at bit 4 - 0.091% Testing bit 60 Testing collisions ( 32-bit) - Expected 511.9, actual 519 (1.01x) (8) Testing distribution - Worst bias is the 18-bit window at bit 26 - 0.041% Testing bit 61 Testing collisions ( 32-bit) - Expected 511.9, actual 522 (1.02x) (11) Testing distribution - Worst bias is the 18-bit window at bit 12 - 0.075% Testing bit 62 Testing collisions ( 32-bit) - Expected 511.9, actual 531 (1.04x) (20) Testing distribution - Worst bias is the 18-bit window at bit 8 - 0.074% Testing bit 63 Testing collisions ( 32-bit) - Expected 511.9, actual 516 (1.01x) (5) Testing distribution - Worst bias is the 18-bit window at bit 25 - 0.057% [[[ MomentChi2 Tests ]]] Analyze hashes produced from a serie of linearly increasing numbers of 32-bit, using a step of 6 ... Target values to approximate : 1391290.000000 - 2060.000000 4 threads starting... done Popcount 1 stats : 1391383.029454 - 2062.225866 Popcount 0 stats : 1391282.214612 - 2061.941309 MomentChi2 for bits 1 : 2.09947 MomentChi2 for bits 0 : 0.0147048 Derivative stats (transition from 2 consecutive values) : Popcount 1 stats : 1391170.203209 - 2061.347892 Popcount 0 stats : 1391356.854670 - 2062.002160 MomentChi2 for deriv b1 : 3.48218 MomentChi2 for deriv b0 : 1.08431 Great [[[ Prng Tests ]]] Skipping PRNG test; it is designed for hashes >= 64-bits [[[ BadSeeds Tests ]]] Testing 0 internal secrets: 0x0 PASS Input vcode 0x00000001, Output vcode 0x00000001, Result vcode 0x00000001 Verification value is 0x00000001 - Testing took 1739.564379 seconds -------------------------------------------------------------------------------