1 /* 2 * Copyright (C) 2016 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 // Don't edit this file! It is auto-generated by frameworks/rs/api/generate.sh. 18 19 package android.renderscript.cts; 20 21 import android.renderscript.Allocation; 22 import android.renderscript.RSRuntimeException; 23 import android.renderscript.Element; 24 import android.renderscript.cts.Target; 25 26 import java.util.Arrays; 27 28 public class TestDot extends RSBaseCompute { 29 30 private ScriptC_TestDot script; 31 private ScriptC_TestDotRelaxed scriptRelaxed; 32 33 @Override setUp()34 protected void setUp() throws Exception { 35 super.setUp(); 36 script = new ScriptC_TestDot(mRS); 37 scriptRelaxed = new ScriptC_TestDotRelaxed(mRS); 38 } 39 40 @Override tearDown()41 protected void tearDown() throws Exception { 42 script.destroy(); 43 scriptRelaxed.destroy(); 44 super.tearDown(); 45 } 46 47 public class ArgumentsFloatFloatFloat { 48 public float inLeftVector; 49 public float inRightVector; 50 public Target.Floaty out; 51 } 52 checkDotFloatFloatFloat()53 private void checkDotFloatFloatFloat() { 54 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 1, 0x38fe5ebdf7ff2d3el, false); 55 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 1, 0x948dc35615f562efl, false); 56 try { 57 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 58 script.set_gAllocInRightVector(inRightVector); 59 script.forEach_testDotFloatFloatFloat(inLeftVector, out); 60 verifyResultsDotFloatFloatFloat(inLeftVector, inRightVector, out, false); 61 out.destroy(); 62 } catch (Exception e) { 63 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloatFloatFloat: " + e.toString()); 64 } 65 try { 66 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 67 scriptRelaxed.set_gAllocInRightVector(inRightVector); 68 scriptRelaxed.forEach_testDotFloatFloatFloat(inLeftVector, out); 69 verifyResultsDotFloatFloatFloat(inLeftVector, inRightVector, out, true); 70 out.destroy(); 71 } catch (Exception e) { 72 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloatFloatFloat: " + e.toString()); 73 } 74 inLeftVector.destroy(); 75 inRightVector.destroy(); 76 } 77 verifyResultsDotFloatFloatFloat(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)78 private void verifyResultsDotFloatFloatFloat(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 79 float[] arrayInLeftVector = new float[INPUTSIZE * 1]; 80 Arrays.fill(arrayInLeftVector, (float) 42); 81 inLeftVector.copyTo(arrayInLeftVector); 82 float[] arrayInRightVector = new float[INPUTSIZE * 1]; 83 Arrays.fill(arrayInRightVector, (float) 42); 84 inRightVector.copyTo(arrayInRightVector); 85 float[] arrayOut = new float[INPUTSIZE * 1]; 86 Arrays.fill(arrayOut, (float) 42); 87 out.copyTo(arrayOut); 88 StringBuilder message = new StringBuilder(); 89 boolean errorFound = false; 90 for (int i = 0; i < INPUTSIZE; i++) { 91 ArgumentsFloatFloatFloat args = new ArgumentsFloatFloatFloat(); 92 // Create the appropriate sized arrays in args 93 // Fill args with the input values 94 args.inLeftVector = arrayInLeftVector[i]; 95 args.inRightVector = arrayInRightVector[i]; 96 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.FLOAT, relaxed); 97 CoreMathVerifier.computeDot(args, target); 98 99 // Compare the expected outputs to the actual values returned by RS. 100 boolean valid = true; 101 if (!args.out.couldBe(arrayOut[i])) { 102 valid = false; 103 } 104 if (!valid) { 105 if (!errorFound) { 106 errorFound = true; 107 message.append("Input inLeftVector: "); 108 appendVariableToMessage(message, arrayInLeftVector[i]); 109 message.append("\n"); 110 message.append("Input inRightVector: "); 111 appendVariableToMessage(message, arrayInRightVector[i]); 112 message.append("\n"); 113 message.append("Expected output out: "); 114 appendVariableToMessage(message, args.out); 115 message.append("\n"); 116 message.append("Actual output out: "); 117 appendVariableToMessage(message, arrayOut[i]); 118 if (!args.out.couldBe(arrayOut[i])) { 119 message.append(" FAIL"); 120 } 121 message.append("\n"); 122 message.append("Errors at"); 123 } 124 message.append(" ["); 125 message.append(Integer.toString(i)); 126 message.append("]"); 127 } 128 } 129 assertFalse("Incorrect output for checkDotFloatFloatFloat" + 130 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 131 } 132 133 public class ArgumentsFloatNFloatNFloat { 134 public float[] inLeftVector; 135 public float[] inRightVector; 136 public Target.Floaty out; 137 } 138 checkDotFloat2Float2Float()139 private void checkDotFloat2Float2Float() { 140 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 2, 0x3a9fadaebf79d3a2l, false); 141 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 2, 0xdaa605c7978f55bbl, false); 142 try { 143 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 144 script.set_gAllocInRightVector(inRightVector); 145 script.forEach_testDotFloat2Float2Float(inLeftVector, out); 146 verifyResultsDotFloat2Float2Float(inLeftVector, inRightVector, out, false); 147 out.destroy(); 148 } catch (Exception e) { 149 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloat2Float2Float: " + e.toString()); 150 } 151 try { 152 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 153 scriptRelaxed.set_gAllocInRightVector(inRightVector); 154 scriptRelaxed.forEach_testDotFloat2Float2Float(inLeftVector, out); 155 verifyResultsDotFloat2Float2Float(inLeftVector, inRightVector, out, true); 156 out.destroy(); 157 } catch (Exception e) { 158 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloat2Float2Float: " + e.toString()); 159 } 160 inLeftVector.destroy(); 161 inRightVector.destroy(); 162 } 163 verifyResultsDotFloat2Float2Float(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)164 private void verifyResultsDotFloat2Float2Float(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 165 float[] arrayInLeftVector = new float[INPUTSIZE * 2]; 166 Arrays.fill(arrayInLeftVector, (float) 42); 167 inLeftVector.copyTo(arrayInLeftVector); 168 float[] arrayInRightVector = new float[INPUTSIZE * 2]; 169 Arrays.fill(arrayInRightVector, (float) 42); 170 inRightVector.copyTo(arrayInRightVector); 171 float[] arrayOut = new float[INPUTSIZE * 1]; 172 Arrays.fill(arrayOut, (float) 42); 173 out.copyTo(arrayOut); 174 StringBuilder message = new StringBuilder(); 175 boolean errorFound = false; 176 for (int i = 0; i < INPUTSIZE; i++) { 177 ArgumentsFloatNFloatNFloat args = new ArgumentsFloatNFloatNFloat(); 178 // Create the appropriate sized arrays in args 179 args.inLeftVector = new float[2]; 180 args.inRightVector = new float[2]; 181 // Fill args with the input values 182 for (int j = 0; j < 2 ; j++) { 183 args.inLeftVector[j] = arrayInLeftVector[i * 2 + j]; 184 } 185 for (int j = 0; j < 2 ; j++) { 186 args.inRightVector[j] = arrayInRightVector[i * 2 + j]; 187 } 188 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.FLOAT, relaxed); 189 CoreMathVerifier.computeDot(args, target); 190 191 // Compare the expected outputs to the actual values returned by RS. 192 boolean valid = true; 193 if (!args.out.couldBe(arrayOut[i])) { 194 valid = false; 195 } 196 if (!valid) { 197 if (!errorFound) { 198 errorFound = true; 199 for (int j = 0; j < 2 ; j++) { 200 message.append("Input inLeftVector: "); 201 appendVariableToMessage(message, arrayInLeftVector[i * 2 + j]); 202 message.append("\n"); 203 } 204 for (int j = 0; j < 2 ; j++) { 205 message.append("Input inRightVector: "); 206 appendVariableToMessage(message, arrayInRightVector[i * 2 + j]); 207 message.append("\n"); 208 } 209 message.append("Expected output out: "); 210 appendVariableToMessage(message, args.out); 211 message.append("\n"); 212 message.append("Actual output out: "); 213 appendVariableToMessage(message, arrayOut[i]); 214 if (!args.out.couldBe(arrayOut[i])) { 215 message.append(" FAIL"); 216 } 217 message.append("\n"); 218 message.append("Errors at"); 219 } 220 message.append(" ["); 221 message.append(Integer.toString(i)); 222 message.append("]"); 223 } 224 } 225 assertFalse("Incorrect output for checkDotFloat2Float2Float" + 226 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 227 } 228 checkDotFloat3Float3Float()229 private void checkDotFloat3Float3Float() { 230 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 3, 0x948d32ce11887f0l, false); 231 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 3, 0x910f51f73d379ed5l, false); 232 try { 233 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 234 script.set_gAllocInRightVector(inRightVector); 235 script.forEach_testDotFloat3Float3Float(inLeftVector, out); 236 verifyResultsDotFloat3Float3Float(inLeftVector, inRightVector, out, false); 237 out.destroy(); 238 } catch (Exception e) { 239 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloat3Float3Float: " + e.toString()); 240 } 241 try { 242 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 243 scriptRelaxed.set_gAllocInRightVector(inRightVector); 244 scriptRelaxed.forEach_testDotFloat3Float3Float(inLeftVector, out); 245 verifyResultsDotFloat3Float3Float(inLeftVector, inRightVector, out, true); 246 out.destroy(); 247 } catch (Exception e) { 248 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloat3Float3Float: " + e.toString()); 249 } 250 inLeftVector.destroy(); 251 inRightVector.destroy(); 252 } 253 verifyResultsDotFloat3Float3Float(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)254 private void verifyResultsDotFloat3Float3Float(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 255 float[] arrayInLeftVector = new float[INPUTSIZE * 4]; 256 Arrays.fill(arrayInLeftVector, (float) 42); 257 inLeftVector.copyTo(arrayInLeftVector); 258 float[] arrayInRightVector = new float[INPUTSIZE * 4]; 259 Arrays.fill(arrayInRightVector, (float) 42); 260 inRightVector.copyTo(arrayInRightVector); 261 float[] arrayOut = new float[INPUTSIZE * 1]; 262 Arrays.fill(arrayOut, (float) 42); 263 out.copyTo(arrayOut); 264 StringBuilder message = new StringBuilder(); 265 boolean errorFound = false; 266 for (int i = 0; i < INPUTSIZE; i++) { 267 ArgumentsFloatNFloatNFloat args = new ArgumentsFloatNFloatNFloat(); 268 // Create the appropriate sized arrays in args 269 args.inLeftVector = new float[3]; 270 args.inRightVector = new float[3]; 271 // Fill args with the input values 272 for (int j = 0; j < 3 ; j++) { 273 args.inLeftVector[j] = arrayInLeftVector[i * 4 + j]; 274 } 275 for (int j = 0; j < 3 ; j++) { 276 args.inRightVector[j] = arrayInRightVector[i * 4 + j]; 277 } 278 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.FLOAT, relaxed); 279 CoreMathVerifier.computeDot(args, target); 280 281 // Compare the expected outputs to the actual values returned by RS. 282 boolean valid = true; 283 if (!args.out.couldBe(arrayOut[i])) { 284 valid = false; 285 } 286 if (!valid) { 287 if (!errorFound) { 288 errorFound = true; 289 for (int j = 0; j < 3 ; j++) { 290 message.append("Input inLeftVector: "); 291 appendVariableToMessage(message, arrayInLeftVector[i * 4 + j]); 292 message.append("\n"); 293 } 294 for (int j = 0; j < 3 ; j++) { 295 message.append("Input inRightVector: "); 296 appendVariableToMessage(message, arrayInRightVector[i * 4 + j]); 297 message.append("\n"); 298 } 299 message.append("Expected output out: "); 300 appendVariableToMessage(message, args.out); 301 message.append("\n"); 302 message.append("Actual output out: "); 303 appendVariableToMessage(message, arrayOut[i]); 304 if (!args.out.couldBe(arrayOut[i])) { 305 message.append(" FAIL"); 306 } 307 message.append("\n"); 308 message.append("Errors at"); 309 } 310 message.append(" ["); 311 message.append(Integer.toString(i)); 312 message.append("]"); 313 } 314 } 315 assertFalse("Incorrect output for checkDotFloat3Float3Float" + 316 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 317 } 318 checkDotFloat4Float4Float()319 private void checkDotFloat4Float4Float() { 320 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 4, 0xd7f1f8ab02b73c3el, false); 321 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_32, 4, 0x47789e26e2dfe7efl, false); 322 try { 323 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 324 script.set_gAllocInRightVector(inRightVector); 325 script.forEach_testDotFloat4Float4Float(inLeftVector, out); 326 verifyResultsDotFloat4Float4Float(inLeftVector, inRightVector, out, false); 327 out.destroy(); 328 } catch (Exception e) { 329 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloat4Float4Float: " + e.toString()); 330 } 331 try { 332 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_32, 1), INPUTSIZE); 333 scriptRelaxed.set_gAllocInRightVector(inRightVector); 334 scriptRelaxed.forEach_testDotFloat4Float4Float(inLeftVector, out); 335 verifyResultsDotFloat4Float4Float(inLeftVector, inRightVector, out, true); 336 out.destroy(); 337 } catch (Exception e) { 338 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotFloat4Float4Float: " + e.toString()); 339 } 340 inLeftVector.destroy(); 341 inRightVector.destroy(); 342 } 343 verifyResultsDotFloat4Float4Float(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)344 private void verifyResultsDotFloat4Float4Float(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 345 float[] arrayInLeftVector = new float[INPUTSIZE * 4]; 346 Arrays.fill(arrayInLeftVector, (float) 42); 347 inLeftVector.copyTo(arrayInLeftVector); 348 float[] arrayInRightVector = new float[INPUTSIZE * 4]; 349 Arrays.fill(arrayInRightVector, (float) 42); 350 inRightVector.copyTo(arrayInRightVector); 351 float[] arrayOut = new float[INPUTSIZE * 1]; 352 Arrays.fill(arrayOut, (float) 42); 353 out.copyTo(arrayOut); 354 StringBuilder message = new StringBuilder(); 355 boolean errorFound = false; 356 for (int i = 0; i < INPUTSIZE; i++) { 357 ArgumentsFloatNFloatNFloat args = new ArgumentsFloatNFloatNFloat(); 358 // Create the appropriate sized arrays in args 359 args.inLeftVector = new float[4]; 360 args.inRightVector = new float[4]; 361 // Fill args with the input values 362 for (int j = 0; j < 4 ; j++) { 363 args.inLeftVector[j] = arrayInLeftVector[i * 4 + j]; 364 } 365 for (int j = 0; j < 4 ; j++) { 366 args.inRightVector[j] = arrayInRightVector[i * 4 + j]; 367 } 368 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.FLOAT, relaxed); 369 CoreMathVerifier.computeDot(args, target); 370 371 // Compare the expected outputs to the actual values returned by RS. 372 boolean valid = true; 373 if (!args.out.couldBe(arrayOut[i])) { 374 valid = false; 375 } 376 if (!valid) { 377 if (!errorFound) { 378 errorFound = true; 379 for (int j = 0; j < 4 ; j++) { 380 message.append("Input inLeftVector: "); 381 appendVariableToMessage(message, arrayInLeftVector[i * 4 + j]); 382 message.append("\n"); 383 } 384 for (int j = 0; j < 4 ; j++) { 385 message.append("Input inRightVector: "); 386 appendVariableToMessage(message, arrayInRightVector[i * 4 + j]); 387 message.append("\n"); 388 } 389 message.append("Expected output out: "); 390 appendVariableToMessage(message, args.out); 391 message.append("\n"); 392 message.append("Actual output out: "); 393 appendVariableToMessage(message, arrayOut[i]); 394 if (!args.out.couldBe(arrayOut[i])) { 395 message.append(" FAIL"); 396 } 397 message.append("\n"); 398 message.append("Errors at"); 399 } 400 message.append(" ["); 401 message.append(Integer.toString(i)); 402 message.append("]"); 403 } 404 } 405 assertFalse("Incorrect output for checkDotFloat4Float4Float" + 406 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 407 } 408 409 public class ArgumentsHalfHalfHalf { 410 public short inLeftVector; 411 public double inLeftVectorDouble; 412 public short inRightVector; 413 public double inRightVectorDouble; 414 public Target.Floaty out; 415 } 416 checkDotHalfHalfHalf()417 private void checkDotHalfHalfHalf() { 418 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 1, 0x39e78807cde53c8dl, false); 419 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 1, 0xbbb7b2bd0399f534l, false); 420 try { 421 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 422 script.set_gAllocInRightVector(inRightVector); 423 script.forEach_testDotHalfHalfHalf(inLeftVector, out); 424 verifyResultsDotHalfHalfHalf(inLeftVector, inRightVector, out, false); 425 out.destroy(); 426 } catch (Exception e) { 427 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalfHalfHalf: " + e.toString()); 428 } 429 try { 430 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 431 scriptRelaxed.set_gAllocInRightVector(inRightVector); 432 scriptRelaxed.forEach_testDotHalfHalfHalf(inLeftVector, out); 433 verifyResultsDotHalfHalfHalf(inLeftVector, inRightVector, out, true); 434 out.destroy(); 435 } catch (Exception e) { 436 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalfHalfHalf: " + e.toString()); 437 } 438 inLeftVector.destroy(); 439 inRightVector.destroy(); 440 } 441 verifyResultsDotHalfHalfHalf(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)442 private void verifyResultsDotHalfHalfHalf(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 443 short[] arrayInLeftVector = new short[INPUTSIZE * 1]; 444 Arrays.fill(arrayInLeftVector, (short) 42); 445 inLeftVector.copyTo(arrayInLeftVector); 446 short[] arrayInRightVector = new short[INPUTSIZE * 1]; 447 Arrays.fill(arrayInRightVector, (short) 42); 448 inRightVector.copyTo(arrayInRightVector); 449 short[] arrayOut = new short[INPUTSIZE * 1]; 450 Arrays.fill(arrayOut, (short) 42); 451 out.copyTo(arrayOut); 452 StringBuilder message = new StringBuilder(); 453 boolean errorFound = false; 454 for (int i = 0; i < INPUTSIZE; i++) { 455 ArgumentsHalfHalfHalf args = new ArgumentsHalfHalfHalf(); 456 // Create the appropriate sized arrays in args 457 // Fill args with the input values 458 args.inLeftVector = arrayInLeftVector[i]; 459 args.inLeftVectorDouble = Float16Utils.convertFloat16ToDouble(args.inLeftVector); 460 args.inRightVector = arrayInRightVector[i]; 461 args.inRightVectorDouble = Float16Utils.convertFloat16ToDouble(args.inRightVector); 462 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.HALF, relaxed); 463 CoreMathVerifier.computeDot(args, target); 464 465 // Compare the expected outputs to the actual values returned by RS. 466 boolean valid = true; 467 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 468 valid = false; 469 } 470 if (!valid) { 471 if (!errorFound) { 472 errorFound = true; 473 message.append("Input inLeftVector: "); 474 appendVariableToMessage(message, arrayInLeftVector[i]); 475 message.append("\n"); 476 message.append("Input inRightVector: "); 477 appendVariableToMessage(message, arrayInRightVector[i]); 478 message.append("\n"); 479 message.append("Expected output out: "); 480 appendVariableToMessage(message, args.out); 481 message.append("\n"); 482 message.append("Actual output out: "); 483 appendVariableToMessage(message, arrayOut[i]); 484 message.append("\n"); 485 message.append("Actual output out (in double): "); 486 appendVariableToMessage(message, Float16Utils.convertFloat16ToDouble(arrayOut[i])); 487 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 488 message.append(" FAIL"); 489 } 490 message.append("\n"); 491 message.append("Errors at"); 492 } 493 message.append(" ["); 494 message.append(Integer.toString(i)); 495 message.append("]"); 496 } 497 } 498 assertFalse("Incorrect output for checkDotHalfHalfHalf" + 499 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 500 } 501 502 public class ArgumentsHalfNHalfNHalf { 503 public short[] inLeftVector; 504 public double[] inLeftVectorDouble; 505 public short[] inRightVector; 506 public double[] inRightVectorDouble; 507 public Target.Floaty out; 508 } 509 checkDotHalf2Half2Half()510 private void checkDotHalf2Half2Half() { 511 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 2, 0xa7738380b1799cd3l, false); 512 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 2, 0x223af00b3d8620f6l, false); 513 try { 514 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 515 script.set_gAllocInRightVector(inRightVector); 516 script.forEach_testDotHalf2Half2Half(inLeftVector, out); 517 verifyResultsDotHalf2Half2Half(inLeftVector, inRightVector, out, false); 518 out.destroy(); 519 } catch (Exception e) { 520 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalf2Half2Half: " + e.toString()); 521 } 522 try { 523 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 524 scriptRelaxed.set_gAllocInRightVector(inRightVector); 525 scriptRelaxed.forEach_testDotHalf2Half2Half(inLeftVector, out); 526 verifyResultsDotHalf2Half2Half(inLeftVector, inRightVector, out, true); 527 out.destroy(); 528 } catch (Exception e) { 529 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalf2Half2Half: " + e.toString()); 530 } 531 inLeftVector.destroy(); 532 inRightVector.destroy(); 533 } 534 verifyResultsDotHalf2Half2Half(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)535 private void verifyResultsDotHalf2Half2Half(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 536 short[] arrayInLeftVector = new short[INPUTSIZE * 2]; 537 Arrays.fill(arrayInLeftVector, (short) 42); 538 inLeftVector.copyTo(arrayInLeftVector); 539 short[] arrayInRightVector = new short[INPUTSIZE * 2]; 540 Arrays.fill(arrayInRightVector, (short) 42); 541 inRightVector.copyTo(arrayInRightVector); 542 short[] arrayOut = new short[INPUTSIZE * 1]; 543 Arrays.fill(arrayOut, (short) 42); 544 out.copyTo(arrayOut); 545 StringBuilder message = new StringBuilder(); 546 boolean errorFound = false; 547 for (int i = 0; i < INPUTSIZE; i++) { 548 ArgumentsHalfNHalfNHalf args = new ArgumentsHalfNHalfNHalf(); 549 // Create the appropriate sized arrays in args 550 args.inLeftVector = new short[2]; 551 args.inLeftVectorDouble = new double[2]; 552 args.inRightVector = new short[2]; 553 args.inRightVectorDouble = new double[2]; 554 // Fill args with the input values 555 for (int j = 0; j < 2 ; j++) { 556 args.inLeftVector[j] = arrayInLeftVector[i * 2 + j]; 557 args.inLeftVectorDouble[j] = Float16Utils.convertFloat16ToDouble(args.inLeftVector[j]); 558 } 559 for (int j = 0; j < 2 ; j++) { 560 args.inRightVector[j] = arrayInRightVector[i * 2 + j]; 561 args.inRightVectorDouble[j] = Float16Utils.convertFloat16ToDouble(args.inRightVector[j]); 562 } 563 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.HALF, relaxed); 564 CoreMathVerifier.computeDot(args, target); 565 566 // Compare the expected outputs to the actual values returned by RS. 567 boolean valid = true; 568 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 569 valid = false; 570 } 571 if (!valid) { 572 if (!errorFound) { 573 errorFound = true; 574 for (int j = 0; j < 2 ; j++) { 575 message.append("Input inLeftVector: "); 576 appendVariableToMessage(message, arrayInLeftVector[i * 2 + j]); 577 message.append("\n"); 578 } 579 for (int j = 0; j < 2 ; j++) { 580 message.append("Input inRightVector: "); 581 appendVariableToMessage(message, arrayInRightVector[i * 2 + j]); 582 message.append("\n"); 583 } 584 message.append("Expected output out: "); 585 appendVariableToMessage(message, args.out); 586 message.append("\n"); 587 message.append("Actual output out: "); 588 appendVariableToMessage(message, arrayOut[i]); 589 message.append("\n"); 590 message.append("Actual output out (in double): "); 591 appendVariableToMessage(message, Float16Utils.convertFloat16ToDouble(arrayOut[i])); 592 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 593 message.append(" FAIL"); 594 } 595 message.append("\n"); 596 message.append("Errors at"); 597 } 598 message.append(" ["); 599 message.append(Integer.toString(i)); 600 message.append("]"); 601 } 602 } 603 assertFalse("Incorrect output for checkDotHalf2Half2Half" + 604 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 605 } 606 checkDotHalf3Half3Half()607 private void checkDotHalf3Half3Half() { 608 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 3, 0x552cd0d47bbe958fl, false); 609 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 3, 0x505aed1e371be88al, false); 610 try { 611 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 612 script.set_gAllocInRightVector(inRightVector); 613 script.forEach_testDotHalf3Half3Half(inLeftVector, out); 614 verifyResultsDotHalf3Half3Half(inLeftVector, inRightVector, out, false); 615 out.destroy(); 616 } catch (Exception e) { 617 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalf3Half3Half: " + e.toString()); 618 } 619 try { 620 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 621 scriptRelaxed.set_gAllocInRightVector(inRightVector); 622 scriptRelaxed.forEach_testDotHalf3Half3Half(inLeftVector, out); 623 verifyResultsDotHalf3Half3Half(inLeftVector, inRightVector, out, true); 624 out.destroy(); 625 } catch (Exception e) { 626 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalf3Half3Half: " + e.toString()); 627 } 628 inLeftVector.destroy(); 629 inRightVector.destroy(); 630 } 631 verifyResultsDotHalf3Half3Half(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)632 private void verifyResultsDotHalf3Half3Half(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 633 short[] arrayInLeftVector = new short[INPUTSIZE * 4]; 634 Arrays.fill(arrayInLeftVector, (short) 42); 635 inLeftVector.copyTo(arrayInLeftVector); 636 short[] arrayInRightVector = new short[INPUTSIZE * 4]; 637 Arrays.fill(arrayInRightVector, (short) 42); 638 inRightVector.copyTo(arrayInRightVector); 639 short[] arrayOut = new short[INPUTSIZE * 1]; 640 Arrays.fill(arrayOut, (short) 42); 641 out.copyTo(arrayOut); 642 StringBuilder message = new StringBuilder(); 643 boolean errorFound = false; 644 for (int i = 0; i < INPUTSIZE; i++) { 645 ArgumentsHalfNHalfNHalf args = new ArgumentsHalfNHalfNHalf(); 646 // Create the appropriate sized arrays in args 647 args.inLeftVector = new short[3]; 648 args.inLeftVectorDouble = new double[3]; 649 args.inRightVector = new short[3]; 650 args.inRightVectorDouble = new double[3]; 651 // Fill args with the input values 652 for (int j = 0; j < 3 ; j++) { 653 args.inLeftVector[j] = arrayInLeftVector[i * 4 + j]; 654 args.inLeftVectorDouble[j] = Float16Utils.convertFloat16ToDouble(args.inLeftVector[j]); 655 } 656 for (int j = 0; j < 3 ; j++) { 657 args.inRightVector[j] = arrayInRightVector[i * 4 + j]; 658 args.inRightVectorDouble[j] = Float16Utils.convertFloat16ToDouble(args.inRightVector[j]); 659 } 660 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.HALF, relaxed); 661 CoreMathVerifier.computeDot(args, target); 662 663 // Compare the expected outputs to the actual values returned by RS. 664 boolean valid = true; 665 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 666 valid = false; 667 } 668 if (!valid) { 669 if (!errorFound) { 670 errorFound = true; 671 for (int j = 0; j < 3 ; j++) { 672 message.append("Input inLeftVector: "); 673 appendVariableToMessage(message, arrayInLeftVector[i * 4 + j]); 674 message.append("\n"); 675 } 676 for (int j = 0; j < 3 ; j++) { 677 message.append("Input inRightVector: "); 678 appendVariableToMessage(message, arrayInRightVector[i * 4 + j]); 679 message.append("\n"); 680 } 681 message.append("Expected output out: "); 682 appendVariableToMessage(message, args.out); 683 message.append("\n"); 684 message.append("Actual output out: "); 685 appendVariableToMessage(message, arrayOut[i]); 686 message.append("\n"); 687 message.append("Actual output out (in double): "); 688 appendVariableToMessage(message, Float16Utils.convertFloat16ToDouble(arrayOut[i])); 689 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 690 message.append(" FAIL"); 691 } 692 message.append("\n"); 693 message.append("Errors at"); 694 } 695 message.append(" ["); 696 message.append(Integer.toString(i)); 697 message.append("]"); 698 } 699 } 700 assertFalse("Incorrect output for checkDotHalf3Half3Half" + 701 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 702 } 703 checkDotHalf4Half4Half()704 private void checkDotHalf4Half4Half() { 705 Allocation inLeftVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 4, 0x2e61e2846038e4bl, false); 706 Allocation inRightVector = createRandomAllocation(mRS, Element.DataType.FLOAT_16, 4, 0x7e7aea3130b1b01el, false); 707 try { 708 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 709 script.set_gAllocInRightVector(inRightVector); 710 script.forEach_testDotHalf4Half4Half(inLeftVector, out); 711 verifyResultsDotHalf4Half4Half(inLeftVector, inRightVector, out, false); 712 out.destroy(); 713 } catch (Exception e) { 714 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalf4Half4Half: " + e.toString()); 715 } 716 try { 717 Allocation out = Allocation.createSized(mRS, getElement(mRS, Element.DataType.FLOAT_16, 1), INPUTSIZE); 718 scriptRelaxed.set_gAllocInRightVector(inRightVector); 719 scriptRelaxed.forEach_testDotHalf4Half4Half(inLeftVector, out); 720 verifyResultsDotHalf4Half4Half(inLeftVector, inRightVector, out, true); 721 out.destroy(); 722 } catch (Exception e) { 723 throw new RSRuntimeException("RenderScript. Can't invoke forEach_testDotHalf4Half4Half: " + e.toString()); 724 } 725 inLeftVector.destroy(); 726 inRightVector.destroy(); 727 } 728 verifyResultsDotHalf4Half4Half(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed)729 private void verifyResultsDotHalf4Half4Half(Allocation inLeftVector, Allocation inRightVector, Allocation out, boolean relaxed) { 730 short[] arrayInLeftVector = new short[INPUTSIZE * 4]; 731 Arrays.fill(arrayInLeftVector, (short) 42); 732 inLeftVector.copyTo(arrayInLeftVector); 733 short[] arrayInRightVector = new short[INPUTSIZE * 4]; 734 Arrays.fill(arrayInRightVector, (short) 42); 735 inRightVector.copyTo(arrayInRightVector); 736 short[] arrayOut = new short[INPUTSIZE * 1]; 737 Arrays.fill(arrayOut, (short) 42); 738 out.copyTo(arrayOut); 739 StringBuilder message = new StringBuilder(); 740 boolean errorFound = false; 741 for (int i = 0; i < INPUTSIZE; i++) { 742 ArgumentsHalfNHalfNHalf args = new ArgumentsHalfNHalfNHalf(); 743 // Create the appropriate sized arrays in args 744 args.inLeftVector = new short[4]; 745 args.inLeftVectorDouble = new double[4]; 746 args.inRightVector = new short[4]; 747 args.inRightVectorDouble = new double[4]; 748 // Fill args with the input values 749 for (int j = 0; j < 4 ; j++) { 750 args.inLeftVector[j] = arrayInLeftVector[i * 4 + j]; 751 args.inLeftVectorDouble[j] = Float16Utils.convertFloat16ToDouble(args.inLeftVector[j]); 752 } 753 for (int j = 0; j < 4 ; j++) { 754 args.inRightVector[j] = arrayInRightVector[i * 4 + j]; 755 args.inRightVectorDouble[j] = Float16Utils.convertFloat16ToDouble(args.inRightVector[j]); 756 } 757 Target target = new Target(Target.FunctionType.NORMAL, Target.ReturnType.HALF, relaxed); 758 CoreMathVerifier.computeDot(args, target); 759 760 // Compare the expected outputs to the actual values returned by RS. 761 boolean valid = true; 762 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 763 valid = false; 764 } 765 if (!valid) { 766 if (!errorFound) { 767 errorFound = true; 768 for (int j = 0; j < 4 ; j++) { 769 message.append("Input inLeftVector: "); 770 appendVariableToMessage(message, arrayInLeftVector[i * 4 + j]); 771 message.append("\n"); 772 } 773 for (int j = 0; j < 4 ; j++) { 774 message.append("Input inRightVector: "); 775 appendVariableToMessage(message, arrayInRightVector[i * 4 + j]); 776 message.append("\n"); 777 } 778 message.append("Expected output out: "); 779 appendVariableToMessage(message, args.out); 780 message.append("\n"); 781 message.append("Actual output out: "); 782 appendVariableToMessage(message, arrayOut[i]); 783 message.append("\n"); 784 message.append("Actual output out (in double): "); 785 appendVariableToMessage(message, Float16Utils.convertFloat16ToDouble(arrayOut[i])); 786 if (!args.out.couldBe(Float16Utils.convertFloat16ToDouble(arrayOut[i]))) { 787 message.append(" FAIL"); 788 } 789 message.append("\n"); 790 message.append("Errors at"); 791 } 792 message.append(" ["); 793 message.append(Integer.toString(i)); 794 message.append("]"); 795 } 796 } 797 assertFalse("Incorrect output for checkDotHalf4Half4Half" + 798 (relaxed ? "_relaxed" : "") + ":\n" + message.toString(), errorFound); 799 } 800 testDot()801 public void testDot() { 802 checkDotFloatFloatFloat(); 803 checkDotFloat2Float2Float(); 804 checkDotFloat3Float3Float(); 805 checkDotFloat4Float4Float(); 806 checkDotHalfHalfHalf(); 807 checkDotHalf2Half2Half(); 808 checkDotHalf3Half3Half(); 809 checkDotHalf4Half4Half(); 810 } 811 } 812