Current benchmark data was generated on Thu May 01 2025, 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 |
---|---|---|---|---|---|---|---|
rust | 4-i.rs | 166ms | 3.7ms | 1.9MB | 157ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 238ms | 0.2ms | 1.8MB | 230ms | 0ms | rustc 1.86.0 |
rust | 7-i.rs | 239ms | 2.5ms | 1.8MB | 230ms | 0ms | rustc 1.86.0 |
rust | 3.rs | 279ms | 1.0ms | 1.8MB | 270ms | 0ms | rustc 1.88.0-nightly |
rust | 2.rs | 284ms | 1.0ms | 1.6MB | 273ms | 0ms | rustc 1.86.0 |
ocaml | 1.ml | 372ms | 2.6ms | 5.2MB | 363ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4-i.rs | 18ms | 0.1ms | 1.8MB | 10ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 26ms | 0.2ms | 1.9MB | 20ms | 0ms | rustc 1.86.0 |
rust | 7-i.rs | 26ms | 0.1ms | 1.9MB | 20ms | 0ms | rustc 1.86.0 |
rust | 3.rs | 30ms | 0.1ms | 1.8MB | 20ms | 0ms | rustc 1.88.0-nightly |
rust | 2.rs | 31ms | 0.1ms | 1.6MB | 20ms | 0ms | rustc 1.86.0 |
ocaml | 1.ml | 40ms | 0.0ms | 5.3MB | 30ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 8-m.rs | 492ms | 0.2ms | 2.5MB | 1903ms | 3ms | rustc 1.88.0-nightly |
rust | 7-m.rs | 501ms | 0.3ms | 2.1MB | 1940ms | 0ms | rustc 1.86.0 |
rust | 8.rs | 992ms | 0.2ms | 2.5MB | 980ms | 0ms | rustc 1.88.0-nightly |
rust | 2-m.rs | 1958ms | 7.1ms | 2.3MB | 7653ms | 3ms | rustc 1.86.0 |
rust | 7.rs | 2070ms | 8.8ms | 1.9MB | 2060ms | 0ms | rustc 1.86.0 |
rust | 2.rs | 4205ms | 2.7ms | 2.0MB | 4197ms | 0ms | rustc 1.86.0 |
ocaml | 2.ml | 4563ms | 8.7ms | 6.4MB | 4553ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 8-m.rs | 127ms | 0.7ms | 2.3MB | 467ms | 3ms | rustc 1.88.0-nightly |
rust | 7-m.rs | 129ms | 0.3ms | 2.3MB | 477ms | 3ms | rustc 1.86.0 |
rust | 8.rs | 251ms | 1.3ms | 2.1MB | 240ms | 0ms | rustc 1.88.0-nightly |
rust | 2-m.rs | 492ms | 0.4ms | 2.3MB | 1903ms | 3ms | rustc 1.86.0 |
rust | 7.rs | 517ms | 2.2ms | 1.9MB | 510ms | 0ms | rustc 1.86.0 |
rust | 2.rs | 1053ms | 0.4ms | 2.0MB | 1043ms | 0ms | rustc 1.86.0 |
ocaml | 2.ml | 1146ms | 6.2ms | 6.1MB | 1137ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 8-m.rs | 35ms | 0.0ms | 2.1MB | 110ms | 0ms | rustc 1.88.0-nightly |
rust | 7-m.rs | 36ms | 0.1ms | 2.1MB | 113ms | 0ms | rustc 1.86.0 |
rust | 8.rs | 65ms | 0.1ms | 2.0MB | 60ms | 0ms | rustc 1.88.0-nightly |
rust | 2-m.rs | 127ms | 0.2ms | 2.1MB | 470ms | 0ms | rustc 1.86.0 |
rust | 7.rs | 133ms | 2.9ms | 1.8MB | 123ms | 0ms | rustc 1.86.0 |
rust | 2.rs | 266ms | 1.6ms | 2.0MB | 257ms | 0ms | rustc 1.86.0 |
ocaml | 2.ml | 293ms | 2.5ms | 5.2MB | 283ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4.rs | 1262ms | 11ms | 33.8MB | 1240ms | 10ms | rustc 1.86.0 |
rust | 5.rs | 1330ms | 3.4ms | 33.8MB | 1307ms | 13ms | rustc 1.86.0 |
rust | 3.rs | 1471ms | 55ms | 49.8MB | 1440ms | 17ms | rustc 1.86.0 |
ocaml | 1.ml | 3316ms | 13ms | 157.1MB | 3237ms | 67ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 3-m.rs | 536ms | 39ms | 9.1MB | 2017ms | 67ms | rustc 1.86.0 |
rust | 5-m.rs | 631ms | 109ms | 5.8MB | 2383ms | 60ms | rustc 1.86.0 |
rust | 1-m.rs | 929ms | 2.1ms | 7.3MB | 3410ms | 223ms | rustc 1.86.0 |
rust | 3.rs | 1120ms | 2.0ms | 9.3MB | 1080ms | 27ms | rustc 1.86.0 |
rust | 4.rs | 1843ms | 14ms | 6.9MB | 1833ms | 0ms | rustc 1.86.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-m.rs | 54ms | 1.6ms | 3.5MB | 163ms | 10ms | rustc 1.86.0 |
rust | 3-m.rs | 57ms | 2.5ms | 4.3MB | 183ms | 7ms | rustc 1.86.0 |
rust | 3.rs | 71ms | 1.8ms | 4.0MB | 60ms | 0ms | rustc 1.86.0 |
rust | 1-m.rs | 72ms | 0.4ms | 3.5MB | 223ms | 27ms | rustc 1.86.0 |
rust | 4.rs | 114ms | 2.2ms | 3.1MB | 107ms | 0ms | rustc 1.86.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 3-im.rs | 410ms | 1.6ms | 2.0MB | 1577ms | 0ms | rustc 1.86.0 |
rust | 5-m.rs | 570ms | 3.6ms | 2.1MB | 2180ms | 0ms | rustc 1.86.0 |
rust | 2-im.rs | 631ms | 5.8ms | 2.0MB | 2437ms | 0ms | rustc 1.86.0 |
rust | 1-m.rs | 973ms | 3.3ms | 2.1MB | 3763ms | 0ms | rustc 1.86.0 |
rust | 3-i.rs | 1500ms | 0.7ms | 1.9MB | 1490ms | 0ms | rustc 1.86.0 |
rust | 2-i.rs | 1768ms | 1.0ms | 1.8MB | 1760ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 2689ms | 13ms | 1.8MB | 2683ms | 0ms | rustc 1.86.0 |
ocaml | 2.ml | 2912ms | 1.6ms | 4.9MB | 2900ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 3-im.rs | 38ms | 0.3ms | 2.0MB | 123ms | 0ms | rustc 1.86.0 |
rust | 5-m.rs | 53ms | 0.5ms | 2.1MB | 170ms | 0ms | rustc 1.86.0 |
rust | 2-im.rs | 59ms | 1.0ms | 2.1MB | 200ms | 0ms | rustc 1.86.0 |
rust | 1-m.rs | 86ms | 2.3ms | 2.1MB | 300ms | 0ms | rustc 1.86.0 |
rust | 3-i.rs | 124ms | 0.1ms | 1.9MB | 120ms | 0ms | rustc 1.86.0 |
rust | 2-i.rs | 150ms | 0.3ms | 1.8MB | 140ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 229ms | 0.6ms | 1.8MB | 220ms | 0ms | rustc 1.86.0 |
ocaml | 2.ml | 244ms | 1.2ms | 4.9MB | 237ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5c-m.rs | 88ms | 0.2ms | 3.2MB | 247ms | 0ms | rustc 1.86.0 |
rust | 5-m.rs | 91ms | 1.2ms | 3.2MB | 273ms | 0ms | rustc 1.86.0 |
rust | 6.rs | 143ms | 0.1ms | 1.9MB | 133ms | 0ms | rustc 1.86.0 |
rust | 1c.rs | 163ms | 0.6ms | 1.8MB | 150ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 194ms | 1.0ms | 2.0MB | 187ms | 0ms | rustc 1.86.0 |
ocaml | 6.ml | 345ms | 1.2ms | 24.8MB | 330ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-m.rs | 16ms | 0.2ms | 3.2MB | 30ms | 0ms | rustc 1.86.0 |
rust | 5c-m.rs | 16ms | 0.5ms | 3.2MB | 20ms | 0ms | rustc 1.86.0 |
rust | 6.rs | 17ms | 0.2ms | 1.9MB | 10ms | 0ms | rustc 1.86.0 |
rust | 1c.rs | 19ms | 0.2ms | 1.9MB | 10ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 22ms | 0.4ms | 1.9MB | 10ms | 0ms | rustc 1.86.0 |
ocaml | 6.ml | 38ms | 0.9ms | 7.5MB | 30ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1-m.rs | 341ms | 25ms | 86.5MB | 167ms | 537ms | rustc 1.86.0 |
rust | 2-http2.rs | 380ms | 116ms | 58.1MB | 863ms | 420ms | rustc 1.86.0 |
rust | 2-m.rs | 408ms | 17ms | 74.1MB | 240ms | 863ms | rustc 1.86.0 |
rust | 1-http2.rs | 781ms | 162ms | 68.1MB | 2147ms | 687ms | rustc 1.86.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1-m.rs | 48ms | 1.8ms | 15.8MB | 13ms | 73ms | rustc 1.86.0 |
rust | 2-m.rs | 79ms | 2.0ms | 21.1MB | 37ms | 163ms | rustc 1.86.0 |
rust | 1-http2.rs | 227ms | 53ms | 27.1MB | 590ms | 193ms | rustc 1.86.0 |
rust | 2-http2.rs | 230ms | 60ms | 28.9MB | 603ms | 187ms | rustc 1.86.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-i.rs | 29ms | 1.5ms | 9.8MB | 17ms | 0ms | rustc 1.86.0 |
rust | 4-i.rs | 31ms | 1.5ms | 7.9MB | 20ms | 0ms | rustc 1.86.0 |
rust | 3.rs | 61ms | 2.6ms | 32.0MB | 40ms | 10ms | rustc 1.86.0 |
rust | 2.rs | 62ms | 2.6ms | 33.8MB | 40ms | 10ms | rustc 1.86.0 |
rust | 1.rs | 100ms | 1.5ms | 67.4MB | 57ms | 30ms | rustc 1.86.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-i.rs | 211ms | 3.5ms | 53.3MB | 190ms | 10ms | rustc 1.86.0 |
rust | 4-i.rs | 259ms | 3.8ms | 53.7MB | 203ms | 43ms | rustc 1.86.0 |
rust | 3.rs | 405ms | 1.1ms | 237.8MB | 303ms | 90ms | rustc 1.86.0 |
rust | 2.rs | 413ms | 5.8ms | 237.8MB | 307ms | 93ms | rustc 1.86.0 |
rust | 1.rs | 695ms | 12ms | 551.8MB | 450ms | 227ms | rustc 1.86.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 0-unsafe.rs | 41ms | 7.1ms | 1.9MB | 33ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 47ms | 6.4ms | 2.0MB | 40ms | 0ms | rustc 1.86.0 |
ocaml | 1.ml | 180ms | 3.9ms | 6.4MB | 167ms | 0ms | ocaml 5.3.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 2.rs | 324ms | 2.1ms | 6.6MB | 313ms | 0ms | rustc 1.86.0 |
rust | 1.rs | 342ms | 6.1ms | 40.9MB | 327ms | 3ms | rustc 1.86.0 |
ocaml | 1.ml | 955ms | 5.3ms | 552.0MB | 893ms | 43ms | ocaml 5.3.0 |
ocaml | 2.ml | 1880ms | 9.6ms | 17.1MB | 1867ms | 0ms | ocaml 5.3.0 |