testAddSubSaturate.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. //-------------------------------------------------------------------------------------------------------
  2. // Copyright (C) Microsoft Corporation and contributors. All rights reserved.
  3. // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
  4. //-------------------------------------------------------------------------------------------------------
  5. this.WScript.LoadScriptFile("..\\UnitTestFramework\\SimdJsHelpers.js");
  6. function asmModule(stdlib, imports) {
  7. "use asm";
  8. var ui16 = stdlib.SIMD.Uint8x16;
  9. var ui16check = ui16.check;
  10. var ui16addSaturate = ui16.addSaturate;
  11. var ui16subSaturate = ui16.subSaturate;
  12. var globImportui16 = ui16check(imports.g1);
  13. var ui16g1 = ui16(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16);
  14. var ui16g2 = ui16(256, 255, 128, 127, 0, 0, 1000, 1000, 5, 15, 3, 399, 299, 21, 45, 22);
  15. var loopCOUNT = 3;
  16. var i16 = stdlib.SIMD.Int8x16;
  17. var i16check = i16.check;
  18. var i16fu16 = i16.fromUint8x16Bits;
  19. function testAddSaturateLocal()
  20. {
  21. var a = ui16(80, 70, 60, 50, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16);
  22. var b = ui16(200, 200, 200, 200, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 255);
  23. var result = ui16(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
  24. var loopIndex = 0;
  25. while ( (loopIndex|0) < (loopCOUNT|0)) {
  26. result = ui16addSaturate(a, b);
  27. loopIndex = (loopIndex + 1) | 0;
  28. }
  29. return i16check(i16fu16(result));
  30. }
  31. function testSubSaturateLocal()
  32. {
  33. var a = ui16(80, 70, 60, 50, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16);
  34. var b = ui16(200, 200, 200, 200, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 255);
  35. var result = ui16(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
  36. var loopIndex = 0;
  37. while ( (loopIndex|0) < (loopCOUNT|0)) {
  38. result = ui16subSaturate(a, b);
  39. loopIndex = (loopIndex + 1) | 0;
  40. }
  41. return i16check(i16fu16(result));
  42. }
  43. function testAddSaturateGlobal()
  44. {
  45. var result = ui16(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
  46. var loopIndex = 0;
  47. while ( (loopIndex|0) < (loopCOUNT|0)) {
  48. result = ui16addSaturate(ui16g1, ui16g2);
  49. loopIndex = (loopIndex + 1) | 0;
  50. }
  51. return i16check(i16fu16(result));
  52. }
  53. function testSubSaturateGlobal()
  54. {
  55. var result = ui16(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
  56. var loopIndex = 0;
  57. while ( (loopIndex|0) < (loopCOUNT|0)) {
  58. result = ui16subSaturate(ui16g1, ui16g2);
  59. loopIndex = (loopIndex + 1) | 0;
  60. }
  61. return i16check(i16fu16(result));
  62. }
  63. function testAddSaturateGlobalImport()
  64. {
  65. var a = ui16(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16);
  66. var result = ui16(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
  67. var loopIndex = 0;
  68. while ( (loopIndex|0) < (loopCOUNT|0)) {
  69. result = ui16addSaturate(globImportui16, a);
  70. loopIndex = (loopIndex + 1) | 0;
  71. }
  72. return i16check(i16fu16(result));
  73. }
  74. function testSubSaturateGlobalImport()
  75. {
  76. var a = ui16(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16);
  77. var result = ui16(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
  78. var loopIndex = 0;
  79. while ( (loopIndex|0) < (loopCOUNT|0)) {
  80. result = ui16subSaturate(globImportui16, a);
  81. loopIndex = (loopIndex + 1) | 0;
  82. }
  83. return i16check(i16fu16(result));
  84. }
  85. return { testAddSaturateLocal: testAddSaturateLocal, testSubSaturateLocal: testSubSaturateLocal, testAddSaturateGlobal: testAddSaturateGlobal, testSubSaturateGlobal: testSubSaturateGlobal, testAddSaturateGlobalImport: testAddSaturateGlobalImport, testSubSaturateGlobalImport: testSubSaturateGlobalImport };
  86. }
  87. var m = asmModule(this, {g1:SIMD.Uint8x16(100, 255, 255, 255, 0, 38, 255, 1442, 52, 127, 254, 256, 129, 0, 88, 100234)});
  88. var ret1 = SIMD.Uint8x16.fromInt8x16Bits(m.testAddSaturateLocal());
  89. var ret2 = SIMD.Uint8x16.fromInt8x16Bits(m.testSubSaturateLocal());
  90. var ret3 = SIMD.Uint8x16.fromInt8x16Bits(m.testAddSaturateGlobal());
  91. var ret4 = SIMD.Uint8x16.fromInt8x16Bits(m.testSubSaturateGlobal());
  92. var ret5 = SIMD.Uint8x16.fromInt8x16Bits(m.testAddSaturateGlobalImport());
  93. var ret6 = SIMD.Uint8x16.fromInt8x16Bits(m.testSubSaturateGlobalImport());
  94. equalSimd([255, 255, 255, 250, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 255], ret1, SIMD.Uint8x16, "Func1");
  95. equalSimd([0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 5, 7, 9, 11, 13, 0], ret2, SIMD.Uint8x16, "Func2");
  96. equalSimd([1, 255, 131, 131, 5, 6, 239, 240, 14, 25, 14, 155, 56, 35, 60, 38], ret3, SIMD.Uint8x16, "Func3");
  97. equalSimd([1, 0, 0, 0, 5, 6, 0, 0, 4, 0, 8, 0, 0, 0, 0, 0], ret4, SIMD.Uint8x16, "Func4");
  98. equalSimd([101, 255, 255, 255, 5, 44, 255, 170, 61, 137, 255, 12, 142, 14, 103, 154], ret5, SIMD.Uint8x16, "Func5");
  99. equalSimd([99, 253, 252, 251, 0, 32, 248, 154, 43, 117, 243, 0, 116, 0, 73, 122], ret6, SIMD.Uint8x16, "Func6");
  100. print("PASS");