| // 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) | |
| } | |
| } | |