From: Joel Sing Date: Wed, 5 Apr 2023 20:11:01 +0000 (+1000) Subject: cmd/compile: add math benchmarks X-Git-Tag: go1.21rc1~891 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=7c2550b7bb284e189d9d977800baa33ebf137fea;p=gostls13.git cmd/compile: add math benchmarks This adds benchmarks for division and modulus of 64 bit signed and unsigned integers. Updates #59089 Change-Id: Ie757c6d74a1f355873e79619eae26ece21a8f23e Reviewed-on: https://go-review.googlesource.com/c/go/+/482656 Reviewed-by: David Chase Run-TryBot: Joel Sing TryBot-Result: Gopher Robot Reviewed-by: Keith Randall Reviewed-by: Keith Randall --- diff --git a/src/cmd/compile/internal/test/math_test.go b/src/cmd/compile/internal/test/math_test.go new file mode 100644 index 0000000000..6bcb4601ba --- /dev/null +++ b/src/cmd/compile/internal/test/math_test.go @@ -0,0 +1,167 @@ +package test + +import ( + "testing" +) + +var Output int + +func BenchmarkDiv64UnsignedSmall(b *testing.B) { + q := uint64(1) + for i := 1; i <= b.N; i++ { + q = (q + uint64(i)) / uint64(i) + } + Output = int(q) +} + +func BenchmarkDiv64Small(b *testing.B) { + q := int64(1) + for i := 1; i <= b.N; i++ { + q = (q + int64(i)) / int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64SmallNegDivisor(b *testing.B) { + q := int64(-1) + for i := 1; i <= b.N; i++ { + q = (int64(i) - q) / -int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64SmallNegDividend(b *testing.B) { + q := int64(-1) + for i := 1; i <= b.N; i++ { + q = -(int64(i) - q) / int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64SmallNegBoth(b *testing.B) { + q := int64(1) + for i := 1; i <= b.N; i++ { + q = -(int64(i) + q) / -int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64Unsigned(b *testing.B) { + q := uint64(1) + for i := 1; i <= b.N; i++ { + q = (uint64(0x7fffffffffffffff) - uint64(i) - (q & 1)) / uint64(i) + } + Output = int(q) +} + +func BenchmarkDiv64(b *testing.B) { + q := int64(1) + for i := 1; i <= b.N; i++ { + q = (int64(0x7fffffffffffffff) - int64(i) - (q & 1)) / int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64NegDivisor(b *testing.B) { + q := int64(-1) + for i := 1; i <= b.N; i++ { + q = (int64(0x7fffffffffffffff) - int64(i) - (q & 1)) / -int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64NegDividend(b *testing.B) { + q := int64(-1) + for i := 1; i <= b.N; i++ { + q = -(int64(0x7fffffffffffffff) - int64(i) - (q & 1)) / int64(i) + } + Output = int(q) +} + +func BenchmarkDiv64NegBoth(b *testing.B) { + q := int64(-1) + for i := 1; i <= b.N; i++ { + q = -(int64(0x7fffffffffffffff) - int64(i) - (q & 1)) / -int64(i) + } + Output = int(q) +} + +func BenchmarkMod64UnsignedSmall(b *testing.B) { + r := uint64(1) + for i := 1; i <= b.N; i++ { + r = (uint64(i) + r) % uint64(i) + } + Output = int(r) +} + +func BenchmarkMod64Small(b *testing.B) { + r := int64(1) + for i := 1; i <= b.N; i++ { + r = (int64(i) + r) % int64(i) + } + Output = int(r) +} + +func BenchmarkMod64SmallNegDivisor(b *testing.B) { + r := int64(-1) + for i := 1; i <= b.N; i++ { + r = (int64(i) - r) % -int64(i) + } + Output = int(r) +} + +func BenchmarkMod64SmallNegDividend(b *testing.B) { + r := int64(-1) + for i := 1; i <= b.N; i++ { + r = -(int64(i) - r) % int64(i) + } + Output = int(r) +} + +func BenchmarkMod64SmallNegBoth(b *testing.B) { + r := int64(1) + for i := 1; i <= b.N; i++ { + r = -(int64(i) + r) % -int64(i) + } + Output = int(r) +} + +func BenchmarkMod64Unsigned(b *testing.B) { + r := uint64(1) + for i := 1; i <= b.N; i++ { + r = (uint64(0x7fffffffffffffff) - uint64(i) - (r & 1)) % uint64(i) + } + Output = int(r) +} + +func BenchmarkMod64(b *testing.B) { + r := int64(1) + for i := 1; i <= b.N; i++ { + r = (int64(0x7fffffffffffffff) - int64(i) - (r & 1)) % int64(i) + } + Output = int(r) +} + +func BenchmarkMod64NegDivisor(b *testing.B) { + r := int64(-1) + for i := 1; i <= b.N; i++ { + r = (int64(0x7fffffffffffffff) - int64(i) - (r & 1)) % -int64(i) + } + Output = int(r) +} + +func BenchmarkMod64NegDividend(b *testing.B) { + r := int64(-1) + for i := 1; i <= b.N; i++ { + r = -(int64(0x7fffffffffffffff) - int64(i) - (r & 1)) % int64(i) + } + Output = int(r) +} + +func BenchmarkMod64NegBoth(b *testing.B) { + r := int64(1) + for i := 1; i <= b.N; i++ { + r = -(int64(0x7fffffffffffffff) - int64(i) - (r & 1)) % -int64(i) + } + Output = int(r) +}