blob: 1dc733bf5597277610e3865d4f266ee7292ecd22 [file] [log] [blame] [edit]
// 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)
}
}