mirror of
https://github.com/golang/go
synced 2024-11-13 20:10:32 -07:00
bed6326a3c
- Make Log2 exact for powers of two. - Fix error tolerance function to make tolerance a function of the correct (expected) value. Fixes #9066. Change-Id: I0320a93ce4130deed1c7b7685627d51acb7bc56d Reviewed-on: https://go-review.googlesource.com/12230 Reviewed-by: Ian Lance Taylor <iant@golang.org>
28 lines
740 B
Go
28 lines
740 B
Go
// Copyright 2009 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 math
|
|
|
|
// Log10 returns the decimal logarithm of x.
|
|
// The special cases are the same as for Log.
|
|
func Log10(x float64) float64
|
|
|
|
func log10(x float64) float64 {
|
|
return Log(x) * (1 / Ln10)
|
|
}
|
|
|
|
// Log2 returns the binary logarithm of x.
|
|
// The special cases are the same as for Log.
|
|
func Log2(x float64) float64
|
|
|
|
func log2(x float64) float64 {
|
|
frac, exp := Frexp(x)
|
|
// Make sure exact powers of two give an exact answer.
|
|
// Don't depend on Log(0.5)*(1/Ln2)+exp being exactly exp-1.
|
|
if frac == 0.5 {
|
|
return float64(exp - 1)
|
|
}
|
|
return Log(frac)*(1/Ln2) + float64(exp)
|
|
}
|