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 |
---|---|---|---|---|---|---|---|
rust | 5c-m.rs | 212ms | 1.9ms | 1.7MB | 370ms | 7ms | rustc 1.69.0-nightly |
rust | 5-m.rs | 224ms | 5.8ms | 1.7MB | 400ms | 0ms | rustc 1.67.0 |
go | 3-m.go | 251ms | 0.7ms | 2.9MB | 450ms | 0ms | go 1.19.5 |
rust | 1c.rs | 257ms | 0.4ms | 1.0MB | 247ms | 0ms | rustc 1.69.0-nightly |
rust | 1.rs | 314ms | 1.1ms | 1.0MB | 307ms | 0ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1c.rs | 29ms | 0.8ms | 1.0MB | 20ms | 0ms | rustc 1.69.0-nightly |
go | 3.go | 32ms | 0.4ms | 2.9MB | 40ms | 0ms | go 1.19.5 |
rust | 5-m.rs | 32ms | 0.5ms | 1.7MB | 40ms | 0ms | rustc 1.67.0 |
rust | 5c-m.rs | 33ms | 3.0ms | 1.7MB | 37ms | 3ms | rustc 1.69.0-nightly |
rust | 1.rs | 35ms | 2.0ms | 1.0MB | 23ms | 0ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 9.rs | 435ms | 4.1ms | 4.9MB | 423ms | 0ms | rustc 1.69.0-nightly |
rust | 8.rs | 512ms | 3.2ms | 4.9MB | 497ms | 0ms | rustc 1.67.0 |
go | 1.go | 4741ms | 38ms | 7.4MB | 4710ms | 3ms | go 1.19.5 |
go | 1.go | timeout | 0.0ms | 5.4MB | 4977ms | 0ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4-i.rs | 255ms | 0.3ms | 1.0MB | 237ms | 0ms | rustc 1.67.0 |
rust | 7-i.rs | 376ms | 6.0ms | 1.0MB | 363ms | 0ms | rustc 1.67.0 |
rust | 3.rs | 404ms | 0.9ms | 1.1MB | 390ms | 0ms | rustc 1.69.0-nightly |
rust | 2.rs | 446ms | 30ms | 1.1MB | 433ms | 0ms | rustc 1.67.0 |
rust | 1.rs | 503ms | 8.7ms | 1.1MB | 490ms | 0ms | rustc 1.67.0 |
go | 1.go | 599ms | 3.1ms | 2.9MB | 587ms | 0ms | go 1.19.5 |
go | 1.go | 839ms | 2.3ms | 2.0MB | 830ms | 0ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4-i.rs | 29ms | 0.5ms | 1.0MB | 20ms | 0ms | rustc 1.67.0 |
rust | 7-i.rs | 41ms | 0.3ms | 1.0MB | 30ms | 0ms | rustc 1.67.0 |
rust | 3.rs | 43ms | 0.1ms | 1.0MB | 30ms | 0ms | rustc 1.69.0-nightly |
rust | 2.rs | 45ms | 0.5ms | 1.0MB | 37ms | 0ms | rustc 1.67.0 |
rust | 1.rs | 55ms | 4.2ms | 1.0MB | 43ms | 0ms | rustc 1.67.0 |
go | 1.go | 65ms | 1.5ms | 2.9MB | 50ms | 0ms | go 1.19.5 |
go | 1.go | 84ms | 1.0ms | 0.0MB | 73ms | 0ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 8-m.rs | 1083ms | 2.6ms | 2.5MB | 2073ms | 3ms | rustc 1.69.0-nightly |
rust | 7-m.rs | 1085ms | 14ms | 2.1MB | 2083ms | 0ms | rustc 1.67.0 |
rust | 8.rs | 2075ms | 12ms | 2.4MB | 2067ms | 0ms | rustc 1.69.0-nightly |
rust | 7.rs | 2099ms | 40ms | 2.2MB | 2080ms | 0ms | rustc 1.67.0 |
rust | 2-m.rs | 2234ms | 16ms | 2.3MB | 4307ms | 3ms | rustc 1.67.0 |
go | 4-m.go | 2681ms | 27ms | 4.9MB | 5153ms | 3ms | go 1.19.5 |
go | 1.go | timeout | 0.0ms | 5.4MB | 4983ms | 3ms | go 1.19.5 |
go | 1.go | timeout | 0.0ms | 2.4MB | 4983ms | 0ms | tinygo 0.25.0 |
rust | 2.rs | timeout | 0.0ms | 2.0MB | 4987ms | 0ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 7-m.rs | 280ms | 0.9ms | 1.1MB | 513ms | 0ms | rustc 1.67.0 |
rust | 8-m.rs | 280ms | 2.6ms | 2.2MB | 510ms | 0ms | rustc 1.69.0-nightly |
rust | 7.rs | 523ms | 1.8ms | 1.1MB | 510ms | 0ms | rustc 1.67.0 |
rust | 2-m.rs | 561ms | 0.8ms | 2.1MB | 1063ms | 0ms | rustc 1.67.0 |
rust | 8.rs | 565ms | 14ms | 2.1MB | 553ms | 0ms | rustc 1.69.0-nightly |
go | 4-m.go | 674ms | 7.1ms | 3.4MB | 1277ms | 0ms | go 1.19.5 |
go | 1.go | 1330ms | 2.8ms | 2.9MB | 1323ms | 0ms | go 1.19.5 |
rust | 2.rs | 1966ms | 23ms | 1.0MB | 1950ms | 0ms | rustc 1.67.0 |
go | 1.go | timeout | 0.0ms | 0.0MB | 4983ms | 0ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 8-m.rs | 77ms | 1.9ms | 1.1MB | 127ms | 0ms | rustc 1.69.0-nightly |
rust | 7-m.rs | 79ms | 1.6ms | 1.0MB | 123ms | 0ms | rustc 1.67.0 |
rust | 8.rs | 137ms | 2.1ms | 1.1MB | 123ms | 0ms | rustc 1.69.0-nightly |
rust | 7.rs | 138ms | 2.1ms | 1.1MB | 130ms | 0ms | rustc 1.67.0 |
rust | 2-m.rs | 151ms | 2.4ms | 1.0MB | 267ms | 0ms | rustc 1.67.0 |
go | 4-m.go | 182ms | 3.8ms | 2.9MB | 313ms | 0ms | go 1.19.5 |
go | 1.go | 336ms | 2.1ms | 2.9MB | 327ms | 0ms | go 1.19.5 |
rust | 2.rs | 491ms | 0.1ms | 1.0MB | 480ms | 0ms | rustc 1.67.0 |
go | 1.go | 1953ms | 7.3ms | 0.0MB | 1940ms | 0ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4.rs | 2015ms | 13ms | 33.7MB | 1983ms | 13ms | rustc 1.67.0 |
rust | 5.rs | 2208ms | 16ms | 33.7MB | 2180ms | 13ms | rustc 1.67.0 |
rust | 3.rs | 2379ms | 46ms | 49.8MB | 2343ms | 17ms | rustc 1.67.0 |
go | 1.go | 3847ms | 17ms | 45.6MB | 5503ms | 83ms | go 1.19.5 |
go | 1.go | timeout | 0.0ms | 39.4MB | 4970ms | 7ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 4.rs | 179ms | 1.1ms | 5.7MB | 170ms | 0ms | rustc 1.67.0 |
rust | 5.rs | 200ms | 2.5ms | 5.8MB | 183ms | 0ms | rustc 1.67.0 |
rust | 3.rs | 211ms | 2.3ms | 7.7MB | 190ms | 0ms | rustc 1.67.0 |
go | 1.go | 324ms | 2.4ms | 8.3MB | 417ms | 3ms | go 1.19.5 |
go | 1.go | 438ms | 0.7ms | 5.9MB | 423ms | 0ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 1-m.go | 984ms | 210ms | 13.6MB | 1910ms | 0ms | go 1.19.5 |
rust | 3-m.rs | 1161ms | 4.4ms | 6.2MB | 2220ms | 23ms | rustc 1.67.0 |
rust | 5-m.rs | 1222ms | 11ms | 4.4MB | 2347ms | 30ms | rustc 1.67.0 |
go | 1.go | 2170ms | 13ms | 256.7MB | 2087ms | 63ms | tinygo 0.25.0 |
rust | 3.rs | 2254ms | 3.6ms | 6.2MB | 2200ms | 37ms | rustc 1.67.0 |
rust | 4.rs | 3557ms | 11ms | 4.5MB | 3540ms | 0ms | rustc 1.67.0 |
rust | 1-m.rs | 3918ms | 52ms | 4.9MB | 7567ms | 110ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 1-m.go | 73ms | 13ms | 5.4MB | 117ms | 0ms | go 1.19.5 |
rust | 3-m.rs | 105ms | 17ms | 2.9MB | 173ms | 7ms | rustc 1.67.0 |
rust | 3.rs | 140ms | 0.7ms | 3.2MB | 127ms | 0ms | rustc 1.67.0 |
rust | 5-m.rs | 141ms | 26ms | 2.7MB | 243ms | 7ms | rustc 1.67.0 |
rust | 4.rs | 235ms | 1.7ms | 2.3MB | 223ms | 0ms | rustc 1.67.0 |
rust | 1-m.rs | 271ms | 6.3ms | 2.9MB | 480ms | 13ms | rustc 1.67.0 |
go | 1.go | 346ms | 2.1ms | 65.6MB | 307ms | 23ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 3-im.rs | 750ms | 1.1ms | 1.0MB | 1453ms | 0ms | rustc 1.67.0 |
rust | 2-im.rs | 1071ms | 12ms | 1.0MB | 2070ms | 0ms | rustc 1.67.0 |
rust | 5-m.rs | 1427ms | 22ms | 1.1MB | 2730ms | 0ms | rustc 1.67.0 |
go | 3-m.go | 1448ms | 2.7ms | 5.0MB | 2787ms | 7ms | go 1.19.5 |
rust | 3-i.rs | 1492ms | 23ms | 1.0MB | 1473ms | 0ms | rustc 1.67.0 |
rust | 2-i.rs | 2205ms | 4.9ms | 1.0MB | 2193ms | 0ms | rustc 1.67.0 |
rust | 1-m.rs | 2866ms | 4.7ms | 1.0MB | 5527ms | 0ms | rustc 1.67.0 |
go | 3.go | 3217ms | 6.8ms | 48.9MB | 3190ms | 7ms | tinygo 0.25.0 |
rust | 1.rs | 4707ms | 34ms | 1.0MB | 4693ms | 0ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 3-im.rs | 70ms | 0.7ms | 1.0MB | 117ms | 0ms | rustc 1.67.0 |
rust | 2-im.rs | 100ms | 3.0ms | 1.1MB | 170ms | 0ms | rustc 1.67.0 |
rust | 5-m.rs | 125ms | 1.7ms | 1.0MB | 220ms | 0ms | rustc 1.67.0 |
rust | 3-i.rs | 126ms | 0.8ms | 1.1MB | 117ms | 0ms | rustc 1.67.0 |
go | 3-m.go | 144ms | 2.5ms | 5.0MB | 220ms | 0ms | go 1.19.5 |
rust | 2-i.rs | 191ms | 8.6ms | 1.1MB | 183ms | 0ms | rustc 1.67.0 |
rust | 1-m.rs | 258ms | 4.6ms | 1.1MB | 453ms | 3ms | rustc 1.67.0 |
go | 3.go | 353ms | 3.4ms | 49.9MB | 333ms | 7ms | tinygo 0.25.0 |
rust | 1.rs | 394ms | 1.2ms | 1.1MB | 383ms | 0ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1.rs | 180ms | 40ms | 31.1MB | 103ms | 113ms | rustc 1.67.0 |
go | 1-http2.go | 207ms | 4.6ms | 58.5MB | 300ms | 50ms | go 1.19.5 |
rust | 2-http2.rs | 476ms | 145ms | 45.3MB | 680ms | 150ms | rustc 1.67.0 |
rust | 2-m.rs | 614ms | 14ms | 105.6MB | 340ms | 603ms | rustc 1.67.0 |
go | 1-m.go | 699ms | 31ms | 164.2MB | 677ms | 470ms | go 1.19.5 |
go | 2-m.go | 837ms | 102ms | 180.4MB | 803ms | 630ms | go 1.19.5 |
rust | 1-http2.rs | 1093ms | 130ms | 68.5MB | 1283ms | 613ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 1-http2.go | 49ms | 1.1ms | 25.1MB | 47ms | 13ms | go 1.19.5 |
rust | 1.rs | 65ms | 31ms | 14.1MB | 10ms | 40ms | rustc 1.67.0 |
go | 2.go | 131ms | 41ms | 39.1MB | 93ms | 50ms | go 1.19.5 |
rust | 2.rs | 137ms | 5.4ms | 22.4MB | 30ms | 107ms | rustc 1.67.0 |
go | 1.go | 157ms | 5.5ms | 37.1MB | 103ms | 90ms | go 1.19.5 |
rust | 2-http2.rs | 353ms | 76ms | 22.7MB | 487ms | 107ms | rustc 1.67.0 |
rust | 1-http2.rs | 457ms | 18ms | 25.5MB | 650ms | 127ms | rustc 1.67.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 2-ffi.go | 83ms | 6.6ms | 42.1MB | 60ms | 17ms | go 1.19.5 |
rust | 2.rs | 96ms | 3.0ms | 38.1MB | 70ms | 10ms | rustc 1.67.0 |
rust | 3.rs | 96ms | 2.4ms | 36.2MB | 73ms | 10ms | rustc 1.67.0 |
rust | 1.rs | 154ms | 1.7ms | 75.4MB | 100ms | 40ms | rustc 1.67.0 |
go | 1.go | 213ms | 3.5ms | 18.8MB | 197ms | 3ms | go 1.19.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 2-ffi.go | 483ms | 20ms | 182.5MB | 440ms | 133ms | go 1.19.5 |
rust | 2.rs | 598ms | 0.3ms | 257.9MB | 460ms | 120ms | rustc 1.67.0 |
rust | 3.rs | 611ms | 20ms | 258.6MB | 460ms | 137ms | rustc 1.67.0 |
rust | 1.rs | 1117ms | 11ms | 605.2MB | 760ms | 340ms | rustc 1.67.0 |
go | 1.go | 1288ms | 8.1ms | 105.2MB | 1253ms | 83ms | go 1.19.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 0-unsafe.rs | 65ms | 6.5ms | 1.8MB | 57ms | 0ms | rustc 1.67.0 |
rust | 1.rs | 90ms | 3.6ms | 2.1MB | 80ms | 0ms | rustc 1.67.0 |
go | 3.go | 195ms | 4.6ms | 0.3MB | 183ms | 0ms | tinygo 0.25.0 |
go | 3.go | 201ms | 2.4ms | 3.4MB | 187ms | 0ms | go 1.19.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 0-unsafe.rs | 258ms | 14ms | 1.1MB | 243ms | 0ms | rustc 1.67.0 |
rust | 1.rs | 369ms | 2.5ms | 1.0MB | 360ms | 0ms | rustc 1.67.0 |
go | 3.go | 566ms | 1.0ms | 0.3MB | 553ms | 0ms | tinygo 0.25.0 |
go | 3.go | 589ms | 3.6ms | 3.4MB | 573ms | 0ms | go 1.19.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1.rs | 1082ms | 5.4ms | 33.7MB | 1050ms | 17ms | rustc 1.67.0 |
go | 1.go | 2523ms | 14ms | 38.2MB | 3530ms | 67ms | go 1.19.5 |
go | 2.go | 2861ms | 21ms | 45.1MB | 4040ms | 80ms | go 1.19.5 |
go | 1.go | 4946ms | 23ms | 212.6MB | 4880ms | 50ms | tinygo 0.25.0 |
go | 2.go | timeout | 0.0ms | 51.3MB | 4973ms | 3ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 1.rs | 226ms | 4.6ms | 9.9MB | 207ms | 0ms | rustc 1.67.0 |
go | 1.go | 535ms | 12ms | 12.1MB | 713ms | 20ms | go 1.19.5 |
go | 2.go | 606ms | 2.8ms | 13.4MB | 837ms | 7ms | go 1.19.5 |
go | 1.go | 864ms | 21ms | 51.9MB | 837ms | 7ms | tinygo 0.25.0 |
go | 2.go | 1659ms | 8.8ms | 39.3MB | 1637ms | 7ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 2.rs | 497ms | 1.2ms | 6.6MB | 480ms | 0ms | rustc 1.67.0 |
go | 2.go | 808ms | 5.4ms | 17.6MB | 793ms | 0ms | tinygo 0.25.0 |
go | 1.go | 986ms | 32ms | 73.7MB | 957ms | 17ms | go 1.19.5 |
go | 1.go | 1060ms | 43ms | 43.8MB | 1027ms | 10ms | tinygo 0.25.0 |
rust | 1.rs | 1080ms | 27ms | 40.8MB | 1050ms | 13ms | rustc 1.67.0 |
go | 2.go | 1095ms | 9.3ms | 20.0MB | 1073ms | 13ms | go 1.19.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
rust | 2.rs | 111ms | 0.5ms | 3.1MB | 100ms | 0ms | rustc 1.67.0 |
go | 1.go | 142ms | 8.0ms | 22.2MB | 120ms | 3ms | go 1.19.5 |
rust | 1.rs | 147ms | 6.8ms | 11.6MB | 133ms | 0ms | rustc 1.67.0 |
go | 1.go | 151ms | 0.6ms | 13.4MB | 140ms | 0ms | tinygo 0.25.0 |
go | 2.go | 198ms | 10ms | 5.6MB | 173ms | 0ms | tinygo 0.25.0 |
go | 2.go | 259ms | 2.0ms | 8.0MB | 250ms | 0ms | go 1.19.5 |