Descriptionstrconv: faster FormatFloat(x, *, -1, 64) using Grisu3 algorithm.
The implementation is similar to the one from the double-conversion
library used in the Chrome V8 engine.
old ns/op new ns/op speedup
BenchmarkAppendFloatDecimal 591 480 1.2x
BenchmarkAppendFloat 2956 486 6.1x
BenchmarkAppendFloatExp 10622 503 21.1x
BenchmarkAppendFloatNegExp 40343 483 83.5x
BenchmarkAppendFloatBig 2798 664 4.2x
See F. Loitsch, ``Printing Floating-Point Numbers Quickly and
Accurately with Integers'', Proceedings of the ACM, 2010.
Patch Set 1 #Patch Set 2 : diff -r c956aa39a269 https://go.googlecode.com/hg/ #Patch Set 3 : diff -r c956aa39a269 https://go.googlecode.com/hg/ #Patch Set 4 : diff -r c956aa39a269 https://go.googlecode.com/hg/ #
Total comments: 16
Patch Set 5 : diff -r e8bfc2f65c2b https://go.googlecode.com/hg/ #Patch Set 6 : diff -r 11bb73c84e6c https://go.googlecode.com/hg/ #
MessagesTotal messages: 8
|