| // Copyright 2020 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 ssa |
| |
| import ( |
| "math/rand" |
| "testing" |
| ) |
| |
| var d int |
| |
| //go:noinline |
| func fn(a, b int) bool { |
| c := false |
| if a > 0 { |
| if b < 0 { |
| d = d + 1 |
| } |
| c = true |
| } |
| return c |
| } |
| |
| func BenchmarkPhioptPass(b *testing.B) { |
| for i := 0; i < b.N; i++ { |
| a := rand.Perm(i/10 + 10) |
| for i := 1; i < len(a)/2; i++ { |
| fn(a[i]-a[i-1], a[i+len(a)/2-2]-a[i+len(a)/2-1]) |
| } |
| } |
| } |
| |
| type Point struct { |
| X, Y int |
| } |
| |
| //go:noinline |
| func sign(p1, p2, p3 Point) bool { |
| return (p1.X-p3.X)*(p2.Y-p3.Y)-(p2.X-p3.X)*(p1.Y-p3.Y) < 0 |
| } |
| |
| func BenchmarkInvertLessThanNoov(b *testing.B) { |
| p1 := Point{1, 2} |
| p2 := Point{2, 3} |
| p3 := Point{3, 4} |
| for i := 0; i < b.N; i++ { |
| sign(p1, p2, p3) |
| } |
| } |