Current benchmark data was generated on Sun Dec 01 2024, 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-m.js | 934ms | 12ms | 179.4MB | 1463ms | 247ms | bun 1.1.38 |
javascript | 1-m.js | 1245ms | 11ms | 292.8MB | 2167ms | 173ms | node 23.3.0 |
crystal | 1.cr | 1390ms | 8.4ms | 64.3MB | 1363ms | 7ms | crystal 1.14.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 95ms | 0.9ms | 78.8MB | 67ms | 30ms | bun 1.1.38 |
crystal | 1.cr | 108ms | 0.6ms | 11.1MB | 97ms | 0ms | crystal 1.14.0 |
javascript | 1.js | 124ms | 1.3ms | 82.1MB | 123ms | 20ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 1318ms | 45ms | 20.1MB | 1233ms | 67ms | crystal 1.14.0 |
javascript | 1.js | 1579ms | 4.5ms | 93.9MB | 1667ms | 47ms | node 23.3.0 |
javascript | 1.js | 2164ms | 25ms | 99.8MB | 2190ms | 60ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 77ms | 1.0ms | 7.5MB | 50ms | 13ms | crystal 1.14.0 |
javascript | 1.js | 155ms | 1.6ms | 76.4MB | 140ms | 23ms | node 23.3.0 |
javascript | 1.js | 180ms | 1.0ms | 85.4MB | 213ms | 17ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 60ms | 2.2ms | 6.6MB | 40ms | 10ms | crystal 1.14.0 |
javascript | 1.js | 275ms | 2.6ms | 66.4MB | 273ms | 37ms | node 23.3.0 |
javascript | 1.js | 651ms | 2.3ms | 77.2MB | 620ms | 27ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 23ms | 1.1ms | 5.4MB | 10ms | 0ms | crystal 1.14.0 |
javascript | 1.js | 125ms | 1.1ms | 65.4MB | 143ms | 13ms | node 23.3.0 |
javascript | 1.js | 549ms | 51ms | 67.0MB | 523ms | 20ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 2.1ms | 0.2ms | 3.0MB | 0ms | 0ms | crystal 1.14.0 |
javascript | 1.js | 12ms | 0.4ms | 31.8MB | 0ms | 10ms | bun 1.1.38 |
javascript | 1.js | 31ms | 0.3ms | 51.9MB | 16ms | 4ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1-m.bun.js | 352ms | 14ms | 69.3MB | 150ms | 410ms | bun 1.1.38 |
crystal | 1.cr | 1947ms | 461ms | 187.1MB | 310ms | 500ms | crystal 1.14.0 |
javascript | 1.js | 3204ms | 115ms | 184.7MB | 3040ms | 1450ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.bun.js | 130ms | 10ms | 54.0MB | 43ms | 80ms | bun 1.1.38 |
javascript | 1.js | 397ms | 6.2ms | 85.4MB | 330ms | 133ms | node 23.3.0 |
crystal | 1.cr | 1158ms | 90ms | 66.3MB | 30ms | 90ms | crystal 1.14.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 83ms | 0.8ms | 65.6MB | 53ms | 20ms | bun 1.1.38 |
javascript | 1.js | 131ms | 12ms | 78.8MB | 113ms | 20ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 381ms | 3.3ms | 206.8MB | 340ms | 87ms | bun 1.1.38 |
javascript | 1.js | 750ms | 34ms | 209.9MB | 837ms | 80ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 0-unsafe.cr | 36ms | 1.4ms | 3.1MB | 20ms | 0ms | crystal 1.14.0 |
crystal | 1.cr | 63ms | 1.1ms | 3.1MB | 50ms | 0ms | crystal 1.14.0 |
javascript | 2.js | 307ms | 1.5ms | 66.6MB | 293ms | 17ms | node 23.3.0 |
javascript | 1.js | 556ms | 4.1ms | 64.6MB | 543ms | 7ms | node 23.3.0 |
javascript | 2.js | 654ms | 2.5ms | 122.6MB | 690ms | 73ms | bun 1.1.38 |
javascript | 1.js | 879ms | 2.7ms | 110.8MB | 957ms | 87ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 0-unsafe.cr | 99ms | 0.6ms | 3.1MB | 90ms | 0ms | crystal 1.14.0 |
crystal | 1.cr | 187ms | 1.0ms | 3.3MB | 180ms | 0ms | crystal 1.14.0 |
javascript | 2.js | 850ms | 3.9ms | 71.8MB | 830ms | 23ms | node 23.3.0 |
javascript | 1.js | 1581ms | 2.8ms | 71.0MB | 1560ms | 17ms | node 23.3.0 |
javascript | 2.js | 1821ms | 23ms | 122.0MB | 1977ms | 60ms | bun 1.1.38 |
javascript | 1.js | 2555ms | 37ms | 110.8MB | 2857ms | 143ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 0-unsafe.cr | 19ms | 1.0ms | 3.0MB | 10ms | 0ms | crystal 1.14.0 |
crystal | 1.cr | 30ms | 0.7ms | 3.0MB | 20ms | 0ms | crystal 1.14.0 |
javascript | 2.js | 166ms | 2.5ms | 60.1MB | 163ms | 3ms | node 23.3.0 |
javascript | 1.js | 172ms | 16ms | 61.8MB | 157ms | 10ms | node 23.3.0 |
javascript | 1.js | 323ms | 4.0ms | 119.0MB | 360ms | 73ms | bun 1.1.38 |
javascript | 2.js | 352ms | 4.1ms | 125.4MB | 380ms | 47ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1-m.js | 510ms | 1.8ms | 138.7MB | 657ms | 147ms | bun 1.1.38 |
javascript | 1.js | 538ms | 0.3ms | 134.0MB | 627ms | 60ms | node 23.3.0 |
crystal | 1.cr | 833ms | 8.7ms | 81.7MB | 817ms | 3ms | crystal 1.14.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 124ms | 3.0ms | 86.3MB | 103ms | 37ms | bun 1.1.38 |
javascript | 1.js | 162ms | 1.2ms | 101.8MB | 160ms | 37ms | node 23.3.0 |
crystal | 1.cr | 162ms | 1.4ms | 22.3MB | 147ms | 0ms | crystal 1.14.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 2.cr | 343ms | 1.1ms | 3.4MB | 330ms | 0ms | crystal 1.14.0 |
crystal | 1.cr | 344ms | 2.1ms | 3.4MB | 330ms | 0ms | crystal 1.14.0 |
javascript | 6.js | 460ms | 5.9ms | 59.6MB | 447ms | 7ms | node 23.3.0 |
javascript | 6.js | 672ms | 15ms | 44.9MB | 667ms | 3ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 38ms | 0.8ms | 3.4MB | 30ms | 0ms | crystal 1.14.0 |
crystal | 2.cr | 38ms | 1.0ms | 3.4MB | 27ms | 0ms | crystal 1.14.0 |
javascript | 6.js | 77ms | 1.7ms | 59.5MB | 67ms | 3ms | node 23.3.0 |
javascript | 6.js | 87ms | 1.8ms | 44.9MB | 80ms | 10ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 2575ms | 12ms | 63.5MB | 2577ms | 20ms | node 23.3.0 |
javascript | 1.js | 2795ms | 11ms | 84.3MB | 2807ms | 53ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 1.js | 681ms | 4.2ms | 61.0MB | 683ms | 13ms | node 23.3.0 |
javascript | 1.js | 738ms | 1.4ms | 83.5MB | 747ms | 23ms | bun 1.1.38 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 2001ms | 73ms | 6.4MB | 1963ms | 20ms | crystal 1.14.0 |
javascript | 3.js | 4746ms | 11ms | 91.6MB | 4717ms | 33ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 454ms | 18ms | 5.2MB | 440ms | 0ms | crystal 1.14.0 |
javascript | 3.js | 1029ms | 1.4ms | 74.0MB | 1013ms | 17ms | node 23.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 6-m.js | 2167ms | 20ms | 117.7MB | 8173ms | 63ms | node 23.3.0 |
crystal | 1.cr | 3904ms | 21ms | 4.6MB | 3893ms | 0ms | crystal 1.14.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
javascript | 6-m.js | 643ms | 4.2ms | 117.0MB | 2300ms | 43ms | node 23.3.0 |
crystal | 1.cr | 979ms | 2.1ms | 4.3MB | 967ms | 0ms | crystal 1.14.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 249ms | 2.4ms | 4.0MB | 240ms | 0ms | crystal 1.14.0 |
javascript | 6-m.js | 262ms | 0.7ms | 112.9MB | 813ms | 47ms | node 23.3.0 |