From 813d2e33c8c8ef46f9acfa60f228a258b9abcbc7 Mon Sep 17 00:00:00 2001 From: Max Graey Date: Sat, 21 Jul 2018 15:11:39 +0300 Subject: [PATCH] Update n-body sources and binary for rust. Add bench results (#172) --- README.md | 5 + examples/n-body/README.md | 20 + examples/n-body/assembly/index.js | 1 + examples/n-body/assembly/index.ts | 49 +- examples/n-body/build/index.asm.js | 14 - examples/n-body/build/index.js | 15 +- examples/n-body/build/optimized.wasm | Bin 2280 -> 2220 bytes examples/n-body/build/optimized.wat | 56 +- examples/n-body/build/rust.optimized.wasm | Bin 1147 -> 15188 bytes examples/n-body/build/untouched.wat | 1243 ++++++++++----------- examples/n-body/package.json | 4 +- examples/n-body/rust/Cargo.toml | 2 +- examples/n-body/rust/index.js | 1 + examples/n-body/rust/src/lib.rs | 20 +- examples/n-body/tests/index.js | 53 +- 15 files changed, 704 insertions(+), 779 deletions(-) diff --git a/README.md b/README.md index 68b681d9..1c9e22cd 100644 --- a/README.md +++ b/README.md @@ -70,6 +70,11 @@ Examples * **[WASM parser](./lib/parse)**
A WebAssembly binary parser in WebAssembly. +Benchmarks +--------- +* **[n-body](./examples/n-body)**
+ Compare performance and produced binary size with n-body example from Computer Language Benchmarks Game. + Building -------- diff --git a/examples/n-body/README.md b/examples/n-body/README.md index 26110320..7bf3a18c 100644 --- a/examples/n-body/README.md +++ b/examples/n-body/README.md @@ -25,3 +25,23 @@ To run the benchmark: ``` $> npm run test [steps=1000000] ``` + +Benchmark +========= + +***Environment:*** +- MacBook Pro (Retina, 15-inch, Late 2013) +- macOS 10.13.5 +- node.js v10.6.0 +- rustc 1.29.0-nightly (254f8796b 2018-07-13) + +***Results:*** + +| Target | Time, ***ms*** | Size, ***KB*** | +|-------------------------|-----------------|----------------| +| **AssemblyScript WASM** | **3167** | **2** | +| AssemblyScript ASMJS | 3633 | 21* | +| JavaScript | 2628 | 5* | +| Rust WASM | 3876 | 15 | + +___* unminified___ diff --git a/examples/n-body/assembly/index.js b/examples/n-body/assembly/index.js index b25d0e4a..11c076b2 100644 --- a/examples/n-body/assembly/index.js +++ b/examples/n-body/assembly/index.js @@ -7,6 +7,7 @@ const compiled = new WebAssembly.Module( const imports = { env: { + memory: new WebAssembly.Memory({ initial: 10 }), abort: (filename, line, column) => { throw Error("abort called at " + line + ":" + colum); } diff --git a/examples/n-body/assembly/index.ts b/examples/n-body/assembly/index.ts index e3d5a7a3..8a10f304 100644 --- a/examples/n-body/assembly/index.ts +++ b/examples/n-body/assembly/index.ts @@ -36,62 +36,60 @@ function Sun(): Body { function Jupiter(): Body { return new Body( - 4.84143144246472090e+00, + 4.84143144246472090e+00, -1.16032004402742839e+00, -1.03622044471123109e-01, - 1.66007664274403694e-03 * DAYS_PER_YEAR, - 7.69901118419740425e-03 * DAYS_PER_YEAR, + 1.66007664274403694e-03 * DAYS_PER_YEAR, + 7.69901118419740425e-03 * DAYS_PER_YEAR, -6.90460016972063023e-05 * DAYS_PER_YEAR, - 9.54791938424326609e-04 * SOLAR_MASS + 9.54791938424326609e-04 * SOLAR_MASS ); } function Saturn(): Body { return new Body( - 8.34336671824457987e+00, - 4.12479856412430479e+00, + 8.34336671824457987e+00, + 4.12479856412430479e+00, -4.03523417114321381e-01, -2.76742510726862411e-03 * DAYS_PER_YEAR, - 4.99852801234917238e-03 * DAYS_PER_YEAR, - 2.30417297573763929e-05 * DAYS_PER_YEAR, - 2.85885980666130812e-04 * SOLAR_MASS + 4.99852801234917238e-03 * DAYS_PER_YEAR, + 2.30417297573763929e-05 * DAYS_PER_YEAR, + 2.85885980666130812e-04 * SOLAR_MASS ); } function Uranus(): Body { return new Body( - 1.28943695621391310e+01, + 1.28943695621391310e+01, -1.51111514016986312e+01, -2.23307578892655734e-01, - 2.96460137564761618e-03 * DAYS_PER_YEAR, - 2.37847173959480950e-03 * DAYS_PER_YEAR, + 2.96460137564761618e-03 * DAYS_PER_YEAR, + 2.37847173959480950e-03 * DAYS_PER_YEAR, -2.96589568540237556e-05 * DAYS_PER_YEAR, - 4.36624404335156298e-05 * SOLAR_MASS + 4.36624404335156298e-05 * SOLAR_MASS ); } function Neptune(): Body { return new Body( - 1.53796971148509165e+01, + 1.53796971148509165e+01, -2.59193146099879641e+01, - 1.79258772950371181e-01, - 2.68067772490389322e-03 * DAYS_PER_YEAR, - 1.62824170038242295e-03 * DAYS_PER_YEAR, + 1.79258772950371181e-01, + 2.68067772490389322e-03 * DAYS_PER_YEAR, + 1.62824170038242295e-03 * DAYS_PER_YEAR, -9.51592254519715870e-05 * DAYS_PER_YEAR, - 5.15138902046611451e-05 * SOLAR_MASS + 5.15138902046611451e-05 * SOLAR_MASS ); } class NBodySystem { - constructor( - public bodies: Body[] - ) { + constructor(public bodies: Body[]) { var px: float = 0.0; var py: float = 0.0; var pz: float = 0.0; var size = bodies.length; - for (let i = 0; i < size; i++) { + for (let i = 0; i < size; ++i) { let b = unchecked(bodies[i]); let m = b.mass; px += b.vx * m; @@ -197,16 +195,11 @@ export function init(): void { ]); } -export function getBody(index: i32): Body | null { - var bodies = system.bodies; - return index < bodies.length ? bodies[index] : null; -} - export function step(): float { system.advance(0.01); return system.energy(); } export function bench(steps: u32): void { - for (let i: u32 = 0; i < steps; i++) system.advance(0.01); + for (let i: u32 = 0; i < steps; ++i) system.advance(0.01); } diff --git a/examples/n-body/build/index.asm.js b/examples/n-body/build/index.asm.js index 3797ab4d..1b93834c 100644 --- a/examples/n-body/build/index.asm.js +++ b/examples/n-body/build/index.asm.js @@ -341,19 +341,6 @@ function asmFunc(global, env, buffer) { assembly_index_system = assembly_index_NBodySystem_constructor(0 | 0, $1 | 0) | 0; } - function assembly_index_getBody($0) { - $0 = $0 | 0; - var $1 = 0, $22 = 0, $20 = 0; - $1 = HEAPU32[assembly_index_system >> 2] | 0; - if ($0 >>> 0 < (HEAP32[($1 + 4 | 0) >> 2] | 0) >>> 0) { - $1 = HEAPU32[$1 >> 2] | 0; - if ($0 >>> 0 < ((HEAP32[$1 >> 2] | 0) >>> 2 | 0) >>> 0) $20 = HEAPU32[(($1 + ($0 << 2 | 0) | 0) + 8 | 0) >> 2] | 0; else abort(); - $22 = $20; - } else $22 = 0; - $0 = $22; - return $0 | 0; - } - function assembly_index_NBodySystem_advance($0, $1) { $0 = $0 | 0; $1 = +$1; @@ -533,7 +520,6 @@ function asmFunc(global, env, buffer) { } }), init: assembly_index_init, - getBody: assembly_index_getBody, step: assembly_index_step, bench: assembly_index_bench }; diff --git a/examples/n-body/build/index.js b/examples/n-body/build/index.js index dbf083c7..bd91ac1f 100644 --- a/examples/n-body/build/index.js +++ b/examples/n-body/build/index.js @@ -1,9 +1,7 @@ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); require("allocator/arena"); -// From The Computer Language Benchmarks Game -// http://benchmarksgame.alioth.debian.org -const SOLAR_MASS = 4.0 * Math.PI * Math.PI; +const SOLAR_MASS = (4.0 * Math.PI * Math.PI); const DAYS_PER_YEAR = 365.24; class Body { constructor(x, y, z, vx, vy, vz, mass) { @@ -44,7 +42,7 @@ class NBodySystem { var py = 0.0; var pz = 0.0; var size = bodies.length; - for (let i = 0; i < size; i++) { + for (let i = 0; i < size; ++i) { let b = unchecked(bodies[i]); let m = b.mass; px += b.vx * m; @@ -107,7 +105,7 @@ class NBodySystem { let bim = bodyi.mass; e += 0.5 * bim * (vx * vx + vy * vy + vz * vz); for (let j = i + 1; j < size; ++j) { - let bodyj = bodies[j]; + let bodyj = unchecked(bodies[j]); let dx = ix - bodyj.x; let dy = iy - bodyj.y; let dz = iz - bodyj.z; @@ -129,18 +127,13 @@ function init() { ]); } exports.init = init; -function getBody(index) { - var bodies = system.bodies; - return index < bodies.length ? bodies[index] : null; -} -exports.getBody = getBody; function step() { system.advance(0.01); return system.energy(); } exports.step = step; function bench(steps) { - for (let i = 0; i < steps; i++) + for (let i = 0; i < steps; ++i) system.advance(0.01); } exports.bench = bench; diff --git a/examples/n-body/build/optimized.wasm b/examples/n-body/build/optimized.wasm index f71046780cb82a9925ef42ab9dbef571e33a7a3a..ac96f82a25e5e7f603d8c5bb80f559c35e3d71ad 100644 GIT binary patch delta 133 zcmaDMxJGb-YpOI8b8220YhqGOf-6lamr7rWMF40E=et5;9^Zm%}dT;;O1cD;hG`9 zvvHLbtED9)W4!`{GLr@qgA$_#6N@JckgEV>fw>HhOl2SuMg<_NBuj&dgO!1s6=<;% v!{*1VSxibC%1i>B+!{bbm>ifLK}G0 diff --git a/examples/n-body/build/optimized.wat b/examples/n-body/build/optimized.wat index 40bcbe76..48dcdcc9 100644 --- a/examples/n-body/build/optimized.wat +++ b/examples/n-body/build/optimized.wat @@ -10,14 +10,13 @@ (type $iF (func (param i32) (result f64))) (type $iv (func (param i32))) (import "env" "abort" (func $~lib/env/abort (param i32 i32 i32 i32))) + (import "env" "memory" (memory $0 1)) (global $~lib/allocator/arena/startOffset (mut i32) (i32.const 0)) (global $~lib/allocator/arena/offset (mut i32) (i32.const 0)) (global $assembly/index/system (mut i32) (i32.const 0)) - (memory $0 1) (data (i32.const 8) "\0d\00\00\00~\00l\00i\00b\00/\00a\00r\00r\00a\00y\00.\00t\00s") (export "memory" (memory $0)) (export "init" (func $assembly/index/init)) - (export "getBody" (func $assembly/index/getBody)) (export "step" (func $assembly/index/step)) (export "bench" (func $assembly/index/bench)) (start $start) @@ -823,50 +822,7 @@ ) ) ) - (func $assembly/index/getBody (; 7 ;) (type $ii) (param $0 i32) (result i32) - (local $1 i32) - (tee_local $0 - (if (result i32) - (i32.lt_u - (get_local $0) - (i32.load offset=4 - (tee_local $1 - (i32.load - (get_global $assembly/index/system) - ) - ) - ) - ) - (if (result i32) - (i32.lt_u - (get_local $0) - (i32.shr_u - (i32.load - (tee_local $1 - (i32.load - (get_local $1) - ) - ) - ) - (i32.const 2) - ) - ) - (i32.load offset=8 - (i32.add - (get_local $1) - (i32.shl - (get_local $0) - (i32.const 2) - ) - ) - ) - (unreachable) - ) - (i32.const 0) - ) - ) - ) - (func $assembly/index/NBodySystem#advance (; 8 ;) (type $iFv) (param $0 i32) (param $1 f64) + (func $assembly/index/NBodySystem#advance (; 7 ;) (type $iFv) (param $0 i32) (param $1 f64) (local $2 i32) (local $3 f64) (local $4 i32) @@ -1170,7 +1126,7 @@ ) ) ) - (func $assembly/index/NBodySystem#energy (; 9 ;) (type $iF) (param $0 i32) (result f64) + (func $assembly/index/NBodySystem#energy (; 8 ;) (type $iF) (param $0 i32) (result f64) (local $1 f64) (local $2 i32) (local $3 i32) @@ -1367,7 +1323,7 @@ ) (get_local $1) ) - (func $assembly/index/step (; 10 ;) (type $F) (result f64) + (func $assembly/index/step (; 9 ;) (type $F) (result f64) (call $assembly/index/NBodySystem#advance (get_global $assembly/index/system) (f64.const 0.01) @@ -1376,7 +1332,7 @@ (get_global $assembly/index/system) ) ) - (func $assembly/index/bench (; 11 ;) (type $iv) (param $0 i32) + (func $assembly/index/bench (; 10 ;) (type $iv) (param $0 i32) (local $1 i32) (block $break|0 (loop $repeat|0 @@ -1400,7 +1356,7 @@ ) ) ) - (func $start (; 12 ;) (type $v) + (func $start (; 11 ;) (type $v) (set_global $~lib/allocator/arena/startOffset (i32.const 40) ) diff --git a/examples/n-body/build/rust.optimized.wasm b/examples/n-body/build/rust.optimized.wasm index 2e06fd9e65cb0f9877456412272dea5bdbe883e9..8e3fadeecfbb6492873d4114d7c185e3543ca5a8 100644 GIT binary patch literal 15188 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 eSmkR_L*=fOMV2sXn$r?wUS&dbCh?*9OaN&}Su delta 488 zcmY*Vze~eF6u!H6Nv=%`9R-(nnS?GKTM+D_t^bEoG^vfEMGz|S4{)$_2`;AT;wZX^ zpg8K_BCh@z9UR~KlJ;A@|}KXi!f`Y z6RxfkC|=n73YZ&N17%674umAoM5>}d3M8r?$igsg(8BQXnU|PLM(4C26(m6+DT*?2 z-9yS~#0TnqKPv@Ybyp0kKs>JDZ3fds0x~qh#get:length (get_local $1) ) ) - ;;@ assembly/index.ts:94:4 + ;;@ assembly/index.ts:92:4 (block $break|0 - ;;@ assembly/index.ts:94:9 + ;;@ assembly/index.ts:92:9 (set_local $6 - ;;@ assembly/index.ts:94:17 + ;;@ assembly/index.ts:92:17 (i32.const 0) ) (loop $repeat|0 (br_if $break|0 (i32.eqz - ;;@ assembly/index.ts:94:20 + ;;@ assembly/index.ts:92:20 (i32.lt_s (get_local $6) - ;;@ assembly/index.ts:94:24 + ;;@ assembly/index.ts:92:24 (get_local $5) ) ) ) - ;;@ assembly/index.ts:94:35 + ;;@ assembly/index.ts:92:35 (block - ;;@ assembly/index.ts:95:6 + ;;@ assembly/index.ts:93:6 (set_local $7 - ;;@ assembly/index.ts:95:14 + ;;@ assembly/index.ts:93:14 (call $~lib/array/Array#__unchecked_get - ;;@ assembly/index.ts:95:24 + ;;@ assembly/index.ts:93:24 (get_local $1) - ;;@ assembly/index.ts:95:31 + ;;@ assembly/index.ts:93:31 (get_local $6) ) ) - ;;@ assembly/index.ts:96:6 + ;;@ assembly/index.ts:94:6 (set_local $8 - ;;@ assembly/index.ts:96:14 + ;;@ assembly/index.ts:94:14 (f64.load offset=48 (get_local $7) ) ) - ;;@ assembly/index.ts:97:6 + ;;@ assembly/index.ts:95:6 (set_local $2 (f64.add (get_local $2) - ;;@ assembly/index.ts:97:12 + ;;@ assembly/index.ts:95:12 (f64.mul (f64.load offset=24 (get_local $7) ) + ;;@ assembly/index.ts:95:19 + (get_local $8) + ) + ) + ) + ;;@ assembly/index.ts:96:6 + (set_local $3 + (f64.add + (get_local $3) + ;;@ assembly/index.ts:96:12 + (f64.mul + (f64.load offset=32 + (get_local $7) + ) + ;;@ assembly/index.ts:96:19 + (get_local $8) + ) + ) + ) + ;;@ assembly/index.ts:97:6 + (set_local $4 + (f64.add + (get_local $4) + ;;@ assembly/index.ts:97:12 + (f64.mul + (f64.load offset=40 + (get_local $7) + ) ;;@ assembly/index.ts:97:19 (get_local $8) ) ) ) - ;;@ assembly/index.ts:98:6 - (set_local $3 - (f64.add - (get_local $3) - ;;@ assembly/index.ts:98:12 - (f64.mul - (f64.load offset=32 - (get_local $7) - ) - ;;@ assembly/index.ts:98:19 - (get_local $8) - ) - ) - ) - ;;@ assembly/index.ts:99:6 - (set_local $4 - (f64.add - (get_local $4) - ;;@ assembly/index.ts:99:12 - (f64.mul - (f64.load offset=40 - (get_local $7) - ) - ;;@ assembly/index.ts:99:19 - (get_local $8) - ) - ) - ) ) - ;;@ assembly/index.ts:94:30 + ;;@ assembly/index.ts:92:30 (set_local $6 (i32.add + ;;@ assembly/index.ts:92:32 (get_local $6) (i32.const 1) ) @@ -1375,20 +1375,20 @@ (br $repeat|0) ) ) - ;;@ assembly/index.ts:101:14 + ;;@ assembly/index.ts:99:14 (drop (call $assembly/index/Body#offsetMomentum - ;;@ assembly/index.ts:101:4 + ;;@ assembly/index.ts:99:4 (call $~lib/array/Array#__get (get_local $1) - ;;@ assembly/index.ts:101:11 + ;;@ assembly/index.ts:99:11 (i32.const 0) ) - ;;@ assembly/index.ts:101:29 + ;;@ assembly/index.ts:99:29 (get_local $2) - ;;@ assembly/index.ts:101:33 + ;;@ assembly/index.ts:99:33 (get_local $3) - ;;@ assembly/index.ts:101:37 + ;;@ assembly/index.ts:99:37 (get_local $4) ) ) @@ -1415,12 +1415,12 @@ ) (func $assembly/index/init (; 20 ;) (type $v) (local $0 i32) - ;;@ assembly/index.ts:191:2 + ;;@ assembly/index.ts:189:2 (set_global $assembly/index/system - ;;@ assembly/index.ts:191:11 + ;;@ assembly/index.ts:189:11 (call $assembly/index/NBodySystem#constructor (i32.const 0) - ;;@ assembly/index.ts:191:27 + ;;@ assembly/index.ts:189:27 (block (result i32) (set_local $0 (call $~lib/array/Array#constructor @@ -1431,31 +1431,31 @@ (call $~lib/array/Array#__unchecked_set (get_local $0) (i32.const 0) - ;;@ assembly/index.ts:192:4 + ;;@ assembly/index.ts:190:4 (call $assembly/index/Sun) ) (call $~lib/array/Array#__unchecked_set (get_local $0) (i32.const 1) - ;;@ assembly/index.ts:193:4 + ;;@ assembly/index.ts:191:4 (call $assembly/index/Jupiter) ) (call $~lib/array/Array#__unchecked_set (get_local $0) (i32.const 2) - ;;@ assembly/index.ts:194:4 + ;;@ assembly/index.ts:192:4 (call $assembly/index/Saturn) ) (call $~lib/array/Array#__unchecked_set (get_local $0) (i32.const 3) - ;;@ assembly/index.ts:195:4 + ;;@ assembly/index.ts:193:4 (call $assembly/index/Uranus) ) (call $~lib/array/Array#__unchecked_set (get_local $0) (i32.const 4) - ;;@ assembly/index.ts:196:4 + ;;@ assembly/index.ts:194:4 (call $assembly/index/Neptune) ) (get_local $0) @@ -1463,37 +1463,7 @@ ) ) ) - (func $assembly/index/getBody (; 21 ;) (type $ii) (param $0 i32) (result i32) - (local $1 i32) - ;;@ assembly/index.ts:201:2 - (set_local $1 - ;;@ assembly/index.ts:201:15 - (i32.load - (get_global $assembly/index/system) - ) - ) - ;;@ assembly/index.ts:202:59 - (if (result i32) - ;;@ assembly/index.ts:202:9 - (i32.lt_u - (get_local $0) - ;;@ assembly/index.ts:202:22 - (call $~lib/array/Array#get:length - ;;@ assembly/index.ts:202:27 - (get_local $1) - ) - ) - ;;@ assembly/index.ts:202:43 - (call $~lib/array/Array#__get - (get_local $1) - ;;@ assembly/index.ts:202:50 - (get_local $0) - ) - ;;@ assembly/index.ts:202:59 - (i32.const 0) - ) - ) - (func $assembly/index/NBodySystem#advance (; 22 ;) (type $iFv) (param $0 i32) (param $1 f64) + (func $assembly/index/NBodySystem#advance (; 21 ;) (type $iFv) (param $0 i32) (param $1 f64) (local $2 i32) (local $3 i32) (local $4 i32) @@ -1515,194 +1485,194 @@ (local $20 f64) (local $21 f64) (local $22 f64) - ;;@ assembly/index.ts:105:4 + ;;@ assembly/index.ts:103:4 (set_local $2 - ;;@ assembly/index.ts:105:17 + ;;@ assembly/index.ts:103:17 (i32.load (get_local $0) ) ) - ;;@ assembly/index.ts:106:4 + ;;@ assembly/index.ts:104:4 (set_local $3 - ;;@ assembly/index.ts:106:20 + ;;@ assembly/index.ts:104:20 (call $~lib/array/Array#get:length (get_local $2) ) ) - ;;@ assembly/index.ts:109:4 + ;;@ assembly/index.ts:107:4 (block $break|0 - ;;@ assembly/index.ts:109:9 + ;;@ assembly/index.ts:107:9 (set_local $4 - ;;@ assembly/index.ts:109:22 + ;;@ assembly/index.ts:107:22 (i32.const 0) ) (loop $repeat|0 (br_if $break|0 (i32.eqz - ;;@ assembly/index.ts:109:25 + ;;@ assembly/index.ts:107:25 (i32.lt_u (get_local $4) - ;;@ assembly/index.ts:109:29 + ;;@ assembly/index.ts:107:29 (get_local $3) ) ) ) - ;;@ assembly/index.ts:109:40 + ;;@ assembly/index.ts:107:40 (block - ;;@ assembly/index.ts:110:6 + ;;@ assembly/index.ts:108:6 (set_local $5 - ;;@ assembly/index.ts:110:18 + ;;@ assembly/index.ts:108:18 (call $~lib/array/Array#__unchecked_get - ;;@ assembly/index.ts:110:28 + ;;@ assembly/index.ts:108:28 (get_local $2) - ;;@ assembly/index.ts:110:35 + ;;@ assembly/index.ts:108:35 (get_local $4) ) ) - ;;@ assembly/index.ts:113:6 + ;;@ assembly/index.ts:111:6 (set_local $6 - ;;@ assembly/index.ts:113:15 + ;;@ assembly/index.ts:111:15 (f64.load (get_local $5) ) ) - ;;@ assembly/index.ts:114:6 + ;;@ assembly/index.ts:112:6 (set_local $7 - ;;@ assembly/index.ts:114:15 + ;;@ assembly/index.ts:112:15 (f64.load offset=8 (get_local $5) ) ) - ;;@ assembly/index.ts:115:6 + ;;@ assembly/index.ts:113:6 (set_local $8 - ;;@ assembly/index.ts:115:15 + ;;@ assembly/index.ts:113:15 (f64.load offset=16 (get_local $5) ) ) - ;;@ assembly/index.ts:117:6 + ;;@ assembly/index.ts:115:6 (set_local $9 - ;;@ assembly/index.ts:117:17 + ;;@ assembly/index.ts:115:17 (f64.load offset=24 (get_local $5) ) ) - ;;@ assembly/index.ts:118:6 + ;;@ assembly/index.ts:116:6 (set_local $10 - ;;@ assembly/index.ts:118:17 + ;;@ assembly/index.ts:116:17 (f64.load offset=32 (get_local $5) ) ) - ;;@ assembly/index.ts:119:6 + ;;@ assembly/index.ts:117:6 (set_local $11 - ;;@ assembly/index.ts:119:17 + ;;@ assembly/index.ts:117:17 (f64.load offset=40 (get_local $5) ) ) - ;;@ assembly/index.ts:121:6 + ;;@ assembly/index.ts:119:6 (set_local $12 - ;;@ assembly/index.ts:121:19 + ;;@ assembly/index.ts:119:19 (f64.load offset=48 (get_local $5) ) ) - ;;@ assembly/index.ts:122:6 + ;;@ assembly/index.ts:120:6 (block $break|1 - ;;@ assembly/index.ts:122:11 + ;;@ assembly/index.ts:120:11 (set_local $13 - ;;@ assembly/index.ts:122:24 + ;;@ assembly/index.ts:120:24 (i32.add (get_local $4) - ;;@ assembly/index.ts:122:28 + ;;@ assembly/index.ts:120:28 (i32.const 1) ) ) (loop $repeat|1 (br_if $break|1 (i32.eqz - ;;@ assembly/index.ts:122:31 + ;;@ assembly/index.ts:120:31 (i32.lt_u (get_local $13) - ;;@ assembly/index.ts:122:35 + ;;@ assembly/index.ts:120:35 (get_local $3) ) ) ) - ;;@ assembly/index.ts:122:46 + ;;@ assembly/index.ts:120:46 (block - ;;@ assembly/index.ts:123:8 + ;;@ assembly/index.ts:121:8 (set_local $14 - ;;@ assembly/index.ts:123:20 + ;;@ assembly/index.ts:121:20 (call $~lib/array/Array#__unchecked_get - ;;@ assembly/index.ts:123:30 + ;;@ assembly/index.ts:121:30 (get_local $2) - ;;@ assembly/index.ts:123:37 + ;;@ assembly/index.ts:121:37 (get_local $13) ) ) - ;;@ assembly/index.ts:126:8 + ;;@ assembly/index.ts:124:8 (set_local $15 - ;;@ assembly/index.ts:126:17 + ;;@ assembly/index.ts:124:17 (f64.sub (get_local $6) - ;;@ assembly/index.ts:126:22 + ;;@ assembly/index.ts:124:22 (f64.load (get_local $14) ) ) ) - ;;@ assembly/index.ts:127:8 + ;;@ assembly/index.ts:125:8 (set_local $16 - ;;@ assembly/index.ts:127:17 + ;;@ assembly/index.ts:125:17 (f64.sub (get_local $7) - ;;@ assembly/index.ts:127:22 + ;;@ assembly/index.ts:125:22 (f64.load offset=8 (get_local $14) ) ) ) - ;;@ assembly/index.ts:128:8 + ;;@ assembly/index.ts:126:8 (set_local $17 - ;;@ assembly/index.ts:128:17 + ;;@ assembly/index.ts:126:17 (f64.sub (get_local $8) - ;;@ assembly/index.ts:128:22 + ;;@ assembly/index.ts:126:22 (f64.load offset=16 (get_local $14) ) ) ) - ;;@ assembly/index.ts:130:8 + ;;@ assembly/index.ts:128:8 (set_local $18 - ;;@ assembly/index.ts:130:25 + ;;@ assembly/index.ts:128:25 (f64.add (f64.add (f64.mul (get_local $15) - ;;@ assembly/index.ts:130:30 + ;;@ assembly/index.ts:128:30 (get_local $15) ) - ;;@ assembly/index.ts:130:35 + ;;@ assembly/index.ts:128:35 (f64.mul (get_local $16) - ;;@ assembly/index.ts:130:40 + ;;@ assembly/index.ts:128:40 (get_local $16) ) ) - ;;@ assembly/index.ts:130:45 + ;;@ assembly/index.ts:128:45 (f64.mul (get_local $17) - ;;@ assembly/index.ts:130:50 + ;;@ assembly/index.ts:128:50 (get_local $17) ) ) ) - ;;@ assembly/index.ts:131:8 + ;;@ assembly/index.ts:129:8 (set_local $19 - ;;@ assembly/index.ts:131:23 + ;;@ assembly/index.ts:129:23 (block $~lib/math/NativeMath.sqrt|inlined.0 (result f64) ;;@ ~lib/math.ts:1076:30 (f64.sqrt @@ -1711,126 +1681,126 @@ ) ) ) - ;;@ assembly/index.ts:132:8 + ;;@ assembly/index.ts:130:8 (set_local $20 - ;;@ assembly/index.ts:132:18 + ;;@ assembly/index.ts:130:18 (f64.div (get_local $1) - ;;@ assembly/index.ts:132:23 + ;;@ assembly/index.ts:130:23 (f64.mul - ;;@ assembly/index.ts:132:24 + ;;@ assembly/index.ts:130:24 (get_local $18) - ;;@ assembly/index.ts:132:37 + ;;@ assembly/index.ts:130:37 (get_local $19) ) ) ) - ;;@ assembly/index.ts:134:8 + ;;@ assembly/index.ts:132:8 (set_local $21 - ;;@ assembly/index.ts:134:18 + ;;@ assembly/index.ts:132:18 (f64.mul (get_local $12) - ;;@ assembly/index.ts:134:27 + ;;@ assembly/index.ts:132:27 (get_local $20) ) ) - ;;@ assembly/index.ts:135:8 + ;;@ assembly/index.ts:133:8 (set_local $22 - ;;@ assembly/index.ts:135:18 + ;;@ assembly/index.ts:133:18 (f64.mul (f64.load offset=48 (get_local $14) ) - ;;@ assembly/index.ts:135:31 + ;;@ assembly/index.ts:133:31 (get_local $20) ) ) - ;;@ assembly/index.ts:137:8 + ;;@ assembly/index.ts:135:8 (set_local $9 (f64.sub (get_local $9) - ;;@ assembly/index.ts:137:16 + ;;@ assembly/index.ts:135:16 (f64.mul (get_local $15) + ;;@ assembly/index.ts:135:21 + (get_local $22) + ) + ) + ) + ;;@ assembly/index.ts:136:8 + (set_local $10 + (f64.sub + (get_local $10) + ;;@ assembly/index.ts:136:16 + (f64.mul + (get_local $16) + ;;@ assembly/index.ts:136:21 + (get_local $22) + ) + ) + ) + ;;@ assembly/index.ts:137:8 + (set_local $11 + (f64.sub + (get_local $11) + ;;@ assembly/index.ts:137:16 + (f64.mul + (get_local $17) ;;@ assembly/index.ts:137:21 (get_local $22) ) ) ) - ;;@ assembly/index.ts:138:8 - (set_local $10 - (f64.sub - (get_local $10) - ;;@ assembly/index.ts:138:16 - (f64.mul - (get_local $16) - ;;@ assembly/index.ts:138:21 - (get_local $22) - ) - ) - ) ;;@ assembly/index.ts:139:8 - (set_local $11 - (f64.sub - (get_local $11) - ;;@ assembly/index.ts:139:16 - (f64.mul - (get_local $17) - ;;@ assembly/index.ts:139:21 - (get_local $22) - ) - ) - ) - ;;@ assembly/index.ts:141:8 (f64.store offset=24 (get_local $14) (f64.add (f64.load offset=24 (get_local $14) ) - ;;@ assembly/index.ts:141:20 + ;;@ assembly/index.ts:139:20 (f64.mul (get_local $15) - ;;@ assembly/index.ts:141:25 + ;;@ assembly/index.ts:139:25 (get_local $21) ) ) ) - ;;@ assembly/index.ts:142:8 + ;;@ assembly/index.ts:140:8 (f64.store offset=32 (get_local $14) (f64.add (f64.load offset=32 (get_local $14) ) - ;;@ assembly/index.ts:142:20 + ;;@ assembly/index.ts:140:20 (f64.mul (get_local $16) - ;;@ assembly/index.ts:142:25 + ;;@ assembly/index.ts:140:25 (get_local $21) ) ) ) - ;;@ assembly/index.ts:143:8 + ;;@ assembly/index.ts:141:8 (f64.store offset=40 (get_local $14) (f64.add (f64.load offset=40 (get_local $14) ) - ;;@ assembly/index.ts:143:20 + ;;@ assembly/index.ts:141:20 (f64.mul (get_local $17) - ;;@ assembly/index.ts:143:25 + ;;@ assembly/index.ts:141:25 (get_local $21) ) ) ) ) - ;;@ assembly/index.ts:122:41 + ;;@ assembly/index.ts:120:41 (set_local $13 (i32.add - ;;@ assembly/index.ts:122:43 + ;;@ assembly/index.ts:120:43 (get_local $13) (i32.const 1) ) @@ -1838,74 +1808,74 @@ (br $repeat|1) ) ) - ;;@ assembly/index.ts:146:6 + ;;@ assembly/index.ts:144:6 (f64.store offset=24 (get_local $5) - ;;@ assembly/index.ts:146:17 + ;;@ assembly/index.ts:144:17 (get_local $9) ) - ;;@ assembly/index.ts:147:6 + ;;@ assembly/index.ts:145:6 (f64.store offset=32 (get_local $5) - ;;@ assembly/index.ts:147:17 + ;;@ assembly/index.ts:145:17 (get_local $10) ) - ;;@ assembly/index.ts:148:6 + ;;@ assembly/index.ts:146:6 (f64.store offset=40 (get_local $5) - ;;@ assembly/index.ts:148:17 + ;;@ assembly/index.ts:146:17 (get_local $11) ) - ;;@ assembly/index.ts:150:6 + ;;@ assembly/index.ts:148:6 (f64.store (get_local $5) (f64.add (f64.load (get_local $5) ) - ;;@ assembly/index.ts:150:17 + ;;@ assembly/index.ts:148:17 (f64.mul (get_local $1) - ;;@ assembly/index.ts:150:22 + ;;@ assembly/index.ts:148:22 (get_local $9) ) ) ) - ;;@ assembly/index.ts:151:6 + ;;@ assembly/index.ts:149:6 (f64.store offset=8 (get_local $5) (f64.add (f64.load offset=8 (get_local $5) ) - ;;@ assembly/index.ts:151:17 + ;;@ assembly/index.ts:149:17 (f64.mul (get_local $1) - ;;@ assembly/index.ts:151:22 + ;;@ assembly/index.ts:149:22 (get_local $10) ) ) ) - ;;@ assembly/index.ts:152:6 + ;;@ assembly/index.ts:150:6 (f64.store offset=16 (get_local $5) (f64.add (f64.load offset=16 (get_local $5) ) - ;;@ assembly/index.ts:152:17 + ;;@ assembly/index.ts:150:17 (f64.mul (get_local $1) - ;;@ assembly/index.ts:152:22 + ;;@ assembly/index.ts:150:22 (get_local $11) ) ) ) ) - ;;@ assembly/index.ts:109:35 + ;;@ assembly/index.ts:107:35 (set_local $4 (i32.add - ;;@ assembly/index.ts:109:37 + ;;@ assembly/index.ts:107:37 (get_local $4) (i32.const 1) ) @@ -1914,7 +1884,7 @@ ) ) ) - (func $assembly/index/NBodySystem#energy (; 23 ;) (type $iF) (param $0 i32) (result f64) + (func $assembly/index/NBodySystem#energy (; 22 ;) (type $iF) (param $0 i32) (result f64) (local $1 f64) (local $2 i32) (local $3 i32) @@ -1933,27 +1903,27 @@ (local $16 f64) (local $17 f64) (local $18 f64) - ;;@ assembly/index.ts:157:4 + ;;@ assembly/index.ts:155:4 (set_local $1 - ;;@ assembly/index.ts:157:19 + ;;@ assembly/index.ts:155:19 (f64.const 0) ) - ;;@ assembly/index.ts:158:4 + ;;@ assembly/index.ts:156:4 (set_local $2 - ;;@ assembly/index.ts:158:17 + ;;@ assembly/index.ts:156:17 (i32.load (get_local $0) ) ) - ;;@ assembly/index.ts:160:4 + ;;@ assembly/index.ts:158:4 (block $break|0 (block (set_local $3 - ;;@ assembly/index.ts:160:22 + ;;@ assembly/index.ts:158:22 (i32.const 0) ) (set_local $4 - ;;@ assembly/index.ts:160:37 + ;;@ assembly/index.ts:158:37 (call $~lib/array/Array#get:length (get_local $2) ) @@ -1962,203 +1932,203 @@ (loop $repeat|0 (br_if $break|0 (i32.eqz - ;;@ assembly/index.ts:160:52 + ;;@ assembly/index.ts:158:52 (i32.lt_u (get_local $3) - ;;@ assembly/index.ts:160:56 + ;;@ assembly/index.ts:158:56 (get_local $4) ) ) ) - ;;@ assembly/index.ts:160:67 + ;;@ assembly/index.ts:158:67 (block - ;;@ assembly/index.ts:161:6 + ;;@ assembly/index.ts:159:6 (set_local $5 - ;;@ assembly/index.ts:161:18 + ;;@ assembly/index.ts:159:18 (call $~lib/array/Array#__unchecked_get - ;;@ assembly/index.ts:161:28 + ;;@ assembly/index.ts:159:28 (get_local $2) - ;;@ assembly/index.ts:161:35 + ;;@ assembly/index.ts:159:35 (get_local $3) ) ) - ;;@ assembly/index.ts:163:6 + ;;@ assembly/index.ts:161:6 (set_local $6 - ;;@ assembly/index.ts:163:15 + ;;@ assembly/index.ts:161:15 (f64.load (get_local $5) ) ) - ;;@ assembly/index.ts:164:6 + ;;@ assembly/index.ts:162:6 (set_local $7 - ;;@ assembly/index.ts:164:15 + ;;@ assembly/index.ts:162:15 (f64.load offset=8 (get_local $5) ) ) - ;;@ assembly/index.ts:165:6 + ;;@ assembly/index.ts:163:6 (set_local $8 - ;;@ assembly/index.ts:165:15 + ;;@ assembly/index.ts:163:15 (f64.load offset=16 (get_local $5) ) ) - ;;@ assembly/index.ts:167:6 + ;;@ assembly/index.ts:165:6 (set_local $9 - ;;@ assembly/index.ts:167:15 + ;;@ assembly/index.ts:165:15 (f64.load offset=24 (get_local $5) ) ) - ;;@ assembly/index.ts:168:6 + ;;@ assembly/index.ts:166:6 (set_local $10 - ;;@ assembly/index.ts:168:15 + ;;@ assembly/index.ts:166:15 (f64.load offset=32 (get_local $5) ) ) - ;;@ assembly/index.ts:169:6 + ;;@ assembly/index.ts:167:6 (set_local $11 - ;;@ assembly/index.ts:169:15 + ;;@ assembly/index.ts:167:15 (f64.load offset=40 (get_local $5) ) ) - ;;@ assembly/index.ts:171:6 + ;;@ assembly/index.ts:169:6 (set_local $12 - ;;@ assembly/index.ts:171:16 + ;;@ assembly/index.ts:169:16 (f64.load offset=48 (get_local $5) ) ) - ;;@ assembly/index.ts:173:6 + ;;@ assembly/index.ts:171:6 (set_local $1 (f64.add (get_local $1) - ;;@ assembly/index.ts:173:11 + ;;@ assembly/index.ts:171:11 (f64.mul (f64.mul (f64.const 0.5) - ;;@ assembly/index.ts:173:17 + ;;@ assembly/index.ts:171:17 (get_local $12) ) - ;;@ assembly/index.ts:173:23 + ;;@ assembly/index.ts:171:23 (f64.add - ;;@ assembly/index.ts:173:24 + ;;@ assembly/index.ts:171:24 (f64.add (f64.mul (get_local $9) - ;;@ assembly/index.ts:173:29 + ;;@ assembly/index.ts:171:29 (get_local $9) ) - ;;@ assembly/index.ts:173:34 + ;;@ assembly/index.ts:171:34 (f64.mul (get_local $10) - ;;@ assembly/index.ts:173:39 + ;;@ assembly/index.ts:171:39 (get_local $10) ) ) - ;;@ assembly/index.ts:173:44 + ;;@ assembly/index.ts:171:44 (f64.mul (get_local $11) - ;;@ assembly/index.ts:173:49 + ;;@ assembly/index.ts:171:49 (get_local $11) ) ) ) ) ) - ;;@ assembly/index.ts:175:6 + ;;@ assembly/index.ts:173:6 (block $break|1 - ;;@ assembly/index.ts:175:11 + ;;@ assembly/index.ts:173:11 (set_local $13 - ;;@ assembly/index.ts:175:24 + ;;@ assembly/index.ts:173:24 (i32.add (get_local $3) - ;;@ assembly/index.ts:175:28 + ;;@ assembly/index.ts:173:28 (i32.const 1) ) ) (loop $repeat|1 (br_if $break|1 (i32.eqz - ;;@ assembly/index.ts:175:31 + ;;@ assembly/index.ts:173:31 (i32.lt_u (get_local $13) - ;;@ assembly/index.ts:175:35 + ;;@ assembly/index.ts:173:35 (get_local $4) ) ) ) - ;;@ assembly/index.ts:175:46 + ;;@ assembly/index.ts:173:46 (block - ;;@ assembly/index.ts:176:8 + ;;@ assembly/index.ts:174:8 (set_local $14 - ;;@ assembly/index.ts:176:20 + ;;@ assembly/index.ts:174:20 (call $~lib/array/Array#__unchecked_get - ;;@ assembly/index.ts:176:30 + ;;@ assembly/index.ts:174:30 (get_local $2) - ;;@ assembly/index.ts:176:37 + ;;@ assembly/index.ts:174:37 (get_local $13) ) ) - ;;@ assembly/index.ts:177:8 + ;;@ assembly/index.ts:175:8 (set_local $15 - ;;@ assembly/index.ts:177:17 + ;;@ assembly/index.ts:175:17 (f64.sub (get_local $6) - ;;@ assembly/index.ts:177:22 + ;;@ assembly/index.ts:175:22 (f64.load (get_local $14) ) ) ) - ;;@ assembly/index.ts:178:8 + ;;@ assembly/index.ts:176:8 (set_local $16 - ;;@ assembly/index.ts:178:17 + ;;@ assembly/index.ts:176:17 (f64.sub (get_local $7) - ;;@ assembly/index.ts:178:22 + ;;@ assembly/index.ts:176:22 (f64.load offset=8 (get_local $14) ) ) ) - ;;@ assembly/index.ts:179:8 + ;;@ assembly/index.ts:177:8 (set_local $17 - ;;@ assembly/index.ts:179:17 + ;;@ assembly/index.ts:177:17 (f64.sub (get_local $8) - ;;@ assembly/index.ts:179:22 + ;;@ assembly/index.ts:177:22 (f64.load offset=16 (get_local $14) ) ) ) - ;;@ assembly/index.ts:180:8 + ;;@ assembly/index.ts:178:8 (set_local $18 - ;;@ assembly/index.ts:180:23 + ;;@ assembly/index.ts:178:23 (block $~lib/math/NativeMath.sqrt|inlined.1 (result f64) (set_local $18 - ;;@ assembly/index.ts:180:40 + ;;@ assembly/index.ts:178:40 (f64.add (f64.add (f64.mul (get_local $15) - ;;@ assembly/index.ts:180:45 + ;;@ assembly/index.ts:178:45 (get_local $15) ) - ;;@ assembly/index.ts:180:50 + ;;@ assembly/index.ts:178:50 (f64.mul (get_local $16) - ;;@ assembly/index.ts:180:55 + ;;@ assembly/index.ts:178:55 (get_local $16) ) ) - ;;@ assembly/index.ts:180:60 + ;;@ assembly/index.ts:178:60 (f64.mul (get_local $17) - ;;@ assembly/index.ts:180:65 + ;;@ assembly/index.ts:178:65 (get_local $17) ) ) @@ -2170,29 +2140,29 @@ ) ) ) - ;;@ assembly/index.ts:181:8 + ;;@ assembly/index.ts:179:8 (set_local $1 (f64.sub (get_local $1) - ;;@ assembly/index.ts:181:13 + ;;@ assembly/index.ts:179:13 (f64.div (f64.mul (get_local $12) - ;;@ assembly/index.ts:181:19 + ;;@ assembly/index.ts:179:19 (f64.load offset=48 (get_local $14) ) ) - ;;@ assembly/index.ts:181:32 + ;;@ assembly/index.ts:179:32 (get_local $18) ) ) ) ) - ;;@ assembly/index.ts:175:41 + ;;@ assembly/index.ts:173:41 (set_local $13 (i32.add - ;;@ assembly/index.ts:175:43 + ;;@ assembly/index.ts:173:43 (get_local $13) (i32.const 1) ) @@ -2201,10 +2171,10 @@ ) ) ) - ;;@ assembly/index.ts:160:62 + ;;@ assembly/index.ts:158:62 (set_local $3 (i32.add - ;;@ assembly/index.ts:160:64 + ;;@ assembly/index.ts:158:64 (get_local $3) (i32.const 1) ) @@ -2212,53 +2182,54 @@ (br $repeat|0) ) ) - ;;@ assembly/index.ts:184:11 + ;;@ assembly/index.ts:182:11 (get_local $1) ) - (func $assembly/index/step (; 24 ;) (type $F) (result f64) - ;;@ assembly/index.ts:206:9 + (func $assembly/index/step (; 23 ;) (type $F) (result f64) + ;;@ assembly/index.ts:199:9 (call $assembly/index/NBodySystem#advance - ;;@ assembly/index.ts:206:2 + ;;@ assembly/index.ts:199:2 (get_global $assembly/index/system) - ;;@ assembly/index.ts:206:17 + ;;@ assembly/index.ts:199:17 (f64.const 0.01) ) - ;;@ assembly/index.ts:207:23 + ;;@ assembly/index.ts:200:23 (call $assembly/index/NBodySystem#energy - ;;@ assembly/index.ts:207:9 + ;;@ assembly/index.ts:200:9 (get_global $assembly/index/system) ) ) - (func $assembly/index/bench (; 25 ;) (type $iv) (param $0 i32) + (func $assembly/index/bench (; 24 ;) (type $iv) (param $0 i32) (local $1 i32) - ;;@ assembly/index.ts:211:2 + ;;@ assembly/index.ts:204:2 (block $break|0 - ;;@ assembly/index.ts:211:7 + ;;@ assembly/index.ts:204:7 (set_local $1 - ;;@ assembly/index.ts:211:20 + ;;@ assembly/index.ts:204:20 (i32.const 0) ) (loop $repeat|0 (br_if $break|0 (i32.eqz - ;;@ assembly/index.ts:211:23 + ;;@ assembly/index.ts:204:23 (i32.lt_u (get_local $1) - ;;@ assembly/index.ts:211:27 + ;;@ assembly/index.ts:204:27 (get_local $0) ) ) ) - ;;@ assembly/index.ts:211:46 + ;;@ assembly/index.ts:204:46 (call $assembly/index/NBodySystem#advance - ;;@ assembly/index.ts:211:39 + ;;@ assembly/index.ts:204:39 (get_global $assembly/index/system) - ;;@ assembly/index.ts:211:54 + ;;@ assembly/index.ts:204:54 (f64.const 0.01) ) - ;;@ assembly/index.ts:211:34 + ;;@ assembly/index.ts:204:34 (set_local $1 (i32.add + ;;@ assembly/index.ts:204:36 (get_local $1) (i32.const 1) ) @@ -2267,7 +2238,7 @@ ) ) ) - (func $start (; 26 ;) (type $v) + (func $start (; 25 ;) (type $v) (set_global $~lib/allocator/arena/startOffset ;;@ ~lib/allocator/arena.ts:12:25 (i32.and diff --git a/examples/n-body/package.json b/examples/n-body/package.json index fece7a1c..b52d65c9 100644 --- a/examples/n-body/package.json +++ b/examples/n-body/package.json @@ -3,8 +3,8 @@ "version": "1.0.0", "private": true, "scripts": { - "asbuild:untouched": "asc assembly/index.ts -b build/untouched.wasm -t build/untouched.wat --sourceMap --validate", - "asbuild:optimized": "asc assembly/index.ts -b build/optimized.wasm -t build/optimized.wat -O3 --validate --noDebug --noAssert", + "asbuild:untouched": "asc assembly/index.ts -b build/untouched.wasm -t build/untouched.wat --sourceMap --validate --importMemory", + "asbuild:optimized": "asc assembly/index.ts -b build/optimized.wasm -t build/optimized.wat -O3 --validate --noDebug --noAssert --importMemory", "asbuild:asmjs": "asc assembly/index.ts -a build/index.asm.js -O3 --validate --noDebug --noAssert", "asbuild": "npm run asbuild:untouched && npm run asbuild:optimized && npm run asbuild:asmjs", "tsbuild": "tsc -p assembly -t ES2017 -m commonjs --outDir build", diff --git a/examples/n-body/rust/Cargo.toml b/examples/n-body/rust/Cargo.toml index cb353311..643c7e17 100644 --- a/examples/n-body/rust/Cargo.toml +++ b/examples/n-body/rust/Cargo.toml @@ -9,4 +9,4 @@ crate-type = ["cdylib"] [profile.release] lto = true -opt-level = 's' +opt-level = 3 diff --git a/examples/n-body/rust/index.js b/examples/n-body/rust/index.js index 4195684c..5686c0ef 100644 --- a/examples/n-body/rust/index.js +++ b/examples/n-body/rust/index.js @@ -7,6 +7,7 @@ const compiled = new WebAssembly.Module( const imports = { env: { + memory: new WebAssembly.Memory({ initial: 17 }), abort: (filename, line, column) => { throw Error("abort called at " + line + ":" + colum); } diff --git a/examples/n-body/rust/src/lib.rs b/examples/n-body/rust/src/lib.rs index 018ca9e7..077b8d7a 100644 --- a/examples/n-body/rust/src/lib.rs +++ b/examples/n-body/rust/src/lib.rs @@ -1,22 +1,20 @@ // Code adopted from https://benchmarksgame-team.pages.debian.net/benchmarksgame/program/nbody-rust-1.html -#![feature(core_intrinsics, lang_items)] +#![feature(core_intrinsics, panic_implementation)] #![no_std] -#[lang = "panic_fmt"] -extern "C" fn panic_fmt(_args: ::core::fmt::Arguments, _file: &'static str, _line: u32) -> ! { - use core::intrinsics; - unsafe { - intrinsics::abort(); - } +use core::intrinsics; +use core::panic::PanicInfo; + +#[panic_implementation] +#[no_mangle] +pub fn panic(_info: &PanicInfo) -> ! { + unsafe { intrinsics::abort() } } #[inline(always)] fn sqrt(x: f64) -> f64 { - use core::intrinsics; - unsafe { - intrinsics::sqrtf64(x) - } + unsafe { intrinsics::sqrtf64(x) } } const PI: f64 = 3.141592653589793; diff --git a/examples/n-body/tests/index.js b/examples/n-body/tests/index.js index fa3e4cdd..9a7cebbf 100644 --- a/examples/n-body/tests/index.js +++ b/examples/n-body/tests/index.js @@ -41,38 +41,39 @@ function test(nbody, steps) { } var steps = process.argv.length > 2 ? parseInt(process.argv[2], 10) : 20000000; -var time; -console.log("Performing " + steps + " steps (AssemblyScript WASM) ..."); -time = test(nbodyAS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +function prologue(name, steps) { + console.log("Performing " + steps + " steps (" + name + ") ..."); +} -console.log("Performing " + steps + " steps (AssemblyScript ASMJS) ..."); -time = test(nbodyAsmJS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +function epilogue(time) { + console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +} -console.log("Performing " + steps + " steps (JS) ..."); -time = test(nbodyJS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +console.log("\nCOLD SERIES:\n"); -console.log("Performing " + steps + " steps (Rust WASM) ..."); -time = test(nbodyRS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +prologue("AssemblyScript WASM", steps); +epilogue(test(nbodyAS, steps)); -console.log("\nWARMED UP:\n"); +prologue("AssemblyScript ASMJS", steps); +epilogue(test(nbodyAsmJS, steps)); -console.log("Performing " + steps + " steps (AssemblyScript WASM) ..."); -time = test(nbodyAS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +prologue("JS", steps); +epilogue(test(nbodyJS, steps)); -console.log("Performing " + steps + " steps (AssemblyScript ASMJS) ..."); -time = test(nbodyAsmJS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +prologue("Rust WASM", steps); +epilogue(test(nbodyRS, steps)); -console.log("Performing " + steps + " steps (JS) ..."); -time = test(nbodyJS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +console.log("\nWARMED UP SERIES:\n"); -console.log("Performing " + steps + " steps (Rust WASM) ..."); -time = test(nbodyRS, steps); -console.log("Took " + (time[0] * 1e3 + time[1] / 1e6) + "ms"); +prologue("AssemblyScript WASM", steps); +epilogue(test(nbodyAS, steps)); + +prologue("AssemblyScript ASMJS", steps); +epilogue(test(nbodyAsmJS, steps)); + +prologue("JS", steps); +epilogue(test(nbodyJS, steps)); + +prologue("Rust WASM", steps); +epilogue(test(nbodyRS, steps));