FixedArray experimentation

This commit is contained in:
dcode
2019-03-19 15:43:05 +01:00
parent 74789c9c1e
commit 81039c4167
31 changed files with 762 additions and 855 deletions

View File

@ -52,79 +52,6 @@ function asmFunc(global, env, buffer) {
return $1 + 8 | 0 | 0;
}
function assembly_index_NBodySystem_constructor($0) {
$0 = $0 | 0;
var $1 = 0, $2 = 0, $3 = 0.0, $4 = 0.0, $5 = 0.0, $6 = 0.0, $7 = 0, wasm2js_i32$0 = 0, wasm2js_f64$0 = 0.0, wasm2js_i32$1 = 0;
$7 = HEAP32[($0 + 12 | 0) >> 2] | 0;
repeat_0 : do {
if (($1 | 0) < ($7 | 0)) {
$2 = HEAPU32[((HEAP32[($0 + 4 | 0) >> 2] | 0) + ($1 << 2 | 0) | 0) >> 2] | 0;
$3 = +HEAPF64[($2 + 48 | 0) >> 3];
$4 = $4 + +HEAPF64[($2 + 24 | 0) >> 3] * $3;
$5 = $5 + +HEAPF64[($2 + 32 | 0) >> 3] * $3;
$6 = $6 + +HEAPF64[($2 + 40 | 0) >> 3] * $3;
$1 = $1 + 1 | 0;
continue repeat_0;
}
break repeat_0;
} while (1);
$1 = HEAPU32[(HEAP32[($0 + 4 | 0) >> 2] | 0) >> 2] | 0;
wasm2js_i32$0 = $1;
wasm2js_f64$0 = -$4 / 39.47841760435743;
HEAPF64[(wasm2js_i32$0 + 24 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $1;
wasm2js_f64$0 = -$5 / 39.47841760435743;
HEAPF64[(wasm2js_i32$0 + 32 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $1;
wasm2js_f64$0 = -$6 / 39.47841760435743;
HEAPF64[(wasm2js_i32$0 + 40 | 0) >> 3] = wasm2js_f64$0;
$1 = $lib_runtime_doAllocate(4 | 0) | 0;
wasm2js_i32$0 = $1 - 8 | 0;
wasm2js_i32$1 = 1;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $1;
wasm2js_i32$1 = $0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
return $1 | 0;
}
function assembly_index_Body_constructor($0, $1, $2, $3, $4, $5, $6) {
$0 = +$0;
$1 = +$1;
$2 = +$2;
$3 = +$3;
$4 = +$4;
$5 = +$5;
$6 = +$6;
var $7 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0, wasm2js_f64$0 = 0.0;
$7 = $lib_runtime_doAllocate(56 | 0) | 0;
wasm2js_i32$0 = $7 - 8 | 0;
wasm2js_i32$1 = 2;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $0;
HEAPF64[wasm2js_i32$0 >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $1;
HEAPF64[(wasm2js_i32$0 + 8 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $2;
HEAPF64[(wasm2js_i32$0 + 16 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $3;
HEAPF64[(wasm2js_i32$0 + 24 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $4;
HEAPF64[(wasm2js_i32$0 + 32 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $5;
HEAPF64[(wasm2js_i32$0 + 40 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $6;
HEAPF64[(wasm2js_i32$0 + 48 | 0) >> 3] = wasm2js_f64$0;
return $7 | 0;
}
function $lib_memory_memory_fill($0) {
$0 = $0 | 0;
var $1 = 0, $2 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0, wasm2js_i32$2 = 0, wasm2js_i32$3 = 0;
@ -250,87 +177,112 @@ function asmFunc(global, env, buffer) {
};
}
function $lib_runtime_ArrayBufferView_constructor($0) {
function assembly_index_Body_constructor($0, $1, $2, $3, $4, $5, $6) {
$0 = +$0;
$1 = +$1;
$2 = +$2;
$3 = +$3;
$4 = +$4;
$5 = +$5;
$6 = +$6;
var $7 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0, wasm2js_f64$0 = 0.0;
$7 = $lib_runtime_doAllocate(56 | 0) | 0;
wasm2js_i32$0 = $7 - 8 | 0;
wasm2js_i32$1 = 3;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $0;
HEAPF64[wasm2js_i32$0 >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $1;
HEAPF64[(wasm2js_i32$0 + 8 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $2;
HEAPF64[(wasm2js_i32$0 + 16 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $3;
HEAPF64[(wasm2js_i32$0 + 24 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $4;
HEAPF64[(wasm2js_i32$0 + 32 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $5;
HEAPF64[(wasm2js_i32$0 + 40 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $7;
wasm2js_f64$0 = $6;
HEAPF64[(wasm2js_i32$0 + 48 | 0) >> 3] = wasm2js_f64$0;
return $7 | 0;
}
function assembly_index_NBodySystem_constructor($0) {
$0 = $0 | 0;
var $1 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
$1 = $lib_runtime_doAllocate(20 | 0) | 0;
$lib_memory_memory_fill($1 | 0);
var $1 = 0, $2 = 0, $3 = 0.0, $4 = 0.0, $5 = 0.0, $6 = 0.0, $7 = 0, wasm2js_i32$0 = 0, wasm2js_f64$0 = 0.0, wasm2js_i32$1 = 0;
$7 = (HEAPU32[(($0 - 8 | 0) + 4 | 0) >> 2] | 0) >>> 2 | 0;
repeat_0 : do {
if (($1 | 0) < ($7 | 0)) {
$2 = HEAPU32[(($1 << 2 | 0) + $0 | 0) >> 2] | 0;
$3 = +HEAPF64[($2 + 48 | 0) >> 3];
$4 = $4 + +HEAPF64[($2 + 24 | 0) >> 3] * $3;
$5 = $5 + +HEAPF64[($2 + 32 | 0) >> 3] * $3;
$6 = $6 + +HEAPF64[($2 + 40 | 0) >> 3] * $3;
$1 = $1 + 1 | 0;
continue repeat_0;
}
break repeat_0;
} while (1);
$1 = HEAPU32[$0 >> 2] | 0;
wasm2js_i32$0 = $1;
wasm2js_f64$0 = -$4 / 39.47841760435743;
HEAPF64[(wasm2js_i32$0 + 24 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $1;
wasm2js_f64$0 = -$5 / 39.47841760435743;
HEAPF64[(wasm2js_i32$0 + 32 | 0) >> 3] = wasm2js_f64$0;
wasm2js_i32$0 = $1;
wasm2js_f64$0 = -$6 / 39.47841760435743;
HEAPF64[(wasm2js_i32$0 + 40 | 0) >> 3] = wasm2js_f64$0;
$1 = $lib_runtime_doAllocate(4 | 0) | 0;
wasm2js_i32$0 = $1 - 8 | 0;
wasm2js_i32$1 = 4;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
if (($0 | 0) == (0 | 0)) {
$0 = $lib_runtime_doAllocate(12 | 0) | 0;
wasm2js_i32$0 = $0 - 8 | 0;
wasm2js_i32$1 = 5;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
}
wasm2js_i32$0 = $0;
wasm2js_i32$1 = 0;
wasm2js_i32$0 = $1;
wasm2js_i32$1 = $0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = 0;
HEAP32[(wasm2js_i32$0 + 4 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = 0;
HEAP32[(wasm2js_i32$0 + 8 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = $1;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = $1;
HEAP32[(wasm2js_i32$0 + 4 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = 20;
HEAP32[(wasm2js_i32$0 + 8 | 0) >> 2] = wasm2js_i32$1;
return $0 | 0;
}
function $lib_array_Array_Body__constructor() {
var $0 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
$0 = $lib_runtime_doAllocate(16 | 0) | 0;
wasm2js_i32$0 = $0 - 8 | 0;
wasm2js_i32$1 = 6;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
$0 = $lib_runtime_ArrayBufferView_constructor($0 | 0) | 0;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = 0;
HEAP32[(wasm2js_i32$0 + 12 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = 5;
HEAP32[(wasm2js_i32$0 + 12 | 0) >> 2] = wasm2js_i32$1;
return $0 | 0;
return $1 | 0;
}
function assembly_index_init() {
var $0 = 0, $1 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
$1 = $lib_array_Array_Body__constructor() | 0;
$0 = HEAPU32[($1 + 4 | 0) >> 2] | 0;
var $0 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
$0 = $lib_runtime_doAllocate(20 | 0) | 0;
$lib_memory_memory_fill($0 | 0);
wasm2js_i32$0 = $0 - 8 | 0;
wasm2js_i32$1 = 2;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$1 = assembly_index_Body_constructor(+(0.0), +(0.0), +(0.0), +(0.0), +(0.0), +(0.0), +(39.47841760435743)) | 0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
wasm2js_i32$0 = $0 + 4 | 0;
wasm2js_i32$1 = assembly_index_Body_constructor(+(4.841431442464721), +(-1.1603200440274284), +(-.10362204447112311), +(.606326392995832), +(2.81198684491626), +(-.02521836165988763), +(.03769367487038949)) | 0;
HEAP32[(wasm2js_i32$0 + 4 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0 + 8 | 0;
wasm2js_i32$1 = assembly_index_Body_constructor(+(8.34336671824458), +(4.124798564124305), +(-.4035234171143214), +(-1.0107743461787924), +(1.8256623712304119), +(.008415761376584154), +(.011286326131968767)) | 0;
HEAP32[(wasm2js_i32$0 + 8 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0 + 12 | 0;
wasm2js_i32$1 = assembly_index_Body_constructor(+(12.894369562139131), +(-15.111151401698631), +(-.22330757889265573), +(1.0827910064415354), +(.8687130181696082), +(-.010832637401363636), +(1.7237240570597112e-03)) | 0;
HEAP32[(wasm2js_i32$0 + 12 | 0) >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
wasm2js_i32$0 = $0 + 16 | 0;
wasm2js_i32$1 = assembly_index_Body_constructor(+(15.379697114850917), +(-25.919314609987964), +(.17925877295037118), +(.979090732243898), +(.5946989986476762), +(-.034755955504078104), +(2.0336868699246304e-03)) | 0;
HEAP32[(wasm2js_i32$0 + 16 | 0) >> 2] = wasm2js_i32$1;
assembly_index_system = assembly_index_NBodySystem_constructor($1 | 0) | 0;
HEAP32[wasm2js_i32$0 >> 2] = wasm2js_i32$1;
assembly_index_system = assembly_index_NBodySystem_constructor($0 | 0) | 0;
}
function assembly_index_NBodySystem_advance($0) {
$0 = $0 | 0;
var $1 = 0, $2 = 0.0, $8 = 0.0, $3 = 0, $4 = 0.0, $5 = 0.0, $6 = 0.0, $7 = 0, $9 = 0.0, $10 = 0.0, $11 = 0.0, $12 = 0, $13 = 0, $18 = 0.0, $14 = 0.0, $15 = 0.0, $16 = 0.0, $17 = 0.0, wasm2js_i32$0 = 0, wasm2js_f64$0 = 0.0;
$12 = HEAPU32[$0 >> 2] | 0;
$13 = HEAP32[($12 + 12 | 0) >> 2] | 0;
$13 = (HEAPU32[(($12 - 8 | 0) + 4 | 0) >> 2] | 0) >>> 2 | 0;
repeat_0 : do {
if ($3 >>> 0 < $13 >>> 0) {
$0 = HEAPU32[((HEAP32[($12 + 4 | 0) >> 2] | 0) + ($3 << 2 | 0) | 0) >> 2] | 0;
$0 = HEAPU32[(($3 << 2 | 0) + $12 | 0) >> 2] | 0;
$14 = +HEAPF64[$0 >> 3];
$15 = +HEAPF64[($0 + 8 | 0) >> 3];
$16 = +HEAPF64[($0 + 16 | 0) >> 3];
@ -341,7 +293,7 @@ function asmFunc(global, env, buffer) {
$7 = $3 + 1 | 0;
repeat_1 : do {
if ($7 >>> 0 < $13 >>> 0) {
$1 = HEAPU32[((HEAP32[($12 + 4 | 0) >> 2] | 0) + ($7 << 2 | 0) | 0) >> 2] | 0;
$1 = HEAPU32[(($7 << 2 | 0) + $12 | 0) >> 2] | 0;
$18 = $14 - +HEAPF64[$1 >> 3];
$2 = $18;
$9 = $15 - +HEAPF64[($1 + 8 | 0) >> 3];
@ -395,28 +347,28 @@ function asmFunc(global, env, buffer) {
function assembly_index_NBodySystem_energy($0) {
$0 = $0 | 0;
var $1 = 0.0, $2 = 0, $3 = 0, $4 = 0, $5 = 0, $9 = 0.0, $6 = 0.0, $7 = 0.0, $8 = 0.0, $30 = 0.0, $39 = 0.0, $45 = 0.0, $10 = 0.0, $72 = 0.0, $86 = 0.0;
var $1 = 0.0, $2 = 0, $3 = 0, $4 = 0, $5 = 0, $9 = 0.0, $6 = 0.0, $7 = 0.0, $8 = 0.0, $31 = 0.0, $40 = 0.0, $46 = 0.0, $10 = 0.0, $72 = 0.0, $86 = 0.0;
$4 = HEAPU32[$0 >> 2] | 0;
$5 = HEAP32[($4 + 12 | 0) >> 2] | 0;
$5 = (HEAPU32[(($4 - 8 | 0) + 4 | 0) >> 2] | 0) >>> 2 | 0;
repeat_0 : do {
if ($2 >>> 0 < $5 >>> 0) {
$0 = HEAPU32[((HEAP32[($4 + 4 | 0) >> 2] | 0) + ($2 << 2 | 0) | 0) >> 2] | 0;
$0 = HEAPU32[(($2 << 2 | 0) + $4 | 0) >> 2] | 0;
$6 = +HEAPF64[$0 >> 3];
$7 = +HEAPF64[($0 + 8 | 0) >> 3];
$8 = +HEAPF64[($0 + 16 | 0) >> 3];
$30 = $1;
$31 = $1;
$9 = +HEAPF64[($0 + 48 | 0) >> 3];
$1 = +HEAPF64[($0 + 24 | 0) >> 3];
$39 = $1 * $1;
$40 = $1 * $1;
$1 = +HEAPF64[($0 + 32 | 0) >> 3];
$45 = $39 + $1 * $1;
$46 = $40 + $1 * $1;
$1 = +HEAPF64[($0 + 40 | 0) >> 3];
$1 = $30 + .5 * $9 * ($45 + $1 * $1);
$1 = $31 + .5 * $9 * ($46 + $1 * $1);
$0 = $2 + 1 | 0;
repeat_1 : do {
if ($0 >>> 0 < $5 >>> 0) {
$10 = $1;
$3 = HEAPU32[((HEAP32[($4 + 4 | 0) >> 2] | 0) + ($0 << 2 | 0) | 0) >> 2] | 0;
$3 = HEAPU32[(($0 << 2 | 0) + $4 | 0) >> 2] | 0;
$1 = $6 - +HEAPF64[$3 >> 3];
$72 = $1 * $1;
$1 = $7 - +HEAPF64[($3 + 8 | 0) >> 3];
@ -458,14 +410,14 @@ function asmFunc(global, env, buffer) {
function assembly_index_getBody($0) {
$0 = $0 | 0;
var $1 = 0, $14 = 0;
var $1 = 0, $15 = 0;
$1 = HEAPU32[assembly_index_system >> 2] | 0;
if ($0 >>> 0 < (HEAP32[($1 + 12 | 0) >> 2] | 0) >>> 0) $14 = HEAPU32[((HEAP32[($1 + 4 | 0) >> 2] | 0) + ($0 << 2 | 0) | 0) >> 2] | 0; else $14 = 0;
return $14 | 0;
if ($0 >>> 0 < ((HEAPU32[(($1 - 8 | 0) + 4 | 0) >> 2] | 0) >>> 2 | 0) >>> 0) $15 = HEAPU32[(($0 << 2 | 0) + $1 | 0) >> 2] | 0; else $15 = 0;
return $15 | 0;
}
function start() {
$lib_allocator_arena_startOffset = 96;
$lib_allocator_arena_startOffset = 56;
$lib_allocator_arena_offset = $lib_allocator_arena_startOffset;
}
@ -535,8 +487,7 @@ const assignasmFunc = (
}
}
)(memasmFunc);
assignasmFunc(8, "AwAAAB4AAAB+AGwAaQBiAC8AcgB1AG4AdABpAG0AZQAuAHQAcw==");
assignasmFunc(48, "AwAAACYAAAB+AGwAaQBiAC8AYQByAHIAYQB5AGIAdQBmAGYAZQByAC4AdABz");
assignasmFunc(8, "AQAAACQAAAB+AGwAaQBiAC8AZgBpAHgAZQBkAGEAcgByAGEAeQAuAHQAcw==");
const retasmFunc = asmFunc({Math,Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,NaN,Infinity}, {abort:function() { throw new Error('abort'); }},memasmFunc);
export const memory = retasmFunc.memory;
export const init = retasmFunc.init;