mirror of
https://github.com/golang/go
synced 2024-11-07 12:26:16 -07:00
519474451a
This is a subset of https://golang.org/cl/20022 with only the copyright header lines, so the next CL will be smaller and more reviewable. Go policy has been single space after periods in comments for some time. The copyright header template at: https://golang.org/doc/contribute.html#copyright also uses a single space. Make them all consistent. Change-Id: Icc26c6b8495c3820da6b171ca96a74701b4a01b0 Reviewed-on: https://go-review.googlesource.com/20111 Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org> Reviewed-by: Matthew Dempsky <mdempsky@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org>
35 lines
784 B
Go
35 lines
784 B
Go
// 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)
|
|
}
|
|
}
|