Acton VS Crystal 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
crystal 1.cr 1276ms 8.3ms 64.0MB 1257ms 0ms crystal 1.15.1
acton 1.act timeout 0.0ms 67.1MB 5977ms 80ms actonc 0.24.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 105ms 2.2ms 10.9MB 90ms 0ms crystal 1.15.1
acton 1.act 835ms 22ms 12.0MB 973ms 73ms actonc 0.24.1

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 59ms 1.7ms 6.4MB 43ms 0ms crystal 1.15.1
acton 1.act 265ms 20ms 7.1MB 230ms 70ms actonc 0.24.1

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 22ms 0.7ms 5.1MB 10ms 0ms crystal 1.15.1
acton 1.act 101ms 17ms 5.3MB 83ms 27ms actonc 0.24.1

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2.0ms 0.5ms 2.8MB 0ms 0ms crystal 1.15.1
acton 1.act 3.6ms 0.3ms 3.9MB 0ms 0ms actonc 0.24.1

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 864ms 6.5ms 64.0MB 843ms 10ms crystal 1.15.1
acton 1.act 3317ms 13ms 102.0MB 3620ms 57ms actonc 0.24.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 157ms 3.4ms 22.1MB 143ms 0ms crystal 1.15.1
acton 1.act 715ms 22ms 30.5MB 753ms 33ms actonc 0.24.1

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 301ms 3.6ms 8.1MB 290ms 0ms crystal 1.15.1
crystal 1.cr 440ms 6.5ms 42.3MB 430ms 0ms crystal 1.15.1
acton 1.act timeout 0.0ms 561.0MB 6737ms 120ms actonc 0.24.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 77ms 2.1ms 4.4MB 67ms 0ms crystal 1.15.1
crystal 1.cr 91ms 3.7ms 13.0MB 80ms 0ms crystal 1.15.1
acton 1.act 2404ms 16ms 192.3MB 2937ms 40ms actonc 0.24.1

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1886ms 42ms 6.2MB 1853ms 17ms crystal 1.15.1
acton 1-m.act 3057ms 164ms 6.7MB 2860ms 2093ms actonc 0.24.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 479ms 12ms 5.0MB 463ms 0ms crystal 1.15.1
acton 1-m.act 870ms 31ms 5.7MB 770ms 633ms actonc 0.24.1