Current benchmark data was generated on Wed Feb 08 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 | 1662ms | 23ms | 244.3MB | 2067ms | 80ms | bun 0.5.5 |
wasm | 3.rs | 2706ms | 17ms | 48.1MB | 2673ms | 17ms | wasmedgec 0.11.2 |
wasm | 5.rs | 2707ms | 6.6ms | 31.2MB | 2683ms | 3ms | wasmedgec 0.11.2 |
wasm | 4.rs | 2873ms | 6.5ms | 31.7MB | 2840ms | 13ms | wasmedgec 0.11.2 |
wasm | 5.rs | 3216ms | 6.5ms | 59.3MB | 3213ms | 20ms | node 16.19.0 |
wasm | 3.rs | 3302ms | 25ms | 74.9MB | 3267ms | 27ms | node 16.19.0 |
wasm | 4.rs | 3315ms | 8.3ms | 59.7MB | 3310ms | 23ms | node 16.19.0 |
wasm | 5.rs | 3364ms | 1.0ms | 26.9MB | 3343ms | 7ms | wasmtime 5.0.0 |
wasm | 4.rs | 3507ms | 18ms | 26.8MB | 3480ms | 10ms | wasmtime 5.0.0 |
wasm | 3.rs | 3669ms | 17ms | 42.5MB | 3647ms | 3ms | wasmtime 5.0.0 |
javascript | 1.js | 4772ms | 40ms | 260.9MB | 3527ms | 1607ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 158ms | 1.8ms | 101.8MB | 143ms | 17ms | bun 0.5.5 |
javascript | 1.js | 235ms | 6.3ms | 70.4MB | 220ms | 23ms | node 19.6.0 |
wasm | 3.rs | 247ms | 1.1ms | 19.0MB | 240ms | 0ms | wasmedgec 0.11.2 |
wasm | 5.rs | 260ms | 3.4ms | 18.7MB | 243ms | 0ms | wasmedgec 0.11.2 |
wasm | 4.rs | 275ms | 4.6ms | 17.0MB | 260ms | 0ms | wasmedgec 0.11.2 |
wasm | 5.rs | 322ms | 4.3ms | 12.9MB | 310ms | 0ms | wasmtime 5.0.0 |
wasm | 4.rs | 332ms | 3.2ms | 12.9MB | 317ms | 0ms | wasmtime 5.0.0 |
wasm | 3.rs | 337ms | 0.5ms | 14.8MB | 320ms | 0ms | wasmtime 5.0.0 |
wasm | 3.rs | 389ms | 13ms | 46.2MB | 393ms | 7ms | node 16.19.0 |
wasm | 5.rs | 390ms | 8.9ms | 45.2MB | 400ms | 7ms | node 16.19.0 |
wasm | 4.rs | 392ms | 3.8ms | 45.1MB | 403ms | 10ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 3.rs | 1809ms | 30ms | 49.9MB | 1860ms | 13ms | node 16.19.0 |
wasm | 3.rs | 1955ms | 5.0ms | 12.9MB | 1940ms | 0ms | wasmtime 5.0.0 |
wasm | 3.rs | 2468ms | 7.7ms | 17.3MB | 2443ms | 7ms | wasmedgec 0.11.2 |
javascript | 1.js | 2662ms | 32ms | 80.6MB | 2730ms | 40ms | node 19.6.0 |
javascript | 1.js | 3952ms | 13ms | 110.6MB | 3947ms | 63ms | bun 0.5.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 3.rs | 131ms | 0.6ms | 11.6MB | 117ms | 0ms | wasmtime 5.0.0 |
wasm | 3.rs | 168ms | 5.8ms | 15.9MB | 157ms | 0ms | wasmedgec 0.11.2 |
javascript | 1.js | 246ms | 11ms | 62.4MB | 217ms | 23ms | node 19.6.0 |
wasm | 3.rs | 260ms | 12ms | 48.5MB | 303ms | 20ms | node 16.19.0 |
javascript | 1.js | 286ms | 5.2ms | 103.2MB | 300ms | 20ms | bun 0.5.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 455ms | 3.5ms | 98.1MB | 427ms | 23ms | bun 0.5.5 |
javascript | 1.js | 475ms | 4.1ms | 60.0MB | 497ms | 17ms | node 19.6.0 |
wasm | 1.rs | 565ms | 4.5ms | 16.2MB | 550ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 707ms | 1.8ms | 12.3MB | 693ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 776ms | 3.6ms | 49.5MB | 810ms | 23ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 153ms | 1.8ms | 15.5MB | 140ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 186ms | 0.7ms | 11.5MB | 173ms | 0ms | wasmtime 5.0.0 |
javascript | 1.js | 220ms | 4.3ms | 52.6MB | 233ms | 10ms | node 19.6.0 |
wasm | 1.rs | 312ms | 9.8ms | 49.6MB | 360ms | 13ms | node 16.19.0 |
javascript | 1.js | 912ms | 14ms | 82.5MB | 873ms | 23ms | bun 0.5.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 8.0ms | 1.2ms | 9.2MB | 0ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 8.7ms | 0.8ms | 16.1MB | 0ms | 0ms | wasmedgec 0.11.2 |
javascript | 1.js | 20ms | 1.3ms | 54.3MB | 3ms | 7ms | bun 0.5.5 |
javascript | 1.js | 56ms | 5.4ms | 42.8MB | 34ms | 10ms | node 19.6.0 |
wasm | 1.rs | 96ms | 4.6ms | 43.5MB | 110ms | 4ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.bun.js | 160ms | 17ms | 89.5MB | 90ms | 80ms | bun 0.5.5 |
javascript | 1.js | 2818ms | 2441ms | 154.5MB | 2333ms | 520ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.bun.js | 108ms | 7.3ms | 74.1MB | 30ms | 43ms | bun 0.5.5 |
javascript | 1.js | 480ms | 18ms | 69.5MB | 453ms | 110ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 166ms | 1.7ms | 91.8MB | 137ms | 17ms | bun 0.5.5 |
javascript | 1.js | 208ms | 11ms | 76.1MB | 190ms | 17ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 945ms | 16ms | 252.9MB | 910ms | 73ms | bun 0.5.5 |
javascript | 1.js | 1405ms | 13ms | 282.5MB | 1377ms | 137ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 185ms | 0.4ms | 15.7MB | 170ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 230ms | 3.2ms | 11.2MB | 213ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 314ms | 3.7ms | 44.8MB | 323ms | 3ms | node 16.19.0 |
javascript | 2.js | 442ms | 6.6ms | 54.8MB | 420ms | 13ms | node 19.6.0 |
javascript | 1.js | 759ms | 10ms | 148.3MB | 750ms | 37ms | bun 0.5.5 |
javascript | 2.js | 810ms | 3.7ms | 109.9MB | 807ms | 33ms | bun 0.5.5 |
javascript | 1.js | 1210ms | 9.1ms | 62.3MB | 1187ms | 17ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 539ms | 1.4ms | 16.2MB | 523ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 665ms | 1.8ms | 11.2MB | 650ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 738ms | 4.8ms | 44.5MB | 750ms | 10ms | node 16.19.0 |
javascript | 2.js | 1163ms | 6.2ms | 62.2MB | 1143ms | 17ms | node 19.6.0 |
javascript | 1.js | 2115ms | 31ms | 176.2MB | 2150ms | 47ms | bun 0.5.5 |
javascript | 2.js | 2310ms | 31ms | 117.3MB | 2307ms | 33ms | bun 0.5.5 |
javascript | 1.js | 3468ms | 2.2ms | 62.0MB | 3437ms | 27ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 100ms | 3.4ms | 15.1MB | 87ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 119ms | 1.5ms | 11.1MB | 110ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 212ms | 6.0ms | 44.3MB | 227ms | 3ms | node 16.19.0 |
javascript | 2.js | 236ms | 4.1ms | 49.2MB | 227ms | 7ms | node 19.6.0 |
javascript | 1.js | 395ms | 6.9ms | 117.2MB | 377ms | 27ms | bun 0.5.5 |
javascript | 2.js | 437ms | 11ms | 104.9MB | 437ms | 27ms | bun 0.5.5 |
javascript | 1.js | 465ms | 5.6ms | 50.4MB | 453ms | 10ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 1004ms | 12ms | 159.3MB | 1113ms | 53ms | bun 0.5.5 |
javascript | 1.js | 1062ms | 17ms | 122.8MB | 1087ms | 70ms | node 19.6.0 |
wasm | 1.rs | 1482ms | 1.7ms | 39.6MB | 1460ms | 7ms | wasmedgec 0.11.2 |
wasm | 1.rs | 1650ms | 32ms | 67.5MB | 1647ms | 17ms | node 16.19.0 |
wasm | 1.rs | 1651ms | 19ms | 34.8MB | 1623ms | 10ms | wasmtime 5.0.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 224ms | 5.8ms | 106.4MB | 207ms | 23ms | bun 0.5.5 |
javascript | 1.js | 303ms | 6.8ms | 90.8MB | 283ms | 37ms | node 19.6.0 |
wasm | 1.rs | 323ms | 7.6ms | 21.7MB | 303ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 355ms | 6.4ms | 17.0MB | 337ms | 3ms | wasmtime 5.0.0 |
wasm | 1.rs | 427ms | 4.6ms | 48.9MB | 437ms | 7ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 679ms | 4.2ms | 9.3MB | 663ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 705ms | 9.6ms | 15.0MB | 690ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 779ms | 2.6ms | 47.5MB | 800ms | 15ms | node 16.19.0 |
javascript | 6.js | 827ms | 4.4ms | 47.8MB | 810ms | 3ms | node 19.6.0 |
wasm | 2.rs | 960ms | 16ms | 9.3MB | 950ms | 0ms | wasmtime 5.0.0 |
wasm | 2.rs | 994ms | 3.2ms | 15.3MB | 977ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 1059ms | 0.4ms | 48.8MB | 1073ms | 13ms | node 16.19.0 |
javascript | 6.js | 1241ms | 8.9ms | 69.6MB | 1223ms | 13ms | bun 0.5.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 1.rs | 76ms | 3.4ms | 11.3MB | 63ms | 3ms | wasmtime 5.0.0 |
wasm | 1.rs | 80ms | 1.6ms | 15.3MB | 67ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 110ms | 5.0ms | 15.0MB | 93ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 110ms | 9.3ms | 11.2MB | 93ms | 0ms | wasmtime 5.0.0 |
javascript | 6.js | 136ms | 2.8ms | 48.2MB | 123ms | 7ms | node 19.6.0 |
javascript | 6.js | 152ms | 0.7ms | 68.3MB | 140ms | 10ms | bun 0.5.5 |
wasm | 1.rs | 183ms | 5.6ms | 48.1MB | 200ms | 13ms | node 16.19.0 |
wasm | 2.rs | 219ms | 7.2ms | 48.7MB | 240ms | 13ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 0.rs | 455ms | 4.4ms | 15.4MB | 440ms | 0ms | wasmedgec 0.11.2 |
wasm | 0.rs | 514ms | 2.2ms | 9.6MB | 500ms | 0ms | wasmtime 5.0.0 |
wasm | 0.rs | 539ms | 4.1ms | 47.3MB | 567ms | 10ms | node 16.19.0 |
javascript | 1.js | 4510ms | 47ms | 105.1MB | 4533ms | 37ms | bun 0.5.5 |
javascript | 1.js | 4699ms | 15ms | 51.8MB | 4707ms | 13ms | node 19.6.0 |
wasm | 1.rs | timeout | 0.0ms | 58.8MB | 5047ms | 20ms | node 16.19.0 |
wasm | 1.rs | timeout | 0.0ms | 16.5MB | 4977ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | timeout | 0.0ms | 11.2MB | 4983ms | 0ms | wasmtime 5.0.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 0.rs | 126ms | 2.2ms | 16.0MB | 110ms | 0ms | wasmedgec 0.11.2 |
wasm | 0.rs | 136ms | 2.1ms | 11.0MB | 123ms | 0ms | wasmtime 5.0.0 |
wasm | 0.rs | 230ms | 4.1ms | 47.0MB | 247ms | 17ms | node 16.19.0 |
javascript | 1.js | 1160ms | 6.5ms | 103.2MB | 1167ms | 27ms | bun 0.5.5 |
javascript | 1.js | 1230ms | 5.1ms | 50.5MB | 1220ms | 17ms | node 19.6.0 |
wasm | 1.rs | 1299ms | 17ms | 15.6MB | 1283ms | 0ms | wasmedgec 0.11.2 |
wasm | 1.rs | 1498ms | 4.1ms | 10.2MB | 1477ms | 0ms | wasmtime 5.0.0 |
wasm | 1.rs | 1548ms | 23ms | 56.2MB | 1583ms | 30ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 2934ms | 12ms | 17.6MB | 2917ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 3366ms | 6.9ms | 11.8MB | 3347ms | 0ms | wasmtime 5.0.0 |
wasm | 2.rs | 3692ms | 11ms | 49.2MB | 3730ms | 17ms | node 16.19.0 |
javascript | 3.js | timeout | 0.0ms | 79.2MB | 4967ms | 37ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 699ms | 5.8ms | 16.4MB | 683ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 813ms | 19ms | 11.3MB | 797ms | 0ms | wasmtime 5.0.0 |
wasm | 2.rs | 979ms | 9.6ms | 48.3MB | 1023ms | 17ms | node 16.19.0 |
javascript | 3.js | 1874ms | 6.6ms | 63.4MB | 1860ms | 17ms | node 19.6.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 6-m.js | 3350ms | 43ms | 69.2MB | 6290ms | 47ms | node 19.6.0 |
wasm | 2.rs | 4361ms | 1.2ms | 16.2MB | 4340ms | 0ms | wasmedgec 0.11.2 |
wasm | 7.rs | 4413ms | 17ms | 16.7MB | 4397ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 4746ms | 106ms | 11.3MB | 4730ms | 0ms | wasmtime 5.0.0 |
wasm | 7.rs | 4837ms | 3.6ms | 11.3MB | 4820ms | 0ms | wasmtime 5.0.0 |
wasm | 2.rs | timeout | 0.0ms | 48.6MB | 5023ms | 10ms | node 16.19.0 |
wasm | 7.rs | timeout | 0.0ms | 48.8MB | 5027ms | 3ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 6-m.js | 1043ms | 7.9ms | 71.9MB | 1807ms | 37ms | node 19.6.0 |
wasm | 2.rs | 1104ms | 4.3ms | 16.1MB | 1087ms | 0ms | wasmedgec 0.11.2 |
wasm | 7.rs | 1124ms | 18ms | 16.2MB | 1107ms | 0ms | wasmedgec 0.11.2 |
wasm | 7.rs | 1216ms | 1.7ms | 11.2MB | 1200ms | 0ms | wasmtime 5.0.0 |
wasm | 2.rs | 1216ms | 4.6ms | 11.3MB | 1200ms | 0ms | wasmtime 5.0.0 |
wasm | 7.rs | 1349ms | 9.2ms | 48.8MB | 1373ms | 3ms | node 16.19.0 |
wasm | 2.rs | 1423ms | 11ms | 48.6MB | 1450ms | 7ms | node 16.19.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
wasm | 2.rs | 286ms | 2.0ms | 15.9MB | 270ms | 0ms | wasmedgec 0.11.2 |
wasm | 7.rs | 299ms | 4.2ms | 15.3MB | 280ms | 0ms | wasmedgec 0.11.2 |
wasm | 2.rs | 311ms | 1.3ms | 11.4MB | 297ms | 0ms | wasmtime 5.0.0 |
wasm | 7.rs | 317ms | 9.7ms | 9.5MB | 300ms | 0ms | wasmtime 5.0.0 |
wasm | 7.rs | 438ms | 5.9ms | 48.9MB | 460ms | 10ms | node 16.19.0 |
wasm | 2.rs | 454ms | 13ms | 48.2MB | 467ms | 20ms | node 16.19.0 |
javascript | 6.js | 467ms | 9.8ms | 67.2MB | 650ms | 23ms | node 19.6.0 |