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 |
---|---|---|---|---|---|---|---|
go | 1-http2.go | 207ms | 4.6ms | 58.5MB | 300ms | 50ms | go 1.19.5 |
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 |
crystal | 1.cr | 3606ms | 81ms | 193.5MB | 693ms | 417ms | crystal 1.7.2 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 0-unsafe.cr | 69ms | 3.1ms | 3.0MB | 57ms | 0ms | crystal 1.7.2 |
crystal | 1.cr | 113ms | 1.8ms | 3.0MB | 100ms | 0ms | crystal 1.7.2 |
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 |
---|---|---|---|---|---|---|---|
crystal | 0-unsafe.cr | 195ms | 4.7ms | 3.0MB | 180ms | 0ms | crystal 1.7.2 |
crystal | 1.cr | 324ms | 1.4ms | 3.0MB | 310ms | 0ms | crystal 1.7.2 |
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 |
---|---|---|---|---|---|---|---|
crystal | 0-unsafe.cr | 36ms | 2.2ms | 2.9MB | 23ms | 0ms | crystal 1.7.2 |
crystal | 1.cr | 56ms | 0.1ms | 2.9MB | 47ms | 0ms | crystal 1.7.2 |
go | 3.go | 99ms | 0.4ms | 0.0MB | 90ms | 0ms | tinygo 0.25.0 |
go | 3.go | 108ms | 3.8ms | 4.1MB | 100ms | 0ms | go 1.19.5 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 1790ms | 9.6ms | 64.3MB | 1750ms | 17ms | crystal 1.7.2 |
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 |
---|---|---|---|---|---|---|---|
crystal | 1.cr | 320ms | 17ms | 22.1MB | 300ms | 7ms | crystal 1.7.2 |
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 |
---|---|---|---|---|---|---|---|
go | 1.go | 599ms | 3.1ms | 2.9MB | 587ms | 0ms | go 1.19.5 |
crystal | 1.cr | 670ms | 3.5ms | 2.9MB | 657ms | 0ms | crystal 1.7.2 |
crystal | 2.cr | 694ms | 9.6ms | 3.0MB | 683ms | 0ms | crystal 1.7.2 |
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 |
---|---|---|---|---|---|---|---|
crystal | 2.cr | 513ms | 4.0ms | 7.8MB | 500ms | 0ms | crystal 1.7.2 |
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 |
go | 2.go | 1095ms | 9.3ms | 20.0MB | 1073ms | 13ms | go 1.19.5 |
crystal | 1.cr | 1150ms | 55ms | 41.9MB | 1130ms | 7ms | crystal 1.7.2 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
crystal | 2.cr | 117ms | 2.4ms | 4.1MB | 103ms | 0ms | crystal 1.7.2 |
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 |
crystal | 1.cr | 175ms | 1.0ms | 12.9MB | 160ms | 0ms | crystal 1.7.2 |
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 |
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 |
crystal | 1.cr | timeout | 0.0ms | 4.0MB | 4977ms | 3ms | crystal 1.7.2 |
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 |