1 /* 2 * Copyright (C) 2017 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 /** 18 * Tests for SAD (sum of absolute differences). 19 */ 20 public class Main { 21 22 /// CHECK-START: int Main.sad1(byte, byte) instruction_simplifier$after_inlining (before) 23 /// CHECK-DAG: <<Select:i\d+>> Select 24 /// CHECK-DAG: Return [<<Select>>] 25 // 26 /// CHECK-START: int Main.sad1(byte, byte) instruction_simplifier$after_inlining (after) 27 /// CHECK-DAG: <<Intrin:i\d+>> InvokeStaticOrDirect intrinsic:MathAbsInt 28 /// CHECK-DAG: Return [<<Intrin>>] sad1(byte x, byte y)29 static int sad1(byte x, byte y) { 30 return x >= y ? x - y : y - x; 31 } 32 33 /// CHECK-START: int Main.sad2(byte, byte) instruction_simplifier$after_inlining (before) 34 /// CHECK-DAG: <<Select:i\d+>> Select 35 /// CHECK-DAG: Return [<<Select>>] 36 // 37 /// CHECK-START: int Main.sad2(byte, byte) instruction_simplifier$after_inlining (after) 38 /// CHECK-DAG: <<Intrin:i\d+>> InvokeStaticOrDirect intrinsic:MathAbsInt 39 /// CHECK-DAG: Return [<<Intrin>>] sad2(byte x, byte y)40 static int sad2(byte x, byte y) { 41 int diff = x - y; 42 if (diff < 0) diff = -diff; 43 return diff; 44 } 45 46 /// CHECK-START: int Main.sad3(byte, byte) instruction_simplifier$after_inlining (before) 47 /// CHECK-DAG: <<Select:i\d+>> Select 48 /// CHECK-DAG: Return [<<Select>>] 49 // 50 /// CHECK-START: int Main.sad3(byte, byte) instruction_simplifier$after_inlining (after) 51 /// CHECK-DAG: <<Intrin:i\d+>> InvokeStaticOrDirect intrinsic:MathAbsInt 52 /// CHECK-DAG: Return [<<Intrin>>] sad3(byte x, byte y)53 static int sad3(byte x, byte y) { 54 int diff = x - y; 55 return diff >= 0 ? diff : -diff; 56 } 57 58 /// CHECK-START: int Main.sad3Alt(byte, byte) instruction_simplifier$after_inlining (before) 59 /// CHECK-DAG: <<Select:i\d+>> Select 60 /// CHECK-DAG: Return [<<Select>>] 61 // 62 /// CHECK-START: int Main.sad3Alt(byte, byte) instruction_simplifier$after_inlining (after) 63 /// CHECK-DAG: <<Intrin:i\d+>> InvokeStaticOrDirect intrinsic:MathAbsInt 64 /// CHECK-DAG: Return [<<Intrin>>] sad3Alt(byte x, byte y)65 static int sad3Alt(byte x, byte y) { 66 int diff = x - y; 67 return 0 <= diff ? diff : -diff; 68 } 69 70 /// CHECK-START: long Main.sadL1(byte, byte) instruction_simplifier$after_inlining (before) 71 /// CHECK-DAG: <<Select:j\d+>> Select 72 /// CHECK-DAG: Return [<<Select>>] 73 // 74 /// CHECK-START: long Main.sadL1(byte, byte) instruction_simplifier$after_inlining (after) 75 /// CHECK-DAG: <<Intrin:j\d+>> InvokeStaticOrDirect intrinsic:MathAbsLong 76 /// CHECK-DAG: Return [<<Intrin>>] sadL1(byte x, byte y)77 static long sadL1(byte x, byte y) { 78 long xl = x; 79 long yl = y; 80 return xl >= yl ? xl - yl : yl - xl; 81 } 82 83 /// CHECK-START: long Main.sadL2(byte, byte) instruction_simplifier$after_inlining (before) 84 /// CHECK-DAG: <<Select:j\d+>> Select 85 /// CHECK-DAG: Return [<<Select>>] 86 // 87 /// CHECK-START: long Main.sadL2(byte, byte) instruction_simplifier$after_inlining (after) 88 /// CHECK-DAG: <<Intrin:j\d+>> InvokeStaticOrDirect intrinsic:MathAbsLong 89 /// CHECK-DAG: Return [<<Intrin>>] sadL2(byte x, byte y)90 static long sadL2(byte x, byte y) { 91 long diff = x - y; 92 if (diff < 0L) diff = -diff; 93 return diff; 94 } 95 96 /// CHECK-START: long Main.sadL3(byte, byte) instruction_simplifier$after_inlining (before) 97 /// CHECK-DAG: <<Select:j\d+>> Select 98 /// CHECK-DAG: Return [<<Select>>] 99 // 100 /// CHECK-START: long Main.sadL3(byte, byte) instruction_simplifier$after_inlining (after) 101 /// CHECK-DAG: <<Intrin:j\d+>> InvokeStaticOrDirect intrinsic:MathAbsLong 102 /// CHECK-DAG: Return [<<Intrin>>] sadL3(byte x, byte y)103 static long sadL3(byte x, byte y) { 104 long diff = x - y; 105 return diff >= 0L ? diff : -diff; 106 } 107 108 /// CHECK-START: long Main.sadL3Alt(byte, byte) instruction_simplifier$after_inlining (before) 109 /// CHECK-DAG: <<Select:j\d+>> Select 110 /// CHECK-DAG: Return [<<Select>>] 111 // 112 /// CHECK-START: long Main.sadL3Alt(byte, byte) instruction_simplifier$after_inlining (after) 113 /// CHECK-DAG: <<Intrin:j\d+>> InvokeStaticOrDirect intrinsic:MathAbsLong 114 /// CHECK-DAG: Return [<<Intrin>>] sadL3Alt(byte x, byte y)115 static long sadL3Alt(byte x, byte y) { 116 long diff = x - y; 117 return 0L <= diff ? diff : -diff; 118 } 119 main(String[] args)120 public static void main(String[] args) { 121 // Use cross-values to test all cases. 122 int n = 256; 123 for (int i = 0; i < n; i++) { 124 for (int j = 0; j < n; j++) { 125 byte x = (byte) i; 126 byte y = (byte) j; 127 int e = Math.abs(x - y); 128 expectEquals(e, sad1(x, y)); 129 expectEquals(e, sad2(x, y)); 130 expectEquals(e, sad3(x, y)); 131 expectEquals(e, sad3Alt(x, y)); 132 expectEquals(e, sadL2(x, y)); 133 expectEquals(e, sadL3(x, y)); 134 expectEquals(e, sadL3Alt(x, y)); 135 } 136 } 137 System.out.println("passed"); 138 } 139 expectEquals(int expected, int result)140 private static void expectEquals(int expected, int result) { 141 if (expected != result) { 142 throw new Error("Expected: " + expected + ", found: " + result); 143 } 144 } 145 expectEquals(long expected, long result)146 private static void expectEquals(long expected, long result) { 147 if (expected != result) { 148 throw new Error("Expected: " + expected + ", found: " + result); 149 } 150 } 151 } 152