login

Year-end appeal: Please make a donation to the OEIS Foundation to support ongoing development and maintenance of the OEIS. We are now in our 61st year, we have over 378,000 sequences, and we’ve reached 11,000 citations (which often say “discovered thanks to the OEIS”).

Related to FNV primes: Least 0 < m < 256 with 4 or 5 1-bits such that 2^n + 256 + m > 16777600 (mod 1099494850560), or 0 if no such m exists.
1

%I #31 Oct 11 2017 05:20:57

%S 147,55,47,47,39,23,89,47,45,43,39,77,0,31,23,53,179,43,71,103,75,29,

%T 117,197,59,23,89,77,39,31,89,55,147,71,143,169,59,109,47,103,51,205,

%U 209,139,89,29,47,29,167,205,107,47,0,61,53,103,87,53,83,85,71,143,51,43

%N Related to FNV primes: Least 0 < m < 256 with 4 or 5 1-bits such that 2^n + 256 + m > 16777600 (mod 1099494850560), or 0 if no such m exists.

%C The FNV-primes for n=8*trunc((2^s+5)/12) and s=5..11 are used in FNV hashes: 24, 40, 88, 168, 344, 680, and 1368.

%C a(n) = 0 for almost all n, thus the fraction of bit sizes suitable for the FNV hash is asymptotically smaller than any fixed fraction. In practice this is not an issue since required sizes are small and for large values some nearby size can be chosen instead. - _Charles R Greathouse IV_, Apr 10 2012

%H Charles R Greathouse IV, <a href="/A195239/b195239.txt">Table of n, a(n) for n = 24..10000</a>

%H IETF, <a href="http://tools.ietf.org/html/draft-eastlake-fnv-13">The FNV non-cryptographic hash algorithm</a>

%H Landon Curt Noll, <a href="http://isthe.com/chongo/tech/comp/fnv/">Fowler/Noll/Vo (FNV) Hash</a>

%H Wikipedia, <a href="http://en.wikipedia.org/wiki/Fowler-Noll-Vo_hash_function">Fowler-Noll-Vo hash function</a>

%e a(24)=147 is binary 10010011, 2^24 + 256 + 147 = 16777619 is prime, and 16777619 > 16777600 (mod 1099494850560). With 24 = 8*trunc((2^5 + 5)/12) this prime is used for 2^5 = 32-bit FNV-hashing. For 2^6 = 64-bit FNV-hashing a(40)=179 with 40 = 8*trunc((64 + 5)/12) determines the FNV-prime 1099511628211.

%t a[n_] := Module[{t}, For[m = 15, m <= 241, m++, t = DigitCount[m, 2, 1]; If[t > 3 && t < 6 && PrimeQ[t = m + 2^n + 256] && Mod[t, 1099494850560] > 16777600, Return[m]]]; 0]; Table[a[n], {n, 24, 100}] (* _Jean-François Alcover_, Oct 10 2017, translated from PARI *)

%o (PARI) a(n)=my(t);for(m=15,241,t=vecsum(binary(m));if(t>3&&t<6&& isprime(t=2^n+256+m)&&t%1099494850560>16777600, return(m))); 0 \\ _Charles R Greathouse IV_, Apr 10 2012

%K nonn

%O 24,1

%A _Frank Ellermann_, Sep 13 2011