Chapel VS Go benchmarks

Current benchmark data was generated on Thu May 01 2025, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][4 cores] AMD EPYC 7763 64-Core Processor (Model 1)

* -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.)

binarytrees

Input: 18

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 1220ms 11ms 55.0MB 1197ms 10ms tinygo 0.37.0
chapel 4.chpl 1953ms 5.8ms 62.4MB 1947ms 0ms chpl 1.31.0
chapel 3.chpl 2034ms 5.7ms 62.3MB 2027ms 0ms chpl 1.31.0
go 1-m.go 2348ms 15ms 40.2MB 5240ms 33ms go 1.24.2

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 113ms 1.8ms 5.6MB 100ms 0ms tinygo 0.37.0
chapel 4.chpl 184ms 0.5ms 32.3MB 180ms 0ms chpl 1.31.0
chapel 3.chpl 189ms 2.4ms 32.3MB 183ms 0ms chpl 1.31.0
go 1-m.go 208ms 0.9ms 8.1MB 367ms 7ms go 1.24.2

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 584ms 107ms 15.6MB 2280ms 0ms go 1.24.2
go 1.go 717ms 25ms 268.1MB 657ms 40ms tinygo 0.37.0
chapel 1-m.chpl 2236ms 75ms 571.9MB 4350ms 80ms chpl 1.31.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 38ms 5.1ms 7.4MB 127ms 0ms go 1.24.2
go 1.go 66ms 1.1ms 67.2MB 40ms 10ms tinygo 0.37.0
chapel 1-m.chpl 193ms 3.2ms 540.5MB 307ms 50ms chpl 1.31.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 74ms 1.0ms 32.5MB 70ms 0ms chpl 1.31.0
go 1.go 117ms 2.3ms 8.6MB 110ms 0ms go 1.24.2

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 34ms 0.7ms 30.5MB 30ms 0ms chpl 1.31.0
go 1.go 35ms 0.5ms 8.2MB 30ms 0ms go 1.24.2

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5-m.chpl 107ms 2.2ms 28.4MB 190ms 0ms chpl 1.31.0
go 3-m.go 118ms 1.3ms 6.8MB 380ms 0ms go 1.24.2

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 17ms 1.1ms 7.5MB 30ms 0ms go 1.24.2
chapel 5.chpl 21ms 1.7ms 28.4MB 20ms 0ms chpl 1.31.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 0.9ms 0.1ms 0.4MB 0ms 0ms tinygo 0.37.0
go 1.go 1.5ms 0.1ms 3.4MB 0ms 0ms go 1.24.2
chapel 1.chpl 11ms 0.5ms 28.8MB 0ms 0ms chpl 1.31.0

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 674ms 2.1ms 41.7MB 2390ms 20ms go 1.24.2
chapel 3-m.chpl 751ms 2.2ms 85.0MB 1420ms 10ms chpl 1.31.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3-m.chpl 116ms 1.0ms 87.0MB 200ms 7ms chpl 1.31.0
go 7-m.go 132ms 1.0ms 23.6MB 343ms 30ms go 1.24.2

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 324ms 3.1ms 28.8MB 320ms 0ms chpl 1.31.0
go 1.go 346ms 0.8ms 0.4MB 340ms 0ms tinygo 0.37.0
go 1.go 350ms 2.0ms 3.5MB 340ms 0ms go 1.24.2

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 37ms 0.7ms 0.4MB 30ms 0ms tinygo 0.37.0
go 1.go 38ms 0.9ms 3.5MB 30ms 0ms go 1.24.2
chapel 2.chpl 45ms 1.4ms 28.8MB 40ms 0ms chpl 1.31.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 448ms 1.7ms 30.4MB 440ms 0ms chpl 1.31.0
go 8.go 1118ms 6.9ms 8.7MB 1103ms 3ms go 1.24.2

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 114ms 1.1ms 30.3MB 110ms 0ms chpl 1.31.0
go 8.go 271ms 2.4ms 8.6MB 260ms 0ms go 1.24.2

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 1396ms 9.5ms 220.2MB 1350ms 40ms chpl 1.31.0
go 3.go timeout 0.0ms 122.2MB 4987ms 40ms go 1.24.2
go 3.go timeout 0.0ms 130.5MB 4977ms 10ms tinygo 0.37.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 162ms 3.8ms 48.9MB 140ms 17ms chpl 1.31.0
go 3.go 1800ms 15ms 20.2MB 1787ms 27ms go 1.24.2
go 3.go 2249ms 8.9ms 29.5MB 2230ms 0ms tinygo 0.37.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 90ms 0.7ms 5.2MB 83ms 0ms go 1.24.2
chapel 1.chpl 1187ms 11ms 29.1MB 1183ms 0ms chpl 1.31.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 25ms 0.2ms 5.2MB 17ms 0ms go 1.24.2
chapel 1.chpl 307ms 3.0ms 29.0MB 303ms 0ms chpl 1.31.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 1913ms 15ms 5.5MB 7410ms 3ms go 1.24.2
chapel 1-m.chpl 1928ms 23ms 28.9MB 3827ms 0ms chpl 1.31.0
go 1.go 3658ms 17ms 5.6MB 3650ms 0ms go 1.24.2
chapel 1.chpl 3719ms 13ms 28.8MB 3713ms 0ms chpl 1.31.0
go 1.go timeout 0.0ms 0.5MB 4990ms 0ms tinygo 0.37.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 489ms 15ms 5.5MB 1830ms 0ms go 1.24.2
chapel 1-m.chpl 492ms 2.8ms 28.8MB 960ms 0ms chpl 1.31.0
go 1.go 941ms 32ms 3.5MB 933ms 0ms go 1.24.2
chapel 1.chpl 944ms 3.9ms 28.8MB 937ms 0ms chpl 1.31.0
go 1.go 1397ms 1.8ms 0.5MB 1390ms 0ms tinygo 0.37.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 125ms 0.5ms 5.6MB 453ms 0ms go 1.24.2
chapel 1-m.chpl 134ms 1.5ms 28.9MB 247ms 0ms chpl 1.31.0
go 1.go 239ms 3.5ms 3.5MB 230ms 0ms go 1.24.2
chapel 1.chpl 247ms 2.2ms 28.8MB 240ms 0ms chpl 1.31.0
go 1.go 351ms 1.0ms 0.4MB 343ms 0ms tinygo 0.37.0