testConversion.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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 i8 = stdlib.SIMD.Int16x8;
  9. var i8check = i8.check;
  10. var i8fromFloat32x4Bits = i8.fromFloat32x4Bits;
  11. var i8fromUint16x8Bits = i8.fromUint16x8Bits;
  12. var i8fromInt32x4Bits = i8.fromInt32x4Bits;
  13. var i8fromUint32x4Bits = i8.fromUint32x4Bits;
  14. //var i8fromInt8x16Bits = i8.fromInt8x16Bits;
  15. var i8fromUint8x16Bits = i8.fromUint8x16Bits;
  16. var i4 = stdlib.SIMD.Int32x4;
  17. var i4check = i4.check;
  18. var f4 = stdlib.SIMD.Float32x4;
  19. var f4check = f4.check;
  20. var ui8 = stdlib.SIMD.Uint16x8;
  21. var ui4 = stdlib.SIMD.Uint32x4;
  22. var ui16 = stdlib.SIMD.Uint8x16;
  23. //var i16 = stdlib.SIMD.Int8x16;
  24. var fround = stdlib.Math.fround;
  25. var globImporti8 = i8check(imports.g1); // global var import
  26. var globImportI4 = i4check(imports.g2); // global var import
  27. var g1 = f4(5033.2,3401.0,665.34,32234.1); // global var initialized
  28. var g2 = i4(1065353216, 1073741824,1077936128, 1082130432); // global var initialized
  29. var loopCOUNT = 3;
  30. function conv1()
  31. {
  32. var x = i8(0,0,0,0,0,0,0,0);
  33. var loopIndex = 0;
  34. while ( (loopIndex|0) < (loopCOUNT|0)) {
  35. x = i8fromFloat32x4Bits(g1);
  36. loopIndex = (loopIndex + 1) | 0;
  37. }
  38. return i8check(x);
  39. }
  40. function conv2()
  41. {
  42. var x = i8(0,0,0,0,0,0,0,0);
  43. var loopIndex = 0;
  44. for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  45. {
  46. x = i8fromInt32x4Bits(globImportI4);
  47. }
  48. return i8check(x);
  49. }
  50. function conv3()
  51. {
  52. var x = i8(0,0,0,0,0,0,0,0);
  53. var y = ui4(1,2,3,4);
  54. var loopIndex = 0;
  55. loopIndex = loopCOUNT | 0;
  56. do {
  57. x = i8fromUint32x4Bits(y);
  58. loopIndex = (loopIndex - 1) | 0;
  59. }
  60. while ( (loopIndex | 0) > 0);
  61. return i8check(x);
  62. }
  63. function conv4()
  64. {
  65. var x = i8(0,0,0,0,0,0,0,0);
  66. var y = ui8(1,2,3,4,5,6,7,8);
  67. var loopIndex = 0;
  68. while ( (loopIndex|0) < (loopCOUNT|0)) {
  69. x = i8fromUint16x8Bits(y);
  70. loopIndex = (loopIndex + 1) | 0;
  71. }
  72. return i8check(x);
  73. }
  74. /*
  75. function conv5()
  76. {
  77. var x = i8(0,0,0,0,0,0,0,0);
  78. var m = i16(0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA);
  79. var loopIndex = 0;
  80. for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  81. {
  82. x = i8fromInt8x16Bits(m);
  83. }
  84. return i8check(x);
  85. }
  86. */
  87. function conv6()
  88. {
  89. var x = i8(0,0,0,0,0,0,0,0);
  90. var m = ui16(0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55);
  91. var loopIndex = 0;
  92. for (loopIndex = 0; (loopIndex | 0) < (loopCOUNT | 0) ; loopIndex = (loopIndex + 1) | 0)
  93. {
  94. x = i8fromUint8x16Bits(m);
  95. }
  96. return i8check(x);
  97. }
  98. // TODO: Test conversion of returned value
  99. function value()
  100. {
  101. var ret = 1.0;
  102. var i = 1.0;
  103. var loopIndex = 0;
  104. while ( (loopIndex|0) < (loopCOUNT|0)) {
  105. ret = ret + i;
  106. loopIndex = (loopIndex + 1) | 0;
  107. }
  108. return +ret;
  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.Int16x8(0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55, 0x55), g2:SIMD.Int32x4(-1065353216, -1073741824,-1077936128, -1082130432)});
  120. /*printSimdBaseline(m.func1(), "SIMD.Int16x8", "m.func1())", "Func1");
  121. printSimdBaseline(m.func2(), "SIMD.Int16x8", "m.func2()", "Func2");
  122. printSimdBaseline(m.func3(), "SIMD.Int16x8", "m.func3()", "Func3");
  123. printSimdBaseline(m.func4(), "SIMD.Int16x8", "m.func4()", "Func4");
  124. printSimdBaseline(m.func5(), "SIMD.Int16x8", "m.func5()", "Func5");
  125. printSimdBaseline(m.func6(), "SIMD.Int16x8", "m.func6()", "Func6");*/
  126. equalSimd([18842, 17821, -28672, 17748, 21955, 17446, -11213, 18171], m.func1(), SIMD.Int16x8, "Func1")
  127. equalSimd([0, -16256, 0, -16384, 0, -16448, 0, -16512], m.func2(), SIMD.Int16x8, "Func2")
  128. equalSimd([1, 0, 2, 0, 3, 0, 4, 0], m.func3(), SIMD.Int16x8, "Func3")
  129. equalSimd([1, 2, 3, 4, 5, 6, 7, 8], m.func4(), SIMD.Int16x8, "Func4")
  130. //equalSimd([-21846, -21846, -21846, -21846, -21846, -21846, -21846, -21846], m.func5(), SIMD.Int16x8, "Func5")
  131. equalSimd([21845, 21845, 21845, 21845, 21845, 21845, 21845, 21845], m.func6(), SIMD.Int16x8, "Func6")
  132. print("PASS");