testConversion.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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 i16 = stdlib.SIMD.Int8x16;
  9. var i16check = i16.check;
  10. var i16splat = i16.splat;
  11. var i16fromFloat32x4Bits = i16.fromFloat32x4Bits;
  12. var i16fromInt32x4Bits = i16.fromInt32x4Bits;
  13. var i16fromUint32x4Bits = i16.fromUint32x4Bits;
  14. var i16fromInt16x8Bits = i16.fromInt16x8Bits;
  15. // var i16fromInt8x16Bits = i16.fromInt8x16Bits;
  16. var i16fromUint16x8Bits = i16.fromUint16x8Bits;
  17. var i16fromUint8x16Bits = i16.fromUint8x16Bits;
  18. var i4 = stdlib.SIMD.Int32x4;
  19. var i4check = i4.check;
  20. var f4 = stdlib.SIMD.Float32x4;
  21. var f4check = f4.check;
  22. var i8 = stdlib.SIMD.Int16x8;
  23. // var i16= stdlib.SIMD.Int8x16;
  24. var ui8 = stdlib.SIMD.Uint16x8;
  25. var u16 = stdlib.SIMD.Uint8x16;
  26. var ui4 = stdlib.SIMD.Uint32x4;
  27. var fround = stdlib.Math.fround;
  28. var globImporti168 = i16check(imports.g1); // global var import
  29. var globImportI4 = i4check(imports.g2); // global var import
  30. var g1 = f4(5033.2,3401.0,665.34,32234.1); // global var initialized
  31. var g2 = i4(1065353216, 1073741824,1077936128, 1082130432); // global var initialized
  32. var loopCOUNT = 3;
  33. function conv1()
  34. {
  35. var x = i16(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. x = i16fromFloat32x4Bits(g1);
  39. loopIndex = (loopIndex + 1) | 0;
  40. }
  41. return i16check(x);
  42. }
  43. function conv2()
  44. {
  45. var x = i16(0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0);
  46. var loopIndex = 0;
  47. for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  48. {
  49. x = i16fromInt32x4Bits(globImportI4);
  50. }
  51. return i16check(x);
  52. }
  53. function conv3()
  54. {
  55. var x = i16(0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0);
  56. var y = ui4(1,2,3,4);
  57. var loopIndex = 0;
  58. loopIndex = loopCOUNT | 0;
  59. do {
  60. x = i16fromUint32x4Bits(y);
  61. loopIndex = (loopIndex - 1) | 0;
  62. }
  63. while ( (loopIndex | 0) > 0);
  64. return i16check(x);
  65. }
  66. function conv4()
  67. {
  68. var x = i16(0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0);
  69. var y = ui8(1,2,3,4,5,6,7,8);
  70. var loopIndex = 0;
  71. while ( (loopIndex|0) < (loopCOUNT|0)) {
  72. x = i16fromUint16x8Bits(y);
  73. loopIndex = (loopIndex + 1) | 0;
  74. }
  75. return i16check(x);
  76. }
  77. function conv5()
  78. {
  79. var x = i16(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);
  80. var m = u16(0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA);
  81. var loopIndex = 0;
  82. for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  83. {
  84. x = i16fromUint8x16Bits(m);
  85. }
  86. return i16check(x);
  87. }
  88. function conv6()
  89. {
  90. var x = i16(0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0);
  91. var m = i8(0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA);
  92. var loopIndex = 0;
  93. for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  94. {
  95. x = i16fromInt16x8Bits(m);
  96. }
  97. return i16check(x);
  98. }
  99. // function conv7()
  100. // {
  101. // var x = i16(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);
  102. // var m = i16(0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA);
  103. // var loopIndex = 0;
  104. // for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  105. // {
  106. // x = i16fromInt8x16Bits(m);
  107. // }
  108. // return i16check(x);
  109. // }
  110. return {
  111. func1:conv1,
  112. func2:conv2,
  113. func3:conv3,
  114. func4:conv4,
  115. func5:conv5,
  116. func6:conv6
  117. };
  118. }
  119. var m = asmModule(this, {g1:SIMD.Int8x16(0x55, 0x55, 0x55, 0x55,0x55, 0x55, 0x55, 0x55), g2:SIMD.Int32x4(-1065353216, -1073741824,-1077936128, -1082130432)});
  120. // printSimdBaseline(m.func1(), "SIMD.Int8x16", "m.func1()", "Func1");
  121. // printSimdBaseline(m.func2(), "SIMD.Int8x16", "m.func2()", "Func2");
  122. // printSimdBaseline(m.func3(), "SIMD.Int8x16", "m.func3()", "Func3");
  123. // printSimdBaseline(m.func4(), "SIMD.Int8x16", "m.func4()", "Func4");
  124. // printSimdBaseline(m.func5(), "SIMD.Int8x16", "m.func5()", "Func5");
  125. // printSimdBaseline(m.func6(), "SIMD.Int8x16", "m.func6()", "Func6");
  126. equalSimd([-102, 73, -99, 69, 0, -112, 84, 69, -61, 85, 38, 68, 51, -44, -5, 70], m.func1(), SIMD.Int8x16, "Func1")
  127. equalSimd([0, 0, -128, -64, 0, 0, 0, -64, 0, 0, -64, -65, 0, 0, -128, -65], m.func2(), SIMD.Int8x16, "Func2")
  128. equalSimd([1, 0, 0, 0, 2, 0, 0, 0, 3, 0, 0, 0, 4, 0, 0, 0], m.func3(), SIMD.Int8x16, "Func3")
  129. equalSimd([1, 0, 2, 0, 3, 0, 4, 0, 5, 0, 6, 0, 7, 0, 8, 0], m.func4(), SIMD.Int8x16, "Func4")
  130. equalSimd([-86, -86, -86, -86, -86, -86, -86, -86, -86, -86, -86, -86, -86, -86, -86, -86], m.func5(), SIMD.Int8x16, "Func5")
  131. equalSimd([-86, 0, -86, 0, -86, 0, -86, 0, -86, 0, -86, 0, -86, 0, -86, 0], m.func6(), SIMD.Int8x16, "Func6")
  132. print("PASS");