Benchmarks for dictionary data structures: hash tables, maps, tries, etc.
The judy
package was removed from this test suite for instability;
it segfaults the program.
For all benchmarks:
$ stack bench
For just space:
$ stack bench :space
For just time:
$ stack bench :time
Case | Bytes | GCs |
---|---|---|
Data.Map.Strict.insert mempty | 64 | 0 |
Data.Map.Lazy.insert mempty | 64 | 0 |
Data.HashMap.Strict.insert mempty | 64 | 0 |
Data.HashMap.Lazy.insert mempty | 48 | 0 |
Case | Total bytes | Max residency | Final live | GCs |
---|---|---|---|---|
Data.Map.Strict.fromList (1 million) | 1,016,187,152 | 55,394,296 | 31,864 | 1,942 |
Data.Map.Lazy.fromList (1 million) | 1,016,187,152 | 55,394,296 | 31,864 | 1,942 |
Data.IntMap.Strict.fromList (1 million) | 776,852,648 | 55,207,424 | 31,864 | 1,489 |
Data.IntMap.Lazy.fromList (1 million) | 776,852,648 | 55,207,424 | 31,864 | 1,489 |
Data.HashMap.Strict.fromList (1 million) | 161,155,384 | 40,358,064 | 0 | 314 |
Data.HashMap.Lazy.fromList (1 million) | 161,155,384 | 40,358,064 | 0 | 314 |
Case | Total bytes | Max residency | Final live | GCs |
---|---|---|---|---|
Data.HashTable.IO.BasicHashTable (1 million) | 424,214,184 | 47,254,400 | 1,120 | 672 |
Data.HashTable.IO.CuckooHashTable (1 million) | 173,581,848 | 1,328 | 1,328 | 244 |
Data.HashTable.IO.LinearHashTable (1 million) | 281,294,784 | 22,373,256 | 0 | 545 |
Name | 10 | 100 | 1000 | 10000 |
---|---|---|---|---|
Data.Map.Lazy | 406.3 ns | 7.695 μs | 137.3 μs | 2.349 ms |
Data.Map.Strict | 473.1 ns | 9.485 μs | 165.3 μs | 2.769 ms |
Data.HashMap.Lazy | 287.2 ns | 3.949 μs | 53.47 μs | 1.741 ms |
Data.HashMap.Strict | 291.8 ns | 3.948 μs | 53.25 μs | 1.711 ms |
Data.IntMap.Lazy | 136.4 ns | 2.119 μs | 30.13 μs | 0.878 ms |
Data.IntMap.Strict | 161.3 ns | 2.878 μs | 39.46 μs | 0.985 ms |
Name | 10 | 100 | 1000 | 10000 |
---|---|---|---|---|
Data.HashTable.IO.BasicHashTable | 356.1 ns | 3.308 μs | 33.70 μs | 466.2 μs |
Data.HashTable.IO.LinearHashTable | 684.2 ns | 7.321 μs | 76.05 μs | 660.1 μs |
Data.HashTable.IO.CuckooHashTable | 875.3 ns | 8.493 μs | 85.69 μs | 943.4 μs |
Name | 10 | 100 | 1000 | 10000 | 100000 | 1000000 |
---|---|---|---|---|---|---|
Data.Map.Lazy | 422.4 ns | 5.036 μs | 63.85 μs | 742.4 μs | 10.38 ms | 154.1 ms |
Data.Map.Strict | 437.6 ns | 5.028 μs | 65.15 μs | 742.6 μs | 9.070 ms | 97.95 ms |
Data.HashMap.Lazy | 118.3 ns | 1.332 μs | 17.81 μs | 225.2 μs | 2.760 ms | 37.95 ms |
Data.HashMap.Strict | 114.4 ns | 1.315 μs | 17.94 μs | 225.5 μs | 2.884 ms | 38.64 ms |
Data.IntMap.Lazy | 66.73 ns | 0.454 μs | 5.146 μs | 121.1 μs | 1.533 ms | 23.48 ms |
Data.IntMap.Strict | 66.86 ns | 0.456 μs | 5.115 μs | 120.2 μs | 1.524 ms | 24.30 ms |
Name | 10 | 100 | 1000 | 10000 | 100000 |
---|---|---|---|---|---|
Data.HashTable.IO.BasicHashTable | 212.9 ns | 1.286 μs | 17.44 μs | 368.9 μs | 9.504 ms |
Data.HashTable.IO.LinearHashTable | 262.8 ns | 2.503 μs | 25.17 μs | 309.6 μs | 14.84 ms |
Data.HashTable.IO.CuckooHashTable | 1010 ns | 8.765 μs | 84.19 μs | 901.9 μs | 19.21 ms |
Name | 10 | 100 | 1000 | 10000 | 100000 | 1000000 |
---|---|---|---|---|---|---|
Data.Map.Lazy | 97.96 ns | 1.634 μs | 52.42 μs | 1023 μs | 20.27 ms | 697.9 ms |
Data.Map.Strict | 101.1 ns | 1.632 μs | 52.25 μs | 970.9 μs | 17.87 ms | 583.0 ms |
Data.HashMap.Lazy | 133.6 ns | 1.705 μs | 22.95 μs | 408.9 μs | 8.338 ms | 453.7 ms |
Data.HashMap.Strict | 132.9 ns | 1.728 μs | 22.42 μs | 411.9 μs | 8.540 ms | 460.5 ms |
Data.IntMap.Lazy | 105.7 ns | 1.756 μs | 53.45 μs | 895.8 μs | 14.88 ms | 710.6 ms |
Data.IntMap.Strict | 103.6 ns | 1.688 μs | 53.62 μs | 883.4 μs | 15.25 ms | 700.8 ms |
Name | 10 | 100 | 1000 | 10000 | 100000 | 1000000 |
---|---|---|---|---|---|---|
Data.HashTable.IO.BasicHashTable | 15.24 ns | 23.19 ns | 14.62 ns | 14.43 ns | 14.34 ns | 14.28 ns |
Data.HashTable.IO.LinearHashTable | 53.83 ns | 58.41 ns | 57.73 ns | 53.36 ns | 57.63 ns | 145.0 ns |
Data.HashTable.IO.CuckooHashTable | 59.15 ns | 57.50 ns | 57.13 ns | 58.15 ns | 57.69 ns | 56.47 ns |
Name | 10000 |
---|---|
Data.Map.Lazy | 3.584 ms |
Data.Map.Strict | 4.161 ms |
Data.HashMap.Lazy | 2.040 ms |
Data.HashMap.Strict | 2.075 ms |
Data.Trie | 8.717 ms |
Name | 10 | 100 | 1000 | 10000 |
---|---|---|---|---|
Data.Map.Lazy | 559.3 ns | 11.60 μs | 236.3 μs | 4.496 ms |
Data.Map.Strict | 631.5 ns | 13.54 μs | 246.4 μs | 5.082 ms |
Data.HashMap.Lazy | 547.8 ns | 7.100 μs | 96.10 μs | 2.741 ms |
Data.HashMap.Strict | 557.0 ns | 7.214 μs | 98.62 μs | 2.710 ms |
Data.Trie | 910.6 ns | 15.71 μs | 373.8 μs | 14.93 ms |
Name | 10000 |
---|---|
Data.Map.Lazy | 91.88 ns |
Data.Map.Strict | 91.35 ns |
Data.HashMap.Lazy | 27.23 ns |
Data.HashMap.Strict | 27.41 ns |
Data.Trie | 150.7 ns |
Name | 10000 |
---|---|
Data.Map.Lazy | 2.031 ms |
Data.Map.Strict | 1.915 ms |
Data.HashMap.Lazy | 0.678 ms |
Data.HashMap.Strict | 0.670 ms |
Data.Trie | 2.515 ms |