Current benchmark data was generated on Sat Jan 28 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 |
---|---|---|---|---|---|---|---|
c | 1.c | 1.7ms | 0.3ms | 1.4MB | 0ms | 0ms | clang 14.0.0 |
c | 1.c | 1.8ms | 0.5ms | 1.3MB | 0ms | 0ms | gcc 12.2.0 |
c | 1.c | 3.4ms | 0.1ms | 0.0MB | 0ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
ruby | 1.rb | 45ms | 2.4ms | 154.4MB | 18ms | 30ms | truffleruby 22.3.1 |
ruby | 1.rb | 72ms | 1.0ms | 32.2MB | 50ms | 10ms | ruby 3.2.0 |
ruby | 1.rb | 77ms | 0.9ms | 32.3MB | 50ms | 12ms | ruby/yjit 3.2.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
ruby | 1.rb | 448ms | 2.7ms | 33.0MB | 420ms | 13ms | ruby/yjit 3.2.0 |
ruby | 1.rb | 602ms | 5.0ms | 32.3MB | 580ms | 3ms | ruby 3.2.0 |
ruby | 1-m.rb | 832ms | 33ms | 335.1MB | 1183ms | 100ms | truffleruby 22.3.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 8-i.c | 315ms | 3.9ms | 1.3MB | 297ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 5.c | 320ms | 0.3ms | 1.3MB | 310ms | 0ms | gcc 12.2.0 |
c | 5.c | 329ms | 1.2ms | 1.0MB | 317ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 5.c | 331ms | 0.2ms | 1.4MB | 320ms | 0ms | clang 14.0.0 |
c | 2.c | 340ms | 2.0ms | 1.2MB | 327ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 2.c | 341ms | 0.6ms | 1.4MB | 330ms | 0ms | clang 14.0.0 |
c | 8-i.c | 365ms | 0.8ms | 1.3MB | 350ms | 0ms | gcc 12.2.0 |
c | 8-i.c | 373ms | 2.0ms | 1.4MB | 360ms | 0ms | clang 14.0.0 |
c | 2.c | 624ms | 0.7ms | 1.3MB | 610ms | 0ms | gcc 12.2.0 |
ruby | 2.rb | 1036ms | 17ms | 305.8MB | 1233ms | 93ms | truffleruby 22.3.1 |
ruby | 2.rb | timeout | 0.0ms | 32.1MB | 4977ms | 7ms | ruby 3.2.0 |
ruby | 2.rb | timeout | 0.0ms | 33.0MB | 4973ms | 10ms | ruby/yjit 3.2.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 8-i.c | 33ms | 0.2ms | 1.3MB | 20ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 5.c | 34ms | 0.3ms | 1.3MB | 23ms | 0ms | gcc 12.2.0 |
c | 5.c | 35ms | 0.2ms | 1.4MB | 27ms | 0ms | clang 14.0.0 |
c | 5.c | 36ms | 0.6ms | 1.0MB | 27ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 2.c | 37ms | 1.2ms | 1.4MB | 30ms | 0ms | clang 14.0.0 |
c | 2.c | 37ms | 1.0ms | 2.0MB | 27ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 8-i.c | 38ms | 0.2ms | 1.3MB | 30ms | 0ms | gcc 12.2.0 |
c | 8-i.c | 40ms | 0.9ms | 1.4MB | 30ms | 0ms | clang 14.0.0 |
c | 2.c | 65ms | 0.4ms | 1.3MB | 53ms | 0ms | gcc 12.2.0 |
ruby | 2-m.rb | 471ms | 46ms | 316.8MB | 680ms | 137ms | truffleruby 22.3.1 |
ruby | 2.rb | 2176ms | 4.7ms | 33.0MB | 2153ms | 7ms | ruby/yjit 3.2.0 |
ruby | 2.rb | 3381ms | 35ms | 32.3MB | 3360ms | 3ms | ruby 3.2.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 1.c | 578ms | 9.5ms | 40.8MB | 553ms | 7ms | clang 14.0.0 |
c | 1.c | 593ms | 23ms | 40.2MB | 570ms | 7ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 1.c | 632ms | 33ms | 41.1MB | 600ms | 13ms | gcc 12.2.0 |
ruby | 1.rb | timeout | 0.0ms | 344.6MB | 4840ms | 133ms | ruby 3.2.0 |
ruby | 1.rb | timeout | 0.0ms | 345.0MB | 4827ms | 150ms | ruby/yjit 3.2.0 |
ruby | 1.rb | timeout | 0.0ms | 685.1MB | 5010ms | 183ms | truffleruby 22.3.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 1.c | 115ms | 1.2ms | 11.4MB | 103ms | 0ms | clang 14.0.0 |
c | 1.c | 119ms | 3.0ms | 11.1MB | 110ms | 0ms | zigcc 0.11.0-dev.1479+97b1a9bb6 |
c | 1.c | 120ms | 2.3ms | 11.8MB | 110ms | 0ms | gcc 12.2.0 |
ruby | 1.rb | 3156ms | 53ms | 419.9MB | 3677ms | 137ms | truffleruby 22.3.1 |
ruby | 1.rb | timeout | 0.0ms | 151.0MB | 4920ms | 53ms | ruby 3.2.0 |
ruby | 1.rb | timeout | 0.0ms | 151.5MB | 4923ms | 57ms | ruby/yjit 3.2.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 4-m.c | 1389ms | 1.4ms | 1.3MB | 2723ms | 0ms | gcc 12.2.0 |
c | 6-im.c | 1613ms | 2.8ms | 1.3MB | 3163ms | 0ms | gcc 12.2.0 |
c | 6-im.c | 1684ms | 16ms | 3.3MB | 3300ms | 0ms | clang 14.0.0 |
c | 4-m.c | 1698ms | 5.3ms | 3.1MB | 3337ms | 0ms | clang 14.0.0 |
c | 5-im.c | 1848ms | 11ms | 1.3MB | 3630ms | 0ms | gcc 12.2.0 |
c | 5-im.c | 2152ms | 3.8ms | 3.2MB | 4233ms | 0ms | clang 14.0.0 |
c | 3-m.c | 2200ms | 14ms | 1.3MB | 4330ms | 0ms | gcc 12.2.0 |
c | 3-m.c | 2210ms | 8.6ms | 3.2MB | 4337ms | 3ms | clang 14.0.0 |
ruby | 4.rb | timeout | 0.0ms | 32.1MB | 4967ms | 13ms | ruby 3.2.0 |
ruby | 4.rb | timeout | 0.0ms | 32.8MB | 4970ms | 13ms | ruby/yjit 3.2.0 |
ruby | 4.rb | timeout | 0.0ms | 566.4MB | 5240ms | 247ms | truffleruby 22.3.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 4-m.c | 357ms | 1.3ms | 1.3MB | 687ms | 0ms | gcc 12.2.0 |
c | 6-im.c | 416ms | 4.5ms | 1.3MB | 793ms | 0ms | gcc 12.2.0 |
c | 6-im.c | 431ms | 2.2ms | 3.1MB | 820ms | 0ms | clang 14.0.0 |
c | 4-m.c | 436ms | 2.6ms | 3.1MB | 837ms | 0ms | clang 14.0.0 |
c | 5-im.c | 472ms | 2.2ms | 1.3MB | 907ms | 0ms | gcc 12.2.0 |
c | 3-m.c | 560ms | 4.0ms | 1.3MB | 1080ms | 0ms | gcc 12.2.0 |
c | 3-m.c | 564ms | 4.7ms | 3.2MB | 1090ms | 0ms | clang 14.0.0 |
c | 5-im.c | 590ms | 76ms | 3.3MB | 1093ms | 0ms | clang 14.0.0 |
ruby | 4.rb | timeout | 0.0ms | 32.2MB | 4973ms | 10ms | ruby 3.2.0 |
ruby | 4.rb | timeout | 0.0ms | 32.8MB | 4973ms | 13ms | ruby/yjit 3.2.0 |
ruby | 4.rb | timeout | 0.0ms | 562.1MB | 5453ms | 223ms | truffleruby 22.3.1 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
c | 4-m.c | 102ms | 3.6ms | 1.3MB | 177ms | 0ms | gcc 12.2.0 |
c | 6-im.c | 112ms | 2.5ms | 1.3MB | 200ms | 0ms | gcc 12.2.0 |
c | 6-im.c | 115ms | 0.2ms | 3.2MB | 203ms | 0ms | clang 14.0.0 |
c | 4-m.c | 119ms | 2.3ms | 3.5MB | 210ms | 0ms | clang 14.0.0 |
c | 5-im.c | 127ms | 0.5ms | 1.3MB | 230ms | 0ms | gcc 12.2.0 |
c | 5-im.c | 147ms | 2.5ms | 3.2MB | 263ms | 3ms | clang 14.0.0 |
c | 3-m.c | 149ms | 1.3ms | 3.3MB | 273ms | 0ms | gcc 12.2.0 |
c | 3-m.c | 150ms | 1.7ms | 3.2MB | 273ms | 0ms | clang 14.0.0 |
ruby | 4.rb | 2585ms | 15ms | 476.7MB | 3107ms | 167ms | truffleruby 22.3.1 |
ruby | 4.rb | timeout | 0.0ms | 32.4MB | 4967ms | 10ms | ruby 3.2.0 |
ruby | 4.rb | timeout | 0.0ms | 32.7MB | 4967ms | 13ms | ruby/yjit 3.2.0 |