Chapel VS Go benchmarks

Current benchmark data was generated on Tue Jul 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 1928ms 4.1ms 51.9MB 1907ms 7ms tinygo 0.38.0
chapel 4.chpl 1970ms 8.4ms 62.3MB 1960ms 3ms chpl 1.31.0
chapel 3.chpl 2062ms 35ms 62.3MB 2057ms 0ms chpl 1.31.0
go 1-m.go 2394ms 16ms 46.3MB 5317ms 47ms go 1.24.4

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 150ms 1.6ms 5.0MB 140ms 0ms tinygo 0.38.0
chapel 3.chpl 188ms 2.0ms 32.3MB 180ms 0ms chpl 1.31.0
chapel 4.chpl 196ms 20ms 32.3MB 190ms 0ms chpl 1.31.0
go 1-m.go 209ms 0.3ms 8.0MB 367ms 13ms go 1.24.4

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 515ms 53ms 15.5MB 2007ms 0ms go 1.24.4
chapel 1-m.chpl 2288ms 97ms 769.4MB 4450ms 97ms chpl 1.31.0
go 1.go timeout 0.0ms 13.1MB 2563ms 16923ms tinygo 0.38.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 60ms 20ms 7.5MB 217ms 0ms go 1.24.4
chapel 1-m.chpl 211ms 14ms 725.6MB 333ms 60ms chpl 1.31.0
go 1-m.go 660ms 66ms 4.3MB 317ms 2160ms tinygo 0.38.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 72ms 0.4ms 32.5MB 70ms 0ms chpl 1.31.0
go 1.go 118ms 0.0ms 8.6MB 110ms 0ms go 1.24.4

Input: 100000

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

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5-m.chpl 108ms 3.0ms 28.4MB 193ms 0ms chpl 1.31.0
go 3-m.go 126ms 0.7ms 5.5MB 377ms 0ms go 1.24.4

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 17ms 0.4ms 7.5MB 30ms 0ms go 1.24.4
chapel 5.chpl 21ms 1.4ms 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.7ms 0.0ms 0.3MB 0ms 0ms tinygo 0.38.0
go 1.go 1.5ms 0.0ms 3.4MB 0ms 0ms go 1.24.4
chapel 1.chpl 11ms 0.4ms 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 695ms 16ms 39.7MB 2387ms 30ms go 1.24.4
chapel 3-m.chpl 789ms 57ms 87.0MB 1463ms 7ms 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 114ms 0.4ms 76.9MB 200ms 3ms chpl 1.31.0
go 7-m.go 131ms 3.9ms 22.8MB 350ms 17ms go 1.24.4

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 320ms 1.9ms 28.8MB 317ms 0ms chpl 1.31.0
go 1.go 352ms 3.6ms 3.5MB 343ms 0ms go 1.24.4
go 1.go 352ms 7.5ms 0.3MB 343ms 0ms tinygo 0.38.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 38ms 1.4ms 3.5MB 30ms 0ms go 1.24.4
go 1.go 39ms 1.1ms 0.3MB 30ms 0ms tinygo 0.38.0
chapel 2.chpl 48ms 4.7ms 28.8MB 43ms 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.5ms 30.3MB 443ms 0ms chpl 1.31.0
go 8.go 1207ms 7.6ms 8.6MB 1193ms 0ms go 1.24.4

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 113ms 1.0ms 30.4MB 110ms 0ms chpl 1.31.0
go 8.go 283ms 3.4ms 8.6MB 270ms 0ms go 1.24.4

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 1397ms 5.8ms 246.1MB 1347ms 40ms chpl 1.31.0
go 3.go timeout 0.0ms 126.4MB 4987ms 40ms go 1.24.4
go 3.go timeout 0.0ms 84.8MB 4967ms 13ms tinygo 0.38.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 160ms 1.0ms 48.9MB 147ms 10ms chpl 1.31.0
go 3.go 1793ms 82ms 19.9MB 1777ms 27ms go 1.24.4
go 3.go 2297ms 19ms 23.0MB 2280ms 3ms tinygo 0.38.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 91ms 0.9ms 5.2MB 83ms 0ms go 1.24.4
chapel 1.chpl 1189ms 8.0ms 29.1MB 1180ms 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.9ms 5.2MB 20ms 0ms go 1.24.4
chapel 1.chpl 310ms 1.9ms 29.2MB 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 1900ms 1.2ms 5.5MB 7423ms 7ms go 1.24.4
chapel 1-m.chpl 1930ms 12ms 28.9MB 3833ms 0ms chpl 1.31.0
go 1.go 3659ms 14ms 5.5MB 3650ms 3ms go 1.24.4
chapel 1.chpl 3728ms 14ms 28.8MB 3723ms 0ms chpl 1.31.0
go 1.go timeout 0.0ms 0.5MB 4990ms 0ms tinygo 0.38.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 480ms 0.2ms 5.6MB 1843ms 0ms go 1.24.4
chapel 1-m.chpl 495ms 2.2ms 28.9MB 960ms 0ms chpl 1.31.0
go 1.go 921ms 7.0ms 3.5MB 913ms 0ms go 1.24.4
chapel 1.chpl 941ms 4.2ms 28.8MB 937ms 0ms chpl 1.31.0
go 1.go 1398ms 2.9ms 0.4MB 1390ms 0ms tinygo 0.38.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 125ms 1.2ms 5.5MB 450ms 0ms go 1.24.4
chapel 1-m.chpl 134ms 0.7ms 29.0MB 240ms 0ms chpl 1.31.0
go 1.go 232ms 0.1ms 3.5MB 220ms 0ms go 1.24.4
chapel 1.chpl 247ms 0.8ms 28.8MB 240ms 0ms chpl 1.31.0
go 1.go 351ms 0.6ms 0.4MB 340ms 0ms tinygo 0.38.0