2016-03-01 15:57:46 -07:00
|
|
|
// Copyright 2015 The Go Authors. All rights reserved.
|
2015-09-14 15:03:45 -06:00
|
|
|
// 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
|
2015-10-13 20:49:40 -06:00
|
|
|
|
|
|
|
inc := 1
|
|
|
|
if testing.Short() {
|
|
|
|
// Check 1K total values, down from 64M.
|
|
|
|
inc = 1 << 16
|
|
|
|
}
|
|
|
|
for i := 1; i < 1<<randomBitCount; i += inc {
|
2015-09-14 15:03:45 -06:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|