lin
2025-06-05 ed3dd9d3e7519a82bb871d5eedb24a2fa0c91f47
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// Copyright 2015 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
 
package runtime_test
 
import (
   "math"
   "runtime"
   "testing"
)
 
func TestFastLog2(t *testing.T) {
   // Compute the euclidean distance between math.Log2 and the FastLog2
   // implementation over the range of interest for heap sampling.
   const randomBitCount = 26
   var e float64
 
   inc := 1
   if testing.Short() {
       // Check 1K total values, down from 64M.
       inc = 1 << 16
   }
   for i := 1; i < 1<<randomBitCount; i += inc {
       l, fl := math.Log2(float64(i)), runtime.Fastlog2(float64(i))
       d := l - fl
       e += d * d
   }
   e = math.Sqrt(e)
 
   if e > 1.0 {
       t.Fatalf("imprecision on fastlog2 implementation, want <=1.0, got %f", e)
   }
}