OCaml VS C++ benchmarks

Current benchmark data was generated on Tue Mar 25 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
ocaml 1.ml 3139ms 30ms 157.2MB 3050ms 73ms ocaml 5.3.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 1.ml 228ms 11ms 19.2MB 213ms 0ms ocaml 5.3.0

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1-im.cpp 400ms 5.5ms 2.6MB 1540ms 0ms g++ 11.4.0
cpp 1-im.cpp 409ms 4.1ms 4.0MB 1590ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 2.ml 2918ms 4.8ms 4.9MB 2910ms 0ms ocaml 5.3.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1-im.cpp 41ms 1.5ms 2.6MB 133ms 0ms g++ 11.4.0
cpp 1-im.cpp 42ms 0.4ms 4.0MB 140ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 2.ml 245ms 1.4ms 4.9MB 237ms 0ms ocaml 5.3.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 6.ml 345ms 0.3ms 24.8MB 330ms 0ms ocaml 5.3.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 6.ml 39ms 0.3ms 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
cpp 1.cpp 1.1ms 0.1ms 1.4MB 0ms 0ms g++ 11.4.0
cpp 1.cpp 1.5ms 0.1ms 2.3MB 0ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 1.ml 1.9ms 0.2ms 5.1MB 0ms 0ms ocaml 5.3.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 1.ml 178ms 2.2ms 6.4MB 170ms 0ms ocaml 5.3.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 1.ml 535ms 18ms 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
ocaml 1.ml 77ms 0.5ms 6.1MB 70ms 0ms ocaml 5.3.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 1.ml 1104ms 1.1ms 70.3MB 1060ms 30ms ocaml 5.3.0
ocaml 2.ml 2279ms 5.8ms 91.8MB 2220ms 43ms ocaml 5.3.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 1.ml 149ms 3.1ms 21.6MB 130ms 7ms ocaml 5.3.0
ocaml 2.ml 396ms 3.4ms 27.7MB 377ms 7ms ocaml 5.3.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 0-i.cpp 167ms 0.1ms 1.5MB 160ms 0ms g++ 11.4.0
cpp 0-i.cpp 171ms 0.5ms 2.3MB 160ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 1.cpp 315ms 0.8ms 2.3MB 307ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 1.cpp 316ms 0.4ms 1.8MB 307ms 0ms g++ 11.4.0
ocaml 1.ml 374ms 0.4ms 5.3MB 367ms 0ms ocaml 5.3.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 0-i.cpp 19ms 0.1ms 1.5MB 10ms 0ms g++ 11.4.0
cpp 0-i.cpp 19ms 0.2ms 2.3MB 10ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 1.cpp 34ms 0.7ms 1.9MB 30ms 0ms g++ 11.4.0
cpp 1.cpp 34ms 0.7ms 2.3MB 30ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 1.ml 41ms 0.7ms 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
cpp 1.cpp 485ms 2.1ms 7.3MB 477ms 0ms g++ 11.4.0
cpp 1.cpp 531ms 3.5ms 7.8MB 523ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 1.ml 1019ms 4.4ms 544.4MB 960ms 43ms ocaml 5.3.0
ocaml 2.ml 1896ms 11ms 17.2MB 1883ms 0ms ocaml 5.3.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1.cpp 119ms 0.4ms 3.6MB 110ms 0ms g++ 11.4.0
cpp 1.cpp 133ms 1.4ms 4.1MB 123ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 1.ml 197ms 0.6ms 128.8MB 173ms 10ms ocaml 5.3.0
ocaml 2.ml 469ms 5.3ms 9.1MB 457ms 0ms ocaml 5.3.0

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 2.ml timeout 0.0ms 462.7MB 4810ms 173ms ocaml 5.3.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ocaml 2.ml 550ms 6.1ms 57.1MB 507ms 27ms ocaml 5.3.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 8-m.cpp 474ms 9.5ms 3.5MB 1827ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 8-m.cpp 484ms 1.5ms 2.1MB 1883ms 0ms g++ 11.4.0
cpp 6-im.cpp 927ms 9.1ms 2.1MB 3633ms 0ms g++ 11.4.0
cpp 6-im.cpp 928ms 16ms 3.6MB 3630ms 0ms clang++ 14.0.0-1ubuntu1.1
ocaml 2.ml 4585ms 15ms 6.4MB 4573ms 0ms ocaml 5.3.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 8-m.cpp 124ms 0.6ms 3.4MB 460ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 8-m.cpp 130ms 0.6ms 2.0MB 490ms 0ms g++ 11.4.0
cpp 6-im.cpp 238ms 0.5ms 3.4MB 903ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 6-im.cpp 240ms 2.0ms 2.1MB 917ms 0ms g++ 11.4.0
ocaml 2.ml 1148ms 6.8ms 6.1MB 1140ms 0ms ocaml 5.3.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 8-m.cpp 40ms 0.2ms 2.0MB 130ms 0ms g++ 11.4.0
cpp 8-m.cpp 41ms 9.9ms 3.4MB 120ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 6-im.cpp 65ms 0.7ms 3.4MB 230ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 6-im.cpp 67ms 0.4ms 2.1MB 240ms 0ms g++ 11.4.0
ocaml 2.ml 296ms 5.1ms 5.2MB 287ms 0ms ocaml 5.3.0