Better GPU Hash Tables

Muhammad A. Awad,Saman Ashkiani,Serban D. Porumbescu,Martín Farach-Colton,John D. Owens
DOI: https://doi.org/10.48550/arXiv.2108.07232
2022-12-18
Abstract:We revisit the problem of building static hash tables on the GPU and design and build three bucketed hash tables that use different probing schemes. Our implementations are lock-free and offer efficient memory access patterns; thus, only the probing scheme is the factor affecting the performance of the hash table's different operations. Our results show that a bucketed cuckoo hash table that uses three hash functions (BCHT) outperforms alternative methods that use power-of-two choices, iceberg hashing, and a cuckoo hash table that uses a bucket size one. At high load factors as high as 0.99, BCHT enjoys an average probe count of 1.43 during insertion. Using three hash functions only, positive and negative queries require at most 1.39 and 2.8 average probes per key, respectively.
Data Structures and Algorithms
What problem does this paper attempt to address?