Probability of 64bit Hash Code Collisions

后端 未结 4 989
天涯浪人
天涯浪人 2021-02-04 07:30

The book Numerical Recipes offers a method to calculate 64bit hash codes in order to reduce the number of collisions.

The algorithm is shown at http://www.javamex.com/tu

4条回答
  •  再見小時候
    2021-02-04 07:56

    Is there a formula to estimate the probability of collisions taking into account the so-called Birthday Paradox?

    Using the Birthday Paradox formula simply tells you at what point you need to start worrying about a collision happening. This is at around Sqrt[n] where n is the total number of possible hash values. In this case n = 2^64 so the Birthday Paradox formula tells you that as long as the number of keys is significantly less than Sqrt[n] = Sqrt[2^64] = 2^32 or approximately 4 billion, you don't need to worry about collisions. The higher the n, the more accurate this estimation. In fact the probability p(k) that a collision will occur with k keys approaches a step function as n gets larger, where the step occurs at k=Sqrt[n].


    Can you estimate the probability of a collision (i.e two keys that hash to the same value)? Let's say with 1,000 keys and with 10,000 keys?

    Assuming the hash function is uniformly distributed it's straightforward to derive the formula.

    p(no collision for k keys) = 1 * (n-1)/n * (n-2)/n * (n-3)/n * ... * (n-(k-1))/n
    

    That formula directly follows from starting with 1 key: The probability of no collision with 1 key is of course 1. The probability of no collision with 2 keys is 1 * (n-1)/n. And so on for all k keys. Conveniently, Mathematica has a Pochhammer[] function for this purpose to express this succinctly:

    p(no collision for k keys) = Pochhammer[n-(k-1),k]/n^k
    

    Then, to calculate the probability that there is at least 1 collision for k keys, subtract it from 1:

    p(k) = 1 - p(no collision for k keys) = 1 - Pochhammer[n-(k-1),k]/n^k
    

    Using Mathematica, one can calculate for n=2^64:

    • p(1,000) = 1 out of 3.7*1013
    • p(10,000) = 1 out of 3.7*1011
    • p(1,000,000) = 1 out of 3.7*107

    Is it safe to assume that a collision of a reasonable number of keys (say, less than 10,000 keys) is so improbable so that if 2 hash codes are the same we can say that the keys are the same without any further checking?

    To answer this precisely depends upon the probability that 2 of the 10,000 keys were identical. What we are looking for is:

    p(a=b|h(a)=h(b)) = The probability that a=b given h(a)=h(b)
    

    where a and b are keys (possibly identical) and h() is the hashing function. We can apply Bayes' Theorem directly:

    p(a=b|h(a)=h(b)) = p(h(a)=h(b)|a=b) * p(a=b) / p(h(a)=h(b))
    

    We immediately see that p(h(a)=h(b)|a=b) = 1 (if a=b then of course h(a)=h(b)) so we get

    p(a=b|h(a)=h(b)) = p(a=b) / p(h(a)=h(b))
    

    As you can see this depends upon p(a=b) which is the probability that a and b are actually the same key. This depends upon how the group of 10,000 keys were selected in the first place. The calculations for the previous two questions assume all keys are distinct, so more information on this scenario is needed to fully answer it.

提交回复
热议问题