Go VS OCaml benchmarks

Current benchmark data was generated on Mon Mar 31 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 1214ms 12ms 55.0MB 1190ms 10ms tinygo 0.37.0
go 1-m.go 2372ms 13ms 46.1MB 5267ms 43ms go 1.24.1
ocaml 1.ml 2992ms 15ms 157.1MB 2910ms 70ms ocaml 5.3.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 115ms 1.5ms 5.6MB 107ms 0ms tinygo 0.37.0
go 1-m.go 209ms 0.5ms 8.0MB 370ms 10ms go 1.24.1
ocaml 1.ml 219ms 1.1ms 19.2MB 203ms 0ms ocaml 5.3.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 473ms 8.9ms 15.6MB 1833ms 3ms go 1.24.1
go 1.go 723ms 8.5ms 269.4MB 670ms 37ms tinygo 0.37.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 38ms 6.0ms 7.5MB 123ms 0ms go 1.24.1
go 1.go 70ms 2.6ms 68.3MB 50ms 10ms tinygo 0.37.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 117ms 1.7ms 8.4MB 110ms 0ms go 1.24.1

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 33ms 0.5ms 8.2MB 23ms 0ms go 1.24.1

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 670ms 3.5ms 5.5MB 2587ms 0ms go 1.24.1
go 3.go 2017ms 1.1ms 49.1MB 1997ms 7ms tinygo 0.37.0
ocaml 2.ml 2927ms 11ms 4.9MB 2917ms 0ms ocaml 5.3.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 73ms 1.0ms 5.6MB 200ms 0ms go 1.24.1
go 3.go 189ms 1.4ms 49.1MB 170ms 3ms tinygo 0.37.0
ocaml 2.ml 246ms 1.5ms 5.1MB 240ms 0ms ocaml 5.3.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 124ms 1.1ms 7.5MB 373ms 0ms go 1.24.1
ocaml 6.ml 346ms 1.3ms 24.8MB 333ms 0ms ocaml 5.3.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 17ms 1.3ms 7.5MB 30ms 0ms go 1.24.1
ocaml 6.ml 38ms 0.4ms 7.3MB 30ms 0ms ocaml 5.3.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.1
ocaml 1.ml 1.9ms 0.1ms 5.1MB 0ms 0ms ocaml 5.3.0

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 119ms 3.6ms 56.1MB 323ms 80ms go 1.24.1
go 1-m.go 398ms 12ms 176.8MB 660ms 667ms go 1.24.1
go 2-m.go 421ms 8.9ms 172.6MB 703ms 713ms go 1.24.1

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-m.go 25ms 28ms 28.6MB 60ms 70ms go 1.24.1
go 1-http2.go 32ms 4.0ms 25.3MB 60ms 20ms go 1.24.1
go 1-m.go 78ms 2.4ms 36.8MB 110ms 103ms go 1.24.1

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 46ms 1.9ms 41.2MB 40ms 7ms go 1.24.1
go 1.go 139ms 1.2ms 18.6MB 133ms 0ms go 1.24.1

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 244ms 7.5ms 141.3MB 240ms 30ms go 1.24.1
go 1.go 746ms 2.5ms 105.0MB 733ms 10ms go 1.24.1

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 680ms 12ms 42.1MB 2393ms 30ms go 1.24.1

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 135ms 3.6ms 23.7MB 343ms 20ms go 1.24.1

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 121ms 2.5ms 3.5MB 113ms 0ms go 1.24.1
go 3.go 131ms 2.2ms 0.5MB 123ms 0ms tinygo 0.37.0
ocaml 1.ml 184ms 5.4ms 6.4MB 173ms 0ms ocaml 5.3.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 388ms 13ms 3.5MB 380ms 0ms go 1.24.1
go 3.go 388ms 2.2ms 0.5MB 380ms 0ms tinygo 0.37.0
ocaml 1.ml 537ms 29ms 6.6MB 523ms 0ms ocaml 5.3.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 51ms 1.0ms 3.5MB 40ms 0ms go 1.24.1
go 3.go 64ms 1.6ms 0.4MB 57ms 0ms tinygo 0.37.0
ocaml 1.ml 78ms 1.3ms 5.9MB 70ms 0ms ocaml 5.3.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 3232ms 34ms 7.7MB 3227ms 0ms go 1.24.1
go 1.go 4076ms 6.3ms 3.4MB 4067ms 0ms tinygo 0.37.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 137ms 1.7ms 3.6MB 130ms 0ms go 1.24.1
go 1.go 171ms 1.9ms 0.5MB 163ms 0ms tinygo 0.37.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 820ms 47ms 63.2MB 797ms 10ms tinygo 0.37.0
ocaml 1.ml 1092ms 5.1ms 70.2MB 1047ms 30ms ocaml 5.3.0
go 2.go 1112ms 7.9ms 55.0MB 1093ms 3ms tinygo 0.37.0
go 1-m.go 1461ms 6.1ms 39.0MB 3090ms 37ms go 1.24.1
go 2-m.go 1661ms 2.3ms 42.9MB 3680ms 40ms go 1.24.1
ocaml 2.ml 2145ms 35ms 91.7MB 2087ms 40ms ocaml 5.3.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 1.ml 152ms 1.5ms 21.6MB 137ms 0ms ocaml 5.3.0
go 1.go 176ms 2.5ms 9.8MB 160ms 0ms tinygo 0.37.0
go 2.go 206ms 2.2ms 17.1MB 190ms 0ms tinygo 0.37.0
go 1-m.go 332ms 4.7ms 12.2MB 677ms 20ms go 1.24.1
ocaml 2.ml 366ms 3.1ms 27.7MB 343ms 10ms ocaml 5.3.0
go 2-m.go 373ms 2.8ms 13.9MB 787ms 27ms go 1.24.1

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 349ms 3.0ms 0.4MB 340ms 0ms tinygo 0.37.0
go 1.go 352ms 2.1ms 3.5MB 343ms 0ms go 1.24.1
ocaml 1.ml 373ms 2.2ms 5.2MB 360ms 0ms ocaml 5.3.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 37ms 0.1ms 3.5MB 30ms 0ms go 1.24.1
go 1.go 38ms 0.7ms 0.4MB 30ms 0ms tinygo 0.37.0
ocaml 1.ml 42ms 0.9ms 5.2MB 30ms 0ms ocaml 5.3.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 272ms 4.7ms 39.5MB 260ms 0ms tinygo 0.37.0
go 1.go 278ms 0.1ms 71.7MB 267ms 0ms go 1.24.1
go 2.go 427ms 1.8ms 21.2MB 417ms 0ms tinygo 0.37.0
go 2.go 742ms 2.8ms 21.6MB 727ms 7ms go 1.24.1
ocaml 1.ml 932ms 3.0ms 552.4MB 873ms 40ms ocaml 5.3.0
ocaml 2.ml 1897ms 2.6ms 17.3MB 1887ms 0ms ocaml 5.3.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 53ms 0.1ms 10.1MB 40ms 0ms tinygo 0.37.0
go 1.go 57ms 2.1ms 21.6MB 50ms 0ms go 1.24.1
go 2.go 109ms 2.0ms 4.9MB 100ms 0ms tinygo 0.37.0
go 2.go 183ms 1.8ms 6.1MB 170ms 0ms go 1.24.1
ocaml 1.ml 189ms 0.9ms 142.3MB 163ms 10ms ocaml 5.3.0
ocaml 2.ml 469ms 4.6ms 9.1MB 457ms 0ms ocaml 5.3.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 1173ms 7.7ms 8.7MB 1157ms 0ms go 1.24.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 280ms 1.6ms 8.6MB 270ms 0ms go 1.24.1

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go timeout 0.0ms 122.0MB 4987ms 47ms go 1.24.1
go 3.go timeout 0.0ms 136.3MB 4980ms 10ms tinygo 0.37.0
ocaml 2.ml timeout 0.0ms 462.9MB 4817ms 167ms ocaml 5.3.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 2.ml 549ms 10ms 57.1MB 513ms 23ms ocaml 5.3.0
go 3.go 1752ms 13ms 19.9MB 1737ms 20ms go 1.24.1
go 3.go 2259ms 19ms 27.6MB 2243ms 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 92ms 0.3ms 5.2MB 87ms 0ms go 1.24.1

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 25ms 0.7ms 5.2MB 20ms 0ms go 1.24.1

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 1911ms 17ms 4.3MB 7403ms 10ms go 1.24.1
go 1.go 3659ms 12ms 5.6MB 3650ms 0ms go 1.24.1
ocaml 2.ml 4556ms 14ms 6.4MB 4543ms 0ms ocaml 5.3.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 481ms 0.6ms 5.5MB 1843ms 0ms go 1.24.1
go 1.go 916ms 4.3ms 3.5MB 910ms 0ms go 1.24.1
ocaml 2.ml 1140ms 6.4ms 6.1MB 1130ms 0ms ocaml 5.3.0
go 1.go 1397ms 0.4ms 0.5MB 1387ms 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.8ms 5.5MB 450ms 0ms go 1.24.1
go 1.go 231ms 1.3ms 3.5MB 220ms 0ms go 1.24.1
ocaml 2.ml 291ms 5.2ms 5.2MB 283ms 0ms ocaml 5.3.0
go 1.go 352ms 0.6ms 0.4MB 340ms 0ms tinygo 0.37.0