MathBuiltinsCall.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. //-------------------------------------------------------------------------------------------------------
  2. // Copyright (C) Microsoft. All rights reserved.
  3. // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
  4. //-------------------------------------------------------------------------------------------------------
  5. function foo() {}
  6. var all = [ undefined, null,
  7. true, false, new Boolean(true), new Boolean(false),
  8. NaN, +0, -0, 0, 1, 10.0, 10.1, -1, -5, 5,
  9. 124, 248, 654, 987, -1026, +98768.2546, -88754.15478,
  10. 1<<32, -(1<<32), (1<<32)-1, 1<<31, -(1<<31), 1<<25, -1<<25, 65536, 46341,
  11. Number.MIN_VALUE, Number.NaN, Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY,
  12. new Number(NaN), new Number(+0), new Number( -0), new Number(0), new Number(1),
  13. new Number(10.0), new Number(10.1),
  14. new Number(Number.MIN_VALUE), new Number(Number.NaN),
  15. new Number(Number.POSITIVE_INFINITY), new Number(Number.NEGATIVE_INFINITY),
  16. "", "hello", "hel" + "lo", "+0", "-0", "0", "1", "10.0", "10.1",
  17. new String(""), new String("hello"), new String("he" + "llo"),
  18. new Object(), [1,2,3], new Object(), [1,2,3] , foo
  19. ];
  20. function AsmModule(stdlib,foreign,buffer) {
  21. "use asm";
  22. // numerical mutable variable
  23. var i1 = 0, d1 = 0.0, i2 = -5;
  24. // foreign imports
  25. var fi1 = foreign.i1|0;
  26. var fi2 = foreign.i2|0;
  27. var fd1 = +foreign.d1;
  28. var fd2 = +foreign.d2;
  29. var fun1 = foreign.fun1;
  30. var fun2 = foreign.fun2;
  31. // stdlib immutable variable type double
  32. var sInf = stdlib.Infinity, sNaN = stdlib.NaN;
  33. // stdlib math (double) -> double
  34. var fround = stdlib.Math.fround ;
  35. var acos = stdlib.Math.acos ;
  36. var asin = stdlib.Math.asin ;
  37. var atan = stdlib.Math.atan ;
  38. var cos = stdlib.Math.cos ;
  39. var sin = stdlib.Math.sin ;
  40. var tan = stdlib.Math.tan ;
  41. var ceil = stdlib.Math.ceil ;
  42. var floor = stdlib.Math.floor;
  43. var exp = stdlib.Math.exp ;
  44. var log = stdlib.Math.log ;
  45. var sqrt = stdlib.Math.sqrt ;
  46. // stdlib math (signed) -> signed ^ (doublish) -> double
  47. var abs = stdlib.Math.abs;
  48. // stdlib math (doublish, doublish) -> double
  49. var atan2 = stdlib.Math.atan2;
  50. var pow = stdlib.Math.pow;
  51. // stdlib math (int,int) -> signed
  52. var imul = stdlib.Math.imul;
  53. // stdlib math imm variable double
  54. var E = stdlib.Math.E;
  55. var LN10 = stdlib.Math.LN10;
  56. var LN2 = stdlib.Math.LN2;
  57. var LOG2E = stdlib.Math.LOG2E;
  58. var LOG10E = stdlib.Math.LOG10E;
  59. var PI = stdlib.Math.PI;
  60. var SQRT1_2 = stdlib.Math.SQRT1_2;
  61. var SQRT2 = stdlib.Math.SQRT2;
  62. //views
  63. var a=new stdlib.Int8Array(buffer);
  64. var b=new stdlib.Int16Array(buffer);
  65. var c=new stdlib.Int32Array(buffer);
  66. var d=new stdlib.Uint8Array(buffer);
  67. var e=new stdlib.Uint16Array(buffer);
  68. var f=new stdlib.Uint32Array(buffer);
  69. var g=new stdlib.Float32Array(buffer);
  70. var h=new stdlib.Float64Array(buffer);
  71. function f1(x){
  72. x = +x;
  73. return +acos(x);
  74. }
  75. function f2(x){
  76. x = +x;
  77. return +asin(x);
  78. }
  79. function f3(x){
  80. x = +x;
  81. return +atan(x);
  82. }
  83. function f4(x){
  84. x = +x;
  85. return +cos(x);
  86. }
  87. function f5(x){
  88. x = +x;
  89. return +sin(x);
  90. }
  91. function f6(x){
  92. x = +x;
  93. return +tan(x);
  94. }
  95. function f7(x){
  96. x = +x;
  97. return +ceil(x);
  98. }
  99. function f8(x){
  100. x = +x;
  101. return +floor(x);
  102. }
  103. function f9(x){
  104. x = +x;
  105. return +exp(x);
  106. }
  107. function f10(x){
  108. x = +x;
  109. return +log(x);
  110. }
  111. function f11(x){
  112. x = +x;
  113. return +sqrt(x);
  114. }
  115. // stdlib math (signed) -> signed ^ (doublish) -> double
  116. function f12(x){
  117. x = +x;
  118. return +abs(x);
  119. }
  120. function f13(x){
  121. x = x|0;
  122. return abs(x|0)|0;
  123. }
  124. // stdlib math (doublish, doublish) -> double
  125. function f14(x,y){
  126. x = +x;
  127. y = +y;
  128. return +atan2(x,y);
  129. }
  130. function f15(x,y){
  131. x = +x;
  132. y = +y;
  133. return +pow(x,y);
  134. }
  135. // stdlib math (int,int) -> signed
  136. function f16(x,y){
  137. x = x|0;
  138. y = y|0;
  139. return imul(x,y)|0;
  140. }
  141. function f17(x){
  142. x = fround(x);
  143. return fround(ceil(x));
  144. }
  145. function f18(x){
  146. x = fround(x);
  147. return fround(floor(x));
  148. }
  149. function f19(x){
  150. x = fround(x);
  151. return fround(sqrt(x));
  152. }
  153. function f20(x){
  154. x = fround(x);
  155. return fround(abs(x));
  156. }
  157. return {
  158. f1 : f1 ,
  159. f2 : f2 ,
  160. f3 : f3 ,
  161. f4 : f4 ,
  162. f5 : f5 ,
  163. f6 : f6 ,
  164. f7 : f7 ,
  165. f8 : f8 ,
  166. f9 : f9 ,
  167. f10 : f10 ,
  168. f11 : f11 ,
  169. f12 : f12 ,
  170. f13 : f13 ,
  171. f14 : f14 ,
  172. f15 : f15 ,
  173. f16 : f16 ,
  174. f17 : f17 ,
  175. f18 : f18 ,
  176. f19 : f19 ,
  177. f20 : f20 ,
  178. };
  179. }
  180. var global = {Math:Math,Int8Array:Int8Array,Int16Array:Int16Array,Int32Array:Int32Array,Uint8Array:Uint8Array,Uint16Array:Uint16Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array,Infinity:Infinity, NaN:NaN}
  181. var env = {fun1:function(x){/*print(x);*/}, fun2:function(x,y){/*print(x,y);*/},i1:155,i2:658,d1:68.25,d2:3.14156,f1:48.1523,f2:14896.2514}
  182. var buffer = new ArrayBuffer(1<<20);
  183. var asmModule = AsmModule(global,env,buffer);
  184. for (var i=0; i<all.length; ++i) {
  185. print("f1 (a["+i+"](" + all[i] +"))= " + (asmModule.f1 (all[i])));
  186. print("f2 (a["+i+"](" + all[i] +"))= " + (asmModule.f2 (all[i])));
  187. print("f3 (a["+i+"](" + all[i] +"))= " + (asmModule.f3 (all[i])));
  188. print("f4 (a["+i+"](" + all[i] +"))= " + Math.round(asmModule.f4 (all[i])));
  189. print("f5 (a["+i+"](" + all[i] +"))= " + Math.round(asmModule.f5 (all[i])));
  190. print("f6 (a["+i+"](" + all[i] +"))= " + Math.round(asmModule.f6 (all[i])));
  191. print("f7 (a["+i+"](" + all[i] +"))= " + (asmModule.f7 (all[i])));
  192. print("f8 (a["+i+"](" + all[i] +"))= " + (asmModule.f8 (all[i])));
  193. print("f9 (a["+i+"](" + all[i] +"))= " + (asmModule.f9 (all[i])));
  194. print("f10 (a["+i+"](" + all[i] +"))= " + (asmModule.f10 (all[i])));
  195. print("f11 (a["+i+"](" + all[i] +"))= " + (asmModule.f11 (all[i])));
  196. print("f12 (a["+i+"](" + all[i] +"))= " + (asmModule.f12 (all[i])));
  197. print("f13 (a["+i+"](" + all[i] +"))= " + (asmModule.f13 (all[i])));
  198. print("f17 (a["+i+"](" + all[i] +"))= " + (asmModule.f17 (all[i])));
  199. print("f18 (a["+i+"](" + all[i] +"))= " + (asmModule.f18 (all[i])));
  200. print("f19 (a["+i+"](" + all[i] +"))= " + (asmModule.f19 (all[i])));
  201. print("f20 (a["+i+"](" + all[i] +"))= " + (asmModule.f20 (all[i])));
  202. }
  203. for (var i=0; i<all.length; ++i) {
  204. for (var j=0; j<all.length; ++j) {
  205. // rounding atan2, because crt call gives us slightly different precision
  206. print("f14 (a["+i+"](" + all[i] +") , a["+j+"](" + all[j] +") )= " + Math.round(asmModule.f14 (all[i],all[j])));
  207. print("f15 (a["+i+"](" + all[i] +") , a["+j+"](" + all[j] +") )= " + Math.round(asmModule.f15 (all[i],all[j]))|0);
  208. print("f16 (a["+i+"](" + all[i] +") , a["+j+"](" + all[j] +") )= " + (asmModule.f16 (all[i],all[j])));
  209. }
  210. }