| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- //-------------------------------------------------------------------------------------------------------
- // Copyright (C) Microsoft. All rights reserved.
- // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
- //-------------------------------------------------------------------------------------------------------
- function InitBuffer1(buffer) {
- HEAP32 = new Int32Array(buffer);
- HEAP32[0] = 13654
- HEAP32[1] = 23
- HEAP32[2] = 13654
- HEAP32[3] = 13654
- HEAP32[4] = 423
- HEAP32[5] = 4
- HEAP32[6] = 5
- HEAP32[7] = 3
- HEAP32[8] = 145764
- HEAP32[9] = 53
- }
- function InitBuffer2(buffer) {
- HEAP32 = new Int32Array(buffer);
- for(var i = 0; i < 999999 - 1; i++) {
- HEAP32[i] = i + 1;
- }
- }
- function asmModule(stdlib, imports, buffer) {
- "use asm";
- var log = stdlib.Math.log;
- var i4 = stdlib.SIMD.Int32x4;
- var i4equal = i4.equal;
- var i4splat = i4.splat;
- var i4swizzle = i4.swizzle;
- var HEAP32 = new stdlib.Int32Array(buffer);
- var BLOCK_SIZE = 4;
- var i = 0;
- function linearSearch(value, length) {
- value = value | 0;
- length = length|0;
- var i4Value = i4(0, 0, 0, 0);
- var i4Heap = i4(0, 0, 0, 0);
- var i4Result = i4(0, 0, 0, 0);
- var i4Flipped = i4(0, 0, 0, 0);
- i4Value = i4splat(value | 0);
- for(i = 0; (i | 0) < (length | 0); i = (i + BLOCK_SIZE) | 0) {
- i4Heap = i4((HEAP32[(i << 2) >> 2] | 0), (HEAP32[((i + 1) << 2) >> 2] | 0), (HEAP32[((i + 2) << 2) >> 2] | 0), (HEAP32[((i + 3) << 2) >> 2] | 0));
- i4Result = i4equal(i4Heap, i4Value);
- if(i4Result.signMask != 0) {
- i4Flipped = i4swizzle(i4Result, 3, 2, 1, 0);
- return (i + BLOCK_SIZE - ~~(log(+(i4Flipped.signMask|0)) / log(2.0)) - 1)|0
- }
- }
- return -1;
- }
- return {linearSearch:linearSearch};
- }
- var buffer = new ArrayBuffer(16 * 1024 * 1024);
- var m = asmModule(this, null, buffer);
- InitBuffer1(buffer);
- WScript.Echo("List 1");
- WScript.Echo(m.linearSearch(13654, 10));
- WScript.Echo(m.linearSearch(23, 10));
- WScript.Echo(m.linearSearch(145764, 10));
- WScript.Echo(m.linearSearch(53, 10));
- WScript.Echo(m.linearSearch(-53, 10));
- InitBuffer2(buffer);
- WScript.Echo("List 2");
- WScript.Echo(m.linearSearch(13654, 999999));
- WScript.Echo(m.linearSearch(23, 999999));
- WScript.Echo(m.linearSearch(145764, 999999));
- WScript.Echo(m.linearSearch(-53, 999999));
|