2008-03-28 14:56:47 -06: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.
|
|
|
|
|
2008-06-27 18:06:23 -06:00
|
|
|
package math
|
2008-03-28 14:56:47 -06:00
|
|
|
|
|
|
|
/*
|
|
|
|
* this table might overflow 127-bit exponent representations.
|
|
|
|
* in that case, truncate it after 1.0e38.
|
|
|
|
* it is important to get all one can from this
|
|
|
|
* routine since it is used in atof to scale numbers.
|
|
|
|
* the presumption is that GO converts fp numbers better
|
|
|
|
* than multipication of lower powers of 10.
|
|
|
|
*/
|
|
|
|
|
2008-07-08 21:48:41 -06:00
|
|
|
const tabsize = 70;
|
|
|
|
var tab[tabsize] float64;
|
|
|
|
|
2008-11-19 17:14:31 -07:00
|
|
|
export func Pow10(e int) float64 {
|
2008-03-28 14:56:47 -06:00
|
|
|
if e < 0 {
|
2008-11-19 17:14:31 -07:00
|
|
|
return 1/Pow10(-e);
|
2008-03-28 14:56:47 -06:00
|
|
|
}
|
|
|
|
if e < tabsize {
|
|
|
|
return tab[e];
|
|
|
|
}
|
|
|
|
m := e/2;
|
2008-11-19 17:14:31 -07:00
|
|
|
return Pow10(m) * Pow10(e-m);
|
2008-03-28 14:56:47 -06:00
|
|
|
}
|
|
|
|
|
2008-11-19 17:14:31 -07:00
|
|
|
func init() {
|
2008-07-08 21:48:41 -06:00
|
|
|
tab[0] = 1.0e0;
|
|
|
|
tab[1] = 1.0e1;
|
|
|
|
for i:=2; i<tabsize; i++ {
|
|
|
|
m := i/2;
|
|
|
|
tab[i] = tab[m] * tab[i-m];
|
2008-03-28 14:56:47 -06:00
|
|
|
}
|
|
|
|
}
|