Commit 711d1ad7 authored by Keith Randall's avatar Keith Randall

runtime: be a lot more lenient on smhasher avalanche test.

Fixes #7943

LGTM=bradfitz
R=golang-codereviews, bradfitz
CC=golang-codereviews
https://golang.org/cl/98170043
parent e3eee85b
...@@ -397,10 +397,10 @@ func avalancheTest1(t *testing.T, k Key) { ...@@ -397,10 +397,10 @@ func avalancheTest1(t *testing.T, k Key) {
// all sums inside those bounds with 99% probability. // all sums inside those bounds with 99% probability.
N := n * hashSize N := n * hashSize
var c float64 var c float64
// find c such that Prob(mean-c*stddev < x < mean+c*stddev)^N > .99 // find c such that Prob(mean-c*stddev < x < mean+c*stddev)^N > .9999
for c = 0.0; math.Pow(math.Erf(c/math.Sqrt(2)), float64(N)) < .99; c += .1 { for c = 0.0; math.Pow(math.Erf(c/math.Sqrt(2)), float64(N)) < .9999; c += .1 {
} }
c *= 2.0 // allowed slack - we don't need to be perfectly random c *= 4.0 // allowed slack - we don't need to be perfectly random
mean := .5 * REP mean := .5 * REP
stddev := .5 * math.Sqrt(REP) stddev := .5 * math.Sqrt(REP)
low := int(mean - c*stddev) low := int(mean - c*stddev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment