Balanced Allocations and Double Hashing

Abstract

Double hashing has recently found more common usage in schemes that use multiple hash functions. In double hashing, for an item x, one generates two hash values f(x) and g(x), and then uses combinations (f(x) +k g(x)) n for k=0,1,2,... to generate multiple hash values from the initial two. We first perform an empirical study showing that, surprisingly, the performance difference between double hashing and fully random hashing appears negligible in the standard balanced allocation paradigm, where each item is placed in the least loaded of d choices, as well as several related variants. We then provide theoretical results that explain the behavior of double hashing in this context.

0

Turn this paper into a lesson

ArcXiv compiles a structured reading guide from this paper's metadata: plain-English importance, contributions, prerequisite concepts, which sections to read first, flashcards, and a quiz. Grounded in the abstract, never invented.

Discussion (0)

Sign in to join the discussion.

Loading comments…