Chapel VS Go benchmarks

Current benchmark data was generated on Mon May 19 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 1249ms 9.0ms 55.0MB 1227ms 10ms tinygo 0.37.0
chapel 4.chpl 1952ms 9.9ms 62.3MB 1943ms 3ms chpl 1.31.0
chapel 3.chpl 2127ms 36ms 62.3MB 2120ms 0ms chpl 1.31.0
go 1-m.go 2386ms 8.7ms 41.6MB 5307ms 40ms go 1.24.3

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 113ms 1.7ms 5.6MB 100ms 0ms tinygo 0.37.0
chapel 4.chpl 184ms 1.8ms 30.3MB 180ms 0ms chpl 1.31.0
chapel 3.chpl 186ms 1.6ms 32.3MB 183ms 0ms chpl 1.31.0
go 1-m.go 210ms 2.2ms 8.1MB 370ms 10ms go 1.24.3

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 545ms 34ms 15.5MB 2127ms 0ms go 1.24.3
go 1.go 739ms 8.5ms 268.3MB 683ms 43ms tinygo 0.37.0
chapel 1-m.chpl 2280ms 43ms 659.8MB 4437ms 87ms chpl 1.31.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 50ms 13ms 7.5MB 167ms 0ms go 1.24.3
go 1.go 70ms 0.3ms 68.6MB 50ms 10ms tinygo 0.37.0
chapel 1-m.chpl 206ms 4.4ms 630.1MB 320ms 60ms chpl 1.31.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 71ms 1.6ms 32.5MB 70ms 0ms chpl 1.31.0
go 1.go 118ms 0.8ms 10.2MB 110ms 0ms go 1.24.3

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 33ms 3.0ms 30.5MB 30ms 0ms chpl 1.31.0
go 1.go 35ms 1.6ms 8.2MB 30ms 0ms go 1.24.3

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5-m.chpl 105ms 0.9ms 28.4MB 190ms 0ms chpl 1.31.0
go 3-m.go 126ms 0.6ms 7.5MB 377ms 0ms go 1.24.3

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 17ms 0.0ms 7.6MB 30ms 0ms go 1.24.3
chapel 5.chpl 22ms 2.1ms 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.8ms 0.0ms 0.4MB 0ms 0ms tinygo 0.37.0
go 1.go 1.4ms 0.1ms 3.4MB 0ms 0ms go 1.24.3
chapel 1.chpl 11ms 0.3ms 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 691ms 14ms 39.6MB 2427ms 27ms go 1.24.3
chapel 3-m.chpl 749ms 3.1ms 86.9MB 1420ms 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 115ms 1.4ms 77.0MB 200ms 0ms chpl 1.31.0
go 7-m.go 133ms 2.9ms 22.8MB 353ms 23ms go 1.24.3

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 322ms 4.1ms 28.9MB 317ms 0ms chpl 1.31.0
go 1.go 349ms 0.2ms 3.5MB 340ms 0ms go 1.24.3
go 1.go 353ms 6.1ms 0.4MB 343ms 0ms tinygo 0.37.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 37ms 0.6ms 0.4MB 30ms 0ms tinygo 0.37.0
go 1.go 38ms 1.3ms 3.5MB 30ms 0ms go 1.24.3
chapel 2.chpl 45ms 0.3ms 28.9MB 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 445ms 2.1ms 30.4MB 440ms 0ms chpl 1.31.0
go 8.go 1191ms 8.1ms 8.6MB 1180ms 3ms go 1.24.3

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 115ms 0.6ms 30.4MB 110ms 0ms chpl 1.31.0
go 8.go 283ms 4.5ms 8.6MB 273ms 0ms go 1.24.3

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 1396ms 9.0ms 220.1MB 1353ms 37ms chpl 1.31.0
go 3.go timeout 0.0ms 122.2MB 4987ms 50ms go 1.24.3
go 3.go timeout 0.0ms 123.4MB 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 163ms 2.2ms 48.9MB 140ms 13ms chpl 1.31.0
go 3.go 1750ms 14ms 20.3MB 1727ms 30ms go 1.24.3
go 3.go 2262ms 24ms 27.0MB 2247ms 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 91ms 2.0ms 5.1MB 87ms 0ms go 1.24.3
chapel 1.chpl 1184ms 16ms 29.1MB 1177ms 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 27ms 0.8ms 5.2MB 20ms 0ms go 1.24.3
chapel 1.chpl 315ms 8.4ms 29.1MB 310ms 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 1909ms 16ms 5.6MB 7410ms 7ms go 1.24.3
chapel 1-m.chpl 1912ms 1.5ms 28.9MB 3800ms 0ms chpl 1.31.0
go 1.go 3665ms 9.0ms 5.6MB 3663ms 0ms go 1.24.3
chapel 1.chpl 3730ms 9.2ms 28.8MB 3720ms 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 480ms 0.9ms 5.5MB 1843ms 0ms go 1.24.3
chapel 1-m.chpl 492ms 1.7ms 28.8MB 960ms 0ms chpl 1.31.0
go 1.go 915ms 1.2ms 3.5MB 910ms 0ms go 1.24.3
chapel 1.chpl 940ms 3.7ms 28.8MB 933ms 0ms chpl 1.31.0
go 1.go 1396ms 0.6ms 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.1ms 5.5MB 450ms 0ms go 1.24.3
chapel 1-m.chpl 134ms 0.9ms 28.9MB 240ms 0ms chpl 1.31.0
go 1.go 233ms 2.1ms 3.5MB 223ms 0ms go 1.24.3
chapel 1.chpl 249ms 2.0ms 28.8MB 243ms 0ms chpl 1.31.0
go 1.go 352ms 1.1ms 0.4MB 340ms 0ms tinygo 0.37.0