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 |
---|---|---|---|---|---|---|---|
d | 1-im.d | 799ms | 0.9ms | 1.5MB | 1513ms | 0ms | ldc2 1.30.0 |
go | 3-m.go | 1448ms | 2.7ms | 5.0MB | 2787ms | 7ms | go 1.19.5 |
d | 1-i.d | 1483ms | 6.0ms | 1.5MB | 1470ms | 0ms | ldc2 1.30.0 |
d | 2-im.d | 3038ms | 42ms | 1.5MB | 5880ms | 0ms | ldc2 1.30.0 |
go | 3.go | 3217ms | 6.8ms | 48.9MB | 3190ms | 7ms | tinygo 0.25.0 |
d | 1.d | 4796ms | 40ms | 1.5MB | 4780ms | 0ms | ldc2 1.30.0 |
d | 1-i.d | timeout | 0.0ms | 2.2MB | 4983ms | 0ms | dmd 2.102.0 |
d | 1-im.d | timeout | 0.0ms | 2.6MB | 9783ms | 3ms | dmd 2.102.0 |
d | 1.d | timeout | 0.0ms | 2.8MB | 4983ms | 0ms | dmd 2.102.0 |
d | 2-i.d | timeout | 0.0ms | 2.6MB | 4983ms | 0ms | dmd 2.102.0 |
d | 2-im.d | timeout | 0.0ms | 2.7MB | 9860ms | 0ms | dmd 2.102.0 |
d | 2-i.d | timeout | 0.0ms | 1.6MB | 4987ms | 0ms | ldc2 1.30.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
d | 1-im.d | 79ms | 2.1ms | 1.5MB | 120ms | 0ms | ldc2 1.30.0 |
d | 1-i.d | 134ms | 13ms | 1.6MB | 123ms | 0ms | ldc2 1.30.0 |
go | 3-m.go | 144ms | 2.5ms | 5.0MB | 220ms | 0ms | go 1.19.5 |
d | 2-im.d | 272ms | 7.5ms | 1.6MB | 480ms | 0ms | ldc2 1.30.0 |
go | 3.go | 353ms | 3.4ms | 49.9MB | 333ms | 7ms | tinygo 0.25.0 |
d | 1.d | 386ms | 6.0ms | 1.6MB | 377ms | 0ms | ldc2 1.30.0 |
d | 1.d | 420ms | 0.6ms | 2.7MB | 407ms | 0ms | dmd 2.102.0 |
d | 2-i.d | 480ms | 0.4ms | 1.5MB | 470ms | 0ms | ldc2 1.30.0 |
d | 1-im.d | 657ms | 120ms | 2.7MB | 1037ms | 0ms | dmd 2.102.0 |
d | 2-im.d | 923ms | 22ms | 2.9MB | 1730ms | 0ms | dmd 2.102.0 |
d | 1-i.d | 1057ms | 43ms | 2.2MB | 1047ms | 0ms | dmd 2.102.0 |
d | 2-i.d | 1622ms | 10ms | 2.6MB | 1613ms | 0ms | dmd 2.102.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 |
d | 2.d | 87ms | 5.4ms | 15.3MB | 80ms | 3ms | ldc2 1.30.0 |
go | 1.go | 213ms | 3.5ms | 18.8MB | 197ms | 3ms | go 1.19.5 |
d | 2.d | 357ms | 9.7ms | 22.5MB | 347ms | 3ms | dmd 2.102.0 |
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 |
d | 2.d | 700ms | 16ms | 138.1MB | 650ms | 33ms | ldc2 1.30.0 |
go | 1.go | 1288ms | 8.1ms | 105.2MB | 1253ms | 83ms | go 1.19.5 |
d | 2.d | 3745ms | 81ms | 157.5MB | 3750ms | 47ms | dmd 2.102.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
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 |
d | 1.d | 222ms | 5.9ms | 3.7MB | 213ms | 0ms | ldc2 1.30.0 |
d | 1.d | 296ms | 1.2ms | 5.3MB | 283ms | 0ms | dmd 2.102.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
d | 1.d | 1818ms | 21ms | 74.8MB | 1883ms | 23ms | ldc2 1.30.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 |
d | 1.d | 3152ms | 10ms | 153.9MB | 3520ms | 57ms | dmd 2.102.0 |
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 |
---|---|---|---|---|---|---|---|
d | 1.d | 355ms | 8.2ms | 38.9MB | 330ms | 13ms | ldc2 1.30.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 |
d | 1.d | 660ms | 15ms | 40.5MB | 707ms | 10ms | dmd 2.102.0 |
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 |
---|---|---|---|---|---|---|---|
d | 1.d | 542ms | 7.3ms | 1.5MB | 527ms | 0ms | ldc2 1.30.0 |
d | 2.d | 577ms | 7.9ms | 1.5MB | 563ms | 0ms | ldc2 1.30.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 |
d | 1.d | 1466ms | 20ms | 2.6MB | 1453ms | 0ms | dmd 2.102.0 |
d | 2.d | 2593ms | 6.6ms | 2.7MB | 2580ms | 0ms | dmd 2.102.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
d | 1.d | 57ms | 0.4ms | 1.5MB | 50ms | 0ms | ldc2 1.30.0 |
d | 2.d | 60ms | 0.3ms | 1.5MB | 47ms | 0ms | ldc2 1.30.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 |
d | 1.d | 155ms | 4.8ms | 2.6MB | 140ms | 0ms | dmd 2.102.0 |
d | 2.d | 264ms | 4.0ms | 2.6MB | 257ms | 0ms | dmd 2.102.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 2.go | 808ms | 5.4ms | 17.6MB | 793ms | 0ms | tinygo 0.25.0 |
d | 1.d | 942ms | 18ms | 42.5MB | 907ms | 13ms | ldc2 1.30.0 |
d | 2.d | 966ms | 16ms | 48.7MB | 930ms | 17ms | ldc2 1.30.0 |
go | 1.go | 986ms | 32ms | 73.7MB | 957ms | 17ms | go 1.19.5 |
d | 1.d | 988ms | 16ms | 76.1MB | 953ms | 20ms | dmd 2.102.0 |
go | 1.go | 1060ms | 43ms | 43.8MB | 1027ms | 10ms | tinygo 0.25.0 |
go | 2.go | 1095ms | 9.3ms | 20.0MB | 1073ms | 13ms | go 1.19.5 |
d | 2.d | 1829ms | 35ms | 50.0MB | 1800ms | 13ms | dmd 2.102.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
d | 1.d | 142ms | 5.6ms | 14.1MB | 127ms | 0ms | ldc2 1.30.0 |
go | 1.go | 142ms | 8.0ms | 22.2MB | 120ms | 3ms | go 1.19.5 |
go | 1.go | 151ms | 0.6ms | 13.4MB | 140ms | 0ms | tinygo 0.25.0 |
d | 1.d | 161ms | 1.4ms | 26.0MB | 140ms | 0ms | dmd 2.102.0 |
go | 2.go | 198ms | 10ms | 5.6MB | 173ms | 0ms | tinygo 0.25.0 |
d | 2.d | 232ms | 6.0ms | 15.4MB | 217ms | 0ms | ldc2 1.30.0 |
go | 2.go | 259ms | 2.0ms | 8.0MB | 250ms | 0ms | go 1.19.5 |
d | 2.d | 458ms | 1.4ms | 16.7MB | 443ms | 0ms | dmd 2.102.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
d | 3.d | 881ms | 1.9ms | 167.1MB | 1077ms | 73ms | ldc2 1.30.0 |
d | 3.d | 2003ms | 6.0ms | 171.4MB | 2230ms | 63ms | dmd 2.102.0 |
go | 3.go | timeout | 0.0ms | 110.6MB | 4970ms | 127ms | go 1.19.5 |
go | 3.go | timeout | 0.0ms | 120.5MB | 4950ms | 30ms | tinygo 0.25.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 4-m.go | 2681ms | 27ms | 4.9MB | 5153ms | 3ms | go 1.19.5 |
d | 1.d | 3326ms | 2880ms | 5.1MB | 4983ms | 0ms | dmd 2.102.0 |
d | 1.d | 4357ms | 8.9ms | 3.7MB | 4343ms | 0ms | ldc2 1.30.0 |
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 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
go | 4-m.go | 674ms | 7.1ms | 3.4MB | 1277ms | 0ms | go 1.19.5 |
d | 1.d | 1091ms | 0.8ms | 3.5MB | 1080ms | 0ms | ldc2 1.30.0 |
d | 1.d | 1256ms | 3.0ms | 5.1MB | 1243ms | 0ms | dmd 2.102.0 |
go | 1.go | 1330ms | 2.8ms | 2.9MB | 1323ms | 0ms | go 1.19.5 |
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 |
---|---|---|---|---|---|---|---|
go | 4-m.go | 182ms | 3.8ms | 2.9MB | 313ms | 0ms | go 1.19.5 |
d | 1.d | 278ms | 0.5ms | 3.0MB | 267ms | 0ms | ldc2 1.30.0 |
d | 1.d | 318ms | 1.4ms | 4.4MB | 310ms | 0ms | dmd 2.102.0 |
go | 1.go | 336ms | 2.1ms | 2.9MB | 327ms | 0ms | go 1.19.5 |
go | 1.go | 1953ms | 7.3ms | 0.0MB | 1940ms | 0ms | tinygo 0.25.0 |