Current benchmark data was generated on Tue Mar 25 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 |
---|---|---|---|---|---|---|---|
kotlin | 1.kt | 482ms | 0.5ms | 578.0MB | 560ms | 90ms | kotlin/jvm 21 |
rust | 4.rs | 1295ms | 3.8ms | 33.6MB | 1273ms | 10ms | rustc 1.85.1 |
rust | 5.rs | 1401ms | 21ms | 33.8MB | 1377ms | 7ms | rustc 1.85.1 |
rust | 3.rs | 1556ms | 12ms | 49.8MB | 1523ms | 20ms | rustc 1.85.1 |
kotlin | 1-m.kt | 3201ms | 42ms | 246.5MB | 5153ms | 850ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
kotlin | 1.kt | 107ms | 0.7ms | 160.3MB | 117ms | 27ms | kotlin/jvm 21 |
rust | 4.rs | 123ms | 2.5ms | 5.8MB | 113ms | 0ms | rustc 1.85.1 |
rust | 5.rs | 127ms | 3.9ms | 5.8MB | 117ms | 0ms | rustc 1.85.1 |
rust | 3.rs | 136ms | 2.8ms | 7.8MB | 123ms | 0ms | rustc 1.85.1 |
kotlin | 1-m.kt | 283ms | 2.6ms | 30.5MB | 453ms | 67ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 3-m.rs | 581ms | 48ms | 9.3MB | 2187ms | 73ms | rustc 1.85.1 |
rust | 5-m.rs | 617ms | 62ms | 5.6MB | 2333ms | 63ms | rustc 1.85.1 |
rust | 1-m.rs | 957ms | 7.3ms | 8.4MB | 3493ms | 230ms | rustc 1.85.1 |
rust | 3.rs | 1163ms | 33ms | 9.3MB | 1117ms | 30ms | rustc 1.85.1 |
rust | 4.rs | 1886ms | 1.9ms | 7.4MB | 1870ms | 0ms | rustc 1.85.1 |
kotlin | 2-m.kt | 1971ms | 329ms | 240.9MB | 7313ms | 117ms | kotlin/jvm 21 |
kotlin | 1.kt | 2173ms | 16ms | 221.5MB | 2997ms | 77ms | kotlin/jvm 21 |
kotlin | 1.kt | timeout | 0.0ms | 12.7MB | 5997ms | 487ms | kotlin/native 1.8.21 |
kotlin | 2-m.kt | timeout | 0.0ms | 69.6MB | 19047ms | 153ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-m.rs | 54ms | 1.7ms | 3.3MB | 163ms | 13ms | rustc 1.85.1 |
rust | 3-m.rs | 59ms | 1.8ms | 4.1MB | 187ms | 10ms | rustc 1.85.1 |
rust | 3.rs | 72ms | 1.0ms | 4.0MB | 60ms | 0ms | rustc 1.85.1 |
rust | 1-m.rs | 73ms | 0.5ms | 3.9MB | 233ms | 23ms | rustc 1.85.1 |
rust | 4.rs | 119ms | 3.2ms | 3.3MB | 110ms | 0ms | rustc 1.85.1 |
kotlin | 2-m.kt | 432ms | 2.7ms | 14.5MB | 1600ms | 20ms | kotlin/native 1.8.21 |
kotlin | 1-m.kt | 468ms | 13ms | 76.2MB | 1060ms | 43ms | kotlin/jvm 21 |
kotlin | 1.kt | 689ms | 14ms | 8.8MB | 817ms | 63ms | kotlin/native 1.8.21 |
kotlin | 2-m.kt | 815ms | 9.7ms | 96.8MB | 2827ms | 77ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1.rs | 1.2ms | 0.1ms | 1.8MB | 0ms | 0ms | rustc 1.85.1 |
rust | 1.rs | 1.4ms | 0.2ms | 1.9MB | 0ms | 0ms | rustc 1.87.0-nightly |
kotlin | 1.kt | 2.2ms | 0.4ms | 2.6MB | 0ms | 0ms | kotlin/native 1.8.21 |
kotlin | 1.kt | 59ms | 4.0ms | 47.2MB | 56ms | 16ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1-m.rs | 304ms | 70ms | 74.8MB | 180ms | 497ms | rustc 1.85.1 |
rust | 2-m.rs | 375ms | 8.8ms | 73.4MB | 257ms | 893ms | rustc 1.85.1 |
rust | 2-http2.rs | 394ms | 102ms | 57.0MB | 917ms | 383ms | rustc 1.85.1 |
rust | 1-http2.rs | 565ms | 74ms | 61.6MB | 1280ms | 690ms | rustc 1.85.1 |
kotlin | 2-m.kt | 4877ms | 110ms | 433.3MB | 14973ms | 2650ms | kotlin/jvm 21 |
kotlin | 1.kt | timeout | 0.0ms | 400.8MB | 16150ms | 2810ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1-m.rs | 38ms | 3.0ms | 13.4MB | 17ms | 57ms | rustc 1.85.1 |
rust | 2-m.rs | 88ms | 11ms | 24.4MB | 40ms | 173ms | rustc 1.85.1 |
rust | 2-http2.rs | 208ms | 35ms | 26.0MB | 497ms | 190ms | rustc 1.85.1 |
rust | 1-http2.rs | 254ms | 38ms | 29.0MB | 667ms | 220ms | rustc 1.85.1 |
kotlin | 1-m.kt | 2051ms | 215ms | 216.8MB | 5830ms | 630ms | kotlin/jvm 21 |
kotlin | 2-m.kt | 2169ms | 316ms | 243.8MB | 3967ms | 420ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-i.rs | 29ms | 1.6ms | 9.8MB | 17ms | 0ms | rustc 1.85.1 |
rust | 4-i.rs | 32ms | 1.5ms | 7.9MB | 20ms | 0ms | rustc 1.85.1 |
rust | 3.rs | 62ms | 0.3ms | 32.0MB | 40ms | 10ms | rustc 1.85.1 |
rust | 2.rs | 62ms | 1.2ms | 33.8MB | 40ms | 10ms | rustc 1.85.1 |
rust | 1.rs | 104ms | 0.3ms | 67.4MB | 60ms | 30ms | rustc 1.85.1 |
kotlin | 1-m.kt | 860ms | 106ms | 201.0MB | 2313ms | 90ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 5-i.rs | 210ms | 1.7ms | 52.6MB | 187ms | 7ms | rustc 1.85.1 |
rust | 4-i.rs | 261ms | 0.4ms | 54.4MB | 207ms | 40ms | rustc 1.85.1 |
rust | 2.rs | 409ms | 2.3ms | 237.6MB | 303ms | 93ms | rustc 1.85.1 |
rust | 3.rs | 409ms | 4.0ms | 237.6MB | 303ms | 90ms | rustc 1.85.1 |
rust | 1.rs | 703ms | 3.1ms | 550.2MB | 450ms | 240ms | rustc 1.85.1 |
kotlin | 1-m.kt | 2344ms | 51ms | 740.7MB | 5013ms | 167ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 0-unsafe.rs | 42ms | 4.5ms | 1.8MB | 37ms | 0ms | rustc 1.85.1 |
rust | 1.rs | 52ms | 8.0ms | 2.0MB | 47ms | 0ms | rustc 1.85.1 |
kotlin | 1-m.kt | 181ms | 4.2ms | 96.8MB | 300ms | 27ms | kotlin/jvm 21 |
kotlin | 2-m.kt | 198ms | 2.0ms | 103.5MB | 420ms | 40ms | kotlin/jvm 21 |
kotlin | 2.kt | 310ms | 2.1ms | 5.9MB | 433ms | 20ms | kotlin/native 1.8.21 |
kotlin | 1.kt | 518ms | 11ms | 5.8MB | 620ms | 3ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 0-unsafe.rs | 143ms | 14ms | 1.9MB | 137ms | 0ms | rustc 1.85.1 |
rust | 1.rs | 193ms | 34ms | 2.0MB | 183ms | 0ms | rustc 1.85.1 |
kotlin | 2-m.kt | 307ms | 3.5ms | 215.7MB | 537ms | 43ms | kotlin/jvm 21 |
kotlin | 1.kt | 335ms | 2.6ms | 204.7MB | 443ms | 43ms | kotlin/jvm 21 |
kotlin | 2.kt | 927ms | 16ms | 7.1MB | 1330ms | 50ms | kotlin/native 1.8.21 |
kotlin | 1.kt | 1539ms | 8.4ms | 5.8MB | 1870ms | 23ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 0-unsafe.rs | 26ms | 0.9ms | 1.8MB | 20ms | 0ms | rustc 1.85.1 |
rust | 1.rs | 29ms | 0.1ms | 1.8MB | 20ms | 0ms | rustc 1.85.1 |
kotlin | 2.kt | 142ms | 1.4ms | 3.6MB | 200ms | 0ms | kotlin/native 1.8.21 |
kotlin | 1-m.kt | 142ms | 1.4ms | 92.3MB | 267ms | 30ms | kotlin/jvm 21 |
kotlin | 2-m.kt | 153ms | 3.2ms | 95.8MB | 303ms | 30ms | kotlin/jvm 21 |
kotlin | 1.kt | 171ms | 1.8ms | 3.8MB | 217ms | 0ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4-i.rs | 168ms | 2.2ms | 1.9MB | 160ms | 0ms | rustc 1.85.1 |
rust | 7-i.rs | 238ms | 0.9ms | 1.9MB | 230ms | 0ms | rustc 1.85.1 |
rust | 1.rs | 240ms | 0.8ms | 1.8MB | 230ms | 0ms | rustc 1.85.1 |
rust | 3.rs | 280ms | 0.4ms | 1.8MB | 270ms | 0ms | rustc 1.87.0-nightly |
rust | 2.rs | 288ms | 8.0ms | 1.6MB | 277ms | 0ms | rustc 1.85.1 |
kotlin | 1n.kt | 404ms | 1.3ms | 2.5MB | 393ms | 0ms | kotlin/native 1.8.21 |
kotlin | 1.kt | 453ms | 4.2ms | 49.4MB | 497ms | 20ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4-i.rs | 19ms | 0.3ms | 1.8MB | 10ms | 0ms | rustc 1.85.1 |
rust | 7-i.rs | 26ms | 0.2ms | 1.8MB | 20ms | 0ms | rustc 1.85.1 |
rust | 1.rs | 26ms | 0.3ms | 1.9MB | 20ms | 0ms | rustc 1.85.1 |
rust | 3.rs | 30ms | 0.1ms | 1.8MB | 20ms | 0ms | rustc 1.87.0-nightly |
rust | 2.rs | 30ms | 0.7ms | 1.8MB | 20ms | 0ms | rustc 1.85.1 |
kotlin | 1n.kt | 44ms | 0.5ms | 2.5MB | 37ms | 0ms | kotlin/native 1.8.21 |
kotlin | 1.kt | 123ms | 1.5ms | 49.5MB | 170ms | 13ms | kotlin/jvm 21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1.rs | 1529ms | 3.0ms | 2.7MB | 1307ms | 203ms | rustc 1.85.1 |
rust | 2.rs | 1714ms | 6.0ms | 2.7MB | 1623ms | 80ms | rustc 1.85.1 |
kotlin | 1.kt | 3765ms | 63ms | 355.2MB | 4593ms | 107ms | kotlin/jvm 21 |
kotlin | 1n.kt | timeout | 0.0ms | 5.4MB | 6277ms | 300ms | kotlin/native 1.8.21 |
kotlin | 2n.kt | timeout | 0.0ms | 6.3MB | 4990ms | 180ms | kotlin/native 1.8.21 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1.rs | 324ms | 4.0ms | 2.4MB | 297ms | 10ms | rustc 1.85.1 |
rust | 2.rs | 382ms | 2.4ms | 2.4MB | 370ms | 0ms | rustc 1.85.1 |
kotlin | 1-m.kt | 1000ms | 30ms | 355.3MB | 1780ms | 93ms | kotlin/jvm 21 |
kotlin | 1n.kt | timeout | 0.0ms | 5.4MB | 6287ms | 287ms | kotlin/native 1.8.21 |
kotlin | 2n.kt | timeout | 0.0ms | 6.2MB | 5010ms | 157ms | kotlin/native 1.8.21 |