2010-12-03 04:34:57 +00:00
|
|
|
// 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.
|
2012-02-07 19:26:30 +00:00
|
|
|
|
|
|
|
//extern log10
|
|
|
|
func libc_log10(float64) float64
|
|
|
|
|
2012-01-12 01:31:45 +00:00
|
|
|
func Log10(x float64) float64 {
|
|
|
|
return libc_log10(x)
|
|
|
|
}
|
|
|
|
|
|
|
|
func log10(x float64) float64 {
|
|
|
|
return Log(x) * (1 / Ln10)
|
|
|
|
}
|
2010-12-03 04:34:57 +00:00
|
|
|
|
|
|
|
// Log2 returns the binary logarithm of x.
|
|
|
|
// The special cases are the same as for Log.
|
2012-02-07 19:26:30 +00:00
|
|
|
|
2012-01-12 01:31:45 +00:00
|
|
|
func Log2(x float64) float64 {
|
2012-02-16 07:17:03 +00:00
|
|
|
return log2(x)
|
2012-01-12 01:31:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func log2(x float64) float64 {
|
2012-12-22 01:15:33 +00:00
|
|
|
frac, exp := Frexp(x)
|
2015-10-31 00:59:47 +00:00
|
|
|
// 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)
|
|
|
|
}
|
2012-12-22 01:15:33 +00:00
|
|
|
return Log(frac)*(1/Ln2) + float64(exp)
|
2012-01-12 01:31:45 +00:00
|
|
|
}
|