Current benchmark data was generated on Thu Jul 13 2023, full log can be found HERE
CONTRIBUTIONS are WELCOME!
* -m in a file name stands for multi-threading or multi-processing
* -i in a file name stands for direct intrinsics usage. (Usage of simd intrinsics via libraries is not counted)
* -ffi in a file name stands for non-stdlib FFI usage
* (You may find time < time(user) + time(sys) for some non-parallelized programs, the overhead is from GC or JIT compiler, which are allowed to take advantage of multi-cores as that's more close to real-world scenarios.)
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 1144ms | 13ms | 191.4MB | 1403ms | 47ms | bun 0.6.14 |
wasm | 3.rs | 2048ms | 5.9ms | 60.1MB | 2017ms | 10ms | wasmedgec 0.13.1 |
wasm | 5.rs | 2074ms | 21ms | 44.2MB | 2047ms | 10ms | wasmedgec 0.13.1 |
wasm | 4.rs | 2202ms | 1.4ms | 44.9MB | 2170ms | 13ms | wasmedgec 0.13.1 |
wasm | 3.rs | 2272ms | 23ms | 48.1MB | 2243ms | 3ms | wasmtime 10.0.1 |
wasm | 3.rs | 2717ms | 81ms | 80.1MB | 2687ms | 27ms | node 18.16.1 |
wasm | 4.rs | 2770ms | 28ms | 65.4MB | 2747ms | 20ms | node 18.16.1 |
wasm | 5.rs | 2774ms | 20ms | 65.1MB | 2763ms | 7ms | node 18.16.1 |
wasm | 5.rs | 2817ms | 17ms | 32.3MB | 2800ms | 7ms | wasmtime 10.0.1 |
wasm | 4.rs | 2933ms | 20ms | 32.2MB | 2910ms | 7ms | wasmtime 10.0.1 |
javascript | 1.js | 3424ms | 30ms | 266.2MB | 2693ms | 1280ms | node 20.4.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 116ms | 4.2ms | 105.5MB | 107ms | 13ms | bun 0.6.14 |
javascript | 1.js | 174ms | 4.1ms | 68.2MB | 153ms | 27ms | node 20.4.0 |
wasm | 3.rs | 203ms | 4.3ms | 32.0MB | 180ms | 0ms | wasmedgec 0.13.1 |
wasm | 5.rs | 204ms | 1.9ms | 30.1MB | 187ms | 0ms | wasmedgec 0.13.1 |
wasm | 3.rs | 215ms | 5.6ms | 20.0MB | 200ms | 0ms | wasmtime 10.0.1 |
wasm | 4.rs | 219ms | 2.6ms | 30.1MB | 197ms | 3ms | wasmedgec 0.13.1 |
wasm | 5.rs | 269ms | 0.5ms | 18.1MB | 257ms | 0ms | wasmtime 10.0.1 |
wasm | 4.rs | 284ms | 1.1ms | 20.0MB | 270ms | 0ms | wasmtime 10.0.1 |
wasm | 3.rs | 305ms | 8.2ms | 52.4MB | 290ms | 3ms | node 18.16.1 |
wasm | 5.rs | 308ms | 1.0ms | 52.2MB | 303ms | 0ms | node 18.16.1 |
wasm | 4.rs | 308ms | 8.2ms | 53.1MB | 300ms | 7ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 3.rs | 1425ms | 14ms | 56.6MB | 1440ms | 10ms | node 18.16.1 |
wasm | 3.rs | 1520ms | 4.5ms | 18.5MB | 1503ms | 3ms | wasmtime 10.0.1 |
wasm | 3.rs | 2028ms | 2.8ms | 28.4MB | 2010ms | 0ms | wasmedgec 0.13.1 |
javascript | 1.js | 2222ms | 17ms | 79.9MB | 2267ms | 43ms | node 20.4.0 |
javascript | 1.js | 3195ms | 143ms | 121.5MB | 3190ms | 27ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 3.rs | 105ms | 0.2ms | 16.9MB | 90ms | 0ms | wasmtime 10.0.1 |
wasm | 3.rs | 143ms | 1.5ms | 29.9MB | 130ms | 0ms | wasmedgec 0.13.1 |
wasm | 3.rs | 165ms | 4.4ms | 58.6MB | 173ms | 10ms | node 18.16.1 |
javascript | 1.js | 215ms | 3.0ms | 61.3MB | 187ms | 27ms | node 20.4.0 |
javascript | 1.js | 235ms | 6.8ms | 102.0MB | 240ms | 13ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 390ms | 4.2ms | 55.4MB | 400ms | 20ms | node 20.4.0 |
javascript | 1.js | 398ms | 2.8ms | 100.1MB | 367ms | 20ms | bun 0.6.14 |
wasm | 1.rs | 484ms | 1.6ms | 28.9MB | 463ms | 0ms | wasmedgec 0.13.1 |
wasm | 1.rs | 589ms | 0.5ms | 17.5MB | 570ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 659ms | 0.8ms | 58.1MB | 690ms | 7ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 132ms | 0.7ms | 29.7MB | 120ms | 0ms | wasmedgec 0.13.1 |
wasm | 1.rs | 157ms | 0.3ms | 16.7MB | 147ms | 0ms | wasmtime 10.0.1 |
javascript | 1.js | 184ms | 1.7ms | 51.6MB | 207ms | 20ms | node 20.4.0 |
wasm | 1.rs | 233ms | 3.6ms | 57.6MB | 260ms | 13ms | node 18.16.1 |
javascript | 1.js | 419ms | 3.1ms | 88.0MB | 393ms | 17ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 7.0ms | 1.0ms | 16.1MB | 0ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 9.9ms | 0.9ms | 28.8MB | 0ms | 0ms | wasmedgec 0.13.1 |
javascript | 1.js | 16ms | 0.7ms | 52.2MB | 0ms | 10ms | bun 0.6.14 |
javascript | 1.js | 44ms | 4.7ms | 40.9MB | 26ms | 8ms | node 20.4.0 |
wasm | 1.rs | 47ms | 2.4ms | 47.3MB | 32ms | 2ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 163ms | 1.5ms | 28.2MB | 147ms | 3ms | wasmedgec 0.13.1 |
wasm | 1.rs | 200ms | 0.9ms | 16.2MB | 187ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 283ms | 1.5ms | 53.4MB | 270ms | 10ms | node 18.16.1 |
javascript | 2.js | 372ms | 9.7ms | 53.0MB | 350ms | 20ms | node 20.4.0 |
javascript | 1.js | 556ms | 2.7ms | 148.0MB | 543ms | 30ms | bun 0.6.14 |
javascript | 1.js | 710ms | 8.8ms | 51.8MB | 687ms | 23ms | node 20.4.0 |
javascript | 2.js | 775ms | 1.4ms | 112.6MB | 790ms | 20ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 466ms | 2.2ms | 27.6MB | 450ms | 0ms | wasmedgec 0.13.1 |
wasm | 1.rs | 584ms | 4.8ms | 16.2MB | 567ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 722ms | 2.0ms | 53.1MB | 710ms | 13ms | node 18.16.1 |
javascript | 2.js | 1001ms | 3.1ms | 63.0MB | 973ms | 23ms | node 20.4.0 |
javascript | 1.js | 1591ms | 6.1ms | 173.4MB | 1610ms | 30ms | bun 0.6.14 |
javascript | 1.js | 2007ms | 8.0ms | 58.4MB | 1987ms | 20ms | node 20.4.0 |
javascript | 2.js | 2225ms | 22ms | 120.8MB | 2230ms | 27ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 88ms | 1.8ms | 28.2MB | 70ms | 3ms | wasmedgec 0.13.1 |
wasm | 1.rs | 103ms | 0.3ms | 16.3MB | 90ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 159ms | 3.7ms | 51.3MB | 143ms | 10ms | node 18.16.1 |
javascript | 2.js | 207ms | 5.6ms | 46.6MB | 187ms | 20ms | node 20.4.0 |
javascript | 1.js | 224ms | 2.5ms | 48.7MB | 200ms | 23ms | node 20.4.0 |
javascript | 1.js | 283ms | 1.9ms | 118.4MB | 270ms | 20ms | bun 0.6.14 |
javascript | 2.js | 421ms | 4.8ms | 107.6MB | 423ms | 20ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 740ms | 11ms | 158.0MB | 823ms | 20ms | bun 0.6.14 |
javascript | 1.js | 761ms | 9.1ms | 120.7MB | 763ms | 50ms | node 20.4.0 |
wasm | 1.rs | 1134ms | 4.5ms | 51.5MB | 1103ms | 10ms | wasmedgec 0.13.1 |
wasm | 1.rs | 1354ms | 4.0ms | 40.3MB | 1327ms | 10ms | wasmtime 10.0.1 |
wasm | 1.rs | 1383ms | 21ms | 73.3MB | 1367ms | 13ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 173ms | 3.3ms | 110.2MB | 153ms | 23ms | bun 0.6.14 |
javascript | 1.js | 217ms | 3.0ms | 88.2MB | 197ms | 30ms | node 20.4.0 |
wasm | 1.rs | 251ms | 2.8ms | 34.9MB | 223ms | 10ms | wasmedgec 0.13.1 |
wasm | 1.rs | 299ms | 4.3ms | 22.3MB | 287ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 340ms | 4.2ms | 55.4MB | 323ms | 17ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 472ms | 2.5ms | 16.1MB | 463ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 492ms | 0.4ms | 28.6MB | 477ms | 0ms | wasmedgec 0.13.1 |
javascript | 6.js | 611ms | 7.4ms | 45.7MB | 590ms | 17ms | node 20.4.0 |
wasm | 2.rs | 655ms | 4.7ms | 27.8MB | 633ms | 7ms | wasmedgec 0.13.1 |
wasm | 2.rs | 657ms | 1.4ms | 16.3MB | 643ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 774ms | 77ms | 48.6MB | 760ms | 7ms | node 18.16.1 |
wasm | 2.rs | 943ms | 2.4ms | 49.3MB | 930ms | 7ms | node 18.16.1 |
javascript | 6.js | 1018ms | 11ms | 74.0MB | 1010ms | 0ms | bun 0.6.14 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 55ms | 1.7ms | 16.1MB | 43ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 60ms | 2.1ms | 27.3MB | 50ms | 0ms | wasmedgec 0.13.1 |
wasm | 2.rs | 75ms | 1.6ms | 16.0MB | 63ms | 0ms | wasmtime 10.0.1 |
wasm | 2.rs | 77ms | 1.6ms | 28.6MB | 63ms | 3ms | wasmedgec 0.13.1 |
javascript | 6.js | 111ms | 1.6ms | 45.8MB | 90ms | 17ms | node 20.4.0 |
wasm | 1.rs | 119ms | 0.8ms | 49.5MB | 107ms | 0ms | node 18.16.1 |
javascript | 6.js | 123ms | 0.5ms | 75.7MB | 120ms | 7ms | bun 0.6.14 |
wasm | 2.rs | 142ms | 2.9ms | 49.9MB | 127ms | 3ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 586ms | 9.0ms | 31.6MB | 567ms | 3ms | wasmedgec 0.13.1 |
wasm | 2.rs | 604ms | 0.9ms | 21.2MB | 590ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 613ms | 36ms | 66.5MB | 587ms | 10ms | wasmedgec 0.13.1 |
wasm | 1.rs | 624ms | 13ms | 55.3MB | 603ms | 7ms | wasmtime 10.0.1 |
wasm | 2.rs | 1090ms | 9.2ms | 53.6MB | 1067ms | 10ms | node 18.16.1 |
wasm | 1.rs | 1351ms | 92ms | 87.9MB | 1337ms | 10ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 142ms | 0.1ms | 17.4MB | 127ms | 0ms | wasmtime 10.0.1 |
wasm | 2.rs | 142ms | 2.1ms | 29.2MB | 127ms | 3ms | wasmedgec 0.13.1 |
wasm | 1.rs | 145ms | 0.5ms | 25.9MB | 130ms | 0ms | wasmtime 10.0.1 |
wasm | 1.rs | 149ms | 3.2ms | 40.5MB | 130ms | 3ms | wasmedgec 0.13.1 |
wasm | 2.rs | 298ms | 1.7ms | 49.2MB | 280ms | 10ms | node 18.16.1 |
wasm | 1.rs | 349ms | 2.5ms | 58.9MB | 333ms | 7ms | node 18.16.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 2761ms | 9.1ms | 28.6MB | 2740ms | 3ms | wasmedgec 0.13.1 |
wasm | 2.rs | 3088ms | 0.8ms | 17.2MB | 3077ms | 0ms | wasmtime 10.0.1 |
wasm | 2.rs | 3251ms | 2.8ms | 53.8MB | 3257ms | 10ms | node 18.16.1 |
javascript | 3.js | timeout | 0.0ms | 77.2MB | 4353ms | 647ms | node 20.4.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 652ms | 3.8ms | 28.8MB | 637ms | 0ms | wasmedgec 0.13.1 |
wasm | 2.rs | 727ms | 1.0ms | 16.9MB | 710ms | 0ms | wasmtime 10.0.1 |
wasm | 2.rs | 815ms | 2.2ms | 54.6MB | 827ms | 13ms | node 18.16.1 |
javascript | 3.js | 1642ms | 5.5ms | 60.9MB | 1547ms | 107ms | node 20.4.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 2985ms | 3.9ms | 105.5MB | 3003ms | 13ms | bun 0.6.14 |
javascript | 1.js | 3180ms | 8.4ms | 48.8MB | 3170ms | 23ms | node 20.4.0 |
wasm | 1.rs | 4503ms | 3.2ms | 27.3MB | 4487ms | 0ms | wasmedgec 0.13.1 |
wasm | 1.rs | 4739ms | 11ms | 66.6MB | 4793ms | 13ms | node 18.16.1 |
wasm | 1.rs | timeout | 0.0ms | 16.1MB | 4983ms | 0ms | wasmtime 10.0.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 768ms | 1.3ms | 103.4MB | 770ms | 17ms | bun 0.6.14 |
javascript | 1.js | 845ms | 3.4ms | 47.5MB | 837ms | 17ms | node 20.4.0 |
wasm | 1.rs | 1138ms | 2.2ms | 26.6MB | 1120ms | 0ms | wasmedgec 0.13.1 |
wasm | 1.rs | 1262ms | 8.5ms | 66.9MB | 1300ms | 23ms | node 18.16.1 |
wasm | 1.rs | 1316ms | 16ms | 16.3MB | 1300ms | 0ms | wasmtime 10.0.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 6-m.js | 2651ms | 11ms | 66.6MB | 5087ms | 50ms | node 20.4.0 |
wasm | 2.rs | 4128ms | 1.6ms | 32.1MB | 4110ms | 0ms | wasmedgec 0.13.1 |
wasm | 7.rs | 4247ms | 3.7ms | 27.6MB | 4233ms | 0ms | wasmedgec 0.13.1 |
wasm | 2.rs | 4317ms | 4.1ms | 49.0MB | 4300ms | 0ms | node 18.16.1 |
wasm | 2.rs | 4425ms | 1.5ms | 16.3MB | 4413ms | 0ms | wasmtime 10.0.1 |
wasm | 7.rs | 4554ms | 1.2ms | 49.4MB | 4540ms | 7ms | node 18.16.1 |
wasm | 7.rs | timeout | 0.0ms | 16.0MB | 4987ms | 0ms | wasmtime 10.0.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 6-m.js | 768ms | 3.5ms | 64.1MB | 1393ms | 47ms | node 20.4.0 |
wasm | 2.rs | 1042ms | 2.4ms | 28.8MB | 1023ms | 0ms | wasmedgec 0.13.1 |
wasm | 7.rs | 1072ms | 1.6ms | 29.5MB | 1060ms | 0ms | wasmedgec 0.13.1 |
wasm | 2.rs | 1116ms | 0.6ms | 16.1MB | 1103ms | 0ms | wasmtime 10.0.1 |
wasm | 2.rs | 1117ms | 3.3ms | 48.3MB | 1097ms | 7ms | node 18.16.1 |
wasm | 7.rs | 1177ms | 0.5ms | 48.4MB | 1160ms | 3ms | node 18.16.1 |
wasm | 7.rs | 3261ms | 2.9ms | 16.3MB | 3243ms | 0ms | wasmtime 10.0.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 271ms | 0.6ms | 28.7MB | 250ms | 0ms | wasmedgec 0.13.1 |
wasm | 7.rs | 278ms | 0.4ms | 27.8MB | 260ms | 0ms | wasmedgec 0.13.1 |
wasm | 2.rs | 289ms | 5.6ms | 16.0MB | 270ms | 0ms | wasmtime 10.0.1 |
javascript | 6-m.js | 303ms | 6.8ms | 68.3MB | 477ms | 33ms | node 20.4.0 |
wasm | 2.rs | 317ms | 1.2ms | 47.0MB | 297ms | 10ms | node 18.16.1 |
wasm | 7.rs | 332ms | 1.3ms | 48.0MB | 313ms | 7ms | node 18.16.1 |
wasm | 7.rs | 822ms | 1.0ms | 16.1MB | 810ms | 0ms | wasmtime 10.0.1 |