diff options
| author | Alberto Donizetti <alb.donizetti@gmail.com> | 2016-05-11 20:55:53 +0200 |
|---|---|---|
| committer | Robert Griesemer <gri@golang.org> | 2016-08-17 17:56:42 +0000 |
| commit | cda633b39b1353d23965337fb3118a3fc532a0c1 (patch) | |
| tree | 9fa01db2948d1486e14c7f7b45f7907a1c795b0a /src/math/big/float_test.go | |
| parent | f542576b9e576758b7e0a8ec7f8d07b5d0c1f29a (diff) | |
| download | go-cda633b39b1353d23965337fb3118a3fc532a0c1.tar.xz | |
math/big: avoid allocation in float.{Add, Sub} when there's no aliasing
name old time/op new time/op delta
FloatAdd/10-4 116ns ± 1% 82ns ± 0% -28.74% (p=0.008 n=5+5)
FloatAdd/100-4 124ns ± 0% 86ns ± 1% -30.34% (p=0.016 n=4+5)
FloatAdd/1000-4 192ns ± 1% 123ns ± 0% -35.94% (p=0.008 n=5+5)
FloatAdd/10000-4 826ns ± 0% 438ns ± 0% -46.99% (p=0.000 n=4+5)
FloatAdd/100000-4 6.82µs ± 1% 3.36µs ± 0% -50.74% (p=0.008 n=5+5)
FloatSub/10-4 108ns ± 1% 77ns ± 1% -29.06% (p=0.008 n=5+5)
FloatSub/100-4 115ns ± 0% 79ns ± 0% -31.48% (p=0.029 n=4+4)
FloatSub/1000-4 168ns ± 0% 99ns ± 0% -41.09% (p=0.029 n=4+4)
FloatSub/10000-4 690ns ± 2% 288ns ± 1% -58.24% (p=0.008 n=5+5)
FloatSub/100000-4 5.37µs ± 1% 2.10µs ± 1% -60.89% (p=0.008 n=5+5)
name old alloc/op new alloc/op delta
FloatAdd/10-4 48.0B ± 0% 0.0B ±NaN% -100.00% (p=0.008 n=5+5)
FloatAdd/100-4 64.0B ± 0% 0.0B ±NaN% -100.00% (p=0.008 n=5+5)
FloatAdd/1000-4 176B ± 0% 0B ±NaN% -100.00% (p=0.008 n=5+5)
FloatAdd/10000-4 1.41kB ± 0% 0.00kB ±NaN% -100.00% (p=0.008 n=5+5)
FloatAdd/100000-4 13.6kB ± 0% 0.0kB ±NaN% -100.00% (p=0.008 n=5+5)
FloatSub/10-4 48.0B ± 0% 0.0B ±NaN% -100.00% (p=0.008 n=5+5)
FloatSub/100-4 64.0B ± 0% 0.0B ±NaN% -100.00% (p=0.008 n=5+5)
FloatSub/1000-4 176B ± 0% 0B ±NaN% -100.00% (p=0.008 n=5+5)
FloatSub/10000-4 1.41kB ± 0% 0.00kB ±NaN% -100.00% (p=0.008 n=5+5)
FloatSub/100000-4 13.6kB ± 0% 0.0kB ±NaN% -100.00% (p=0.008 n=5+5)
Fixes #14868
Change-Id: Ia2b8b1a8ef0868288ecb25f812b17bd03ff40d1c
Reviewed-on: https://go-review.googlesource.com/23568
Reviewed-by: Robert Griesemer <gri@golang.org>
Diffstat (limited to 'src/math/big/float_test.go')
| -rw-r--r-- | src/math/big/float_test.go | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/math/big/float_test.go b/src/math/big/float_test.go index 464619b338..bea5ac175c 100644 --- a/src/math/big/float_test.go +++ b/src/math/big/float_test.go @@ -1762,3 +1762,41 @@ func TestFloatCmpSpecialValues(t *testing.T) { } } } + +func BenchmarkFloatAdd(b *testing.B) { + x := new(Float) + y := new(Float) + z := new(Float) + + for _, prec := range []uint{10, 1e2, 1e3, 1e4, 1e5} { + x.SetPrec(prec).SetRat(NewRat(1, 3)) + y.SetPrec(prec).SetRat(NewRat(1, 6)) + z.SetPrec(prec) + + b.Run(fmt.Sprintf("%v", prec), func(b *testing.B) { + b.ReportAllocs() + for i := 0; i < b.N; i++ { + z.Add(x, y) + } + }) + } +} + +func BenchmarkFloatSub(b *testing.B) { + x := new(Float) + y := new(Float) + z := new(Float) + + for _, prec := range []uint{10, 1e2, 1e3, 1e4, 1e5} { + x.SetPrec(prec).SetRat(NewRat(1, 3)) + y.SetPrec(prec).SetRat(NewRat(1, 6)) + z.SetPrec(prec) + + b.Run(fmt.Sprintf("%v", prec), func(b *testing.B) { + b.ReportAllocs() + for i := 0; i < b.N; i++ { + z.Sub(x, y) + } + }) + } +} |
