Odin VS Crystal benchmarks

Current benchmark data was generated on Tue Dec 31 2024, 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 1267ms 4.6ms 64.3MB 1247ms 7ms crystal 1.14.0
odin 1.odin 2227ms 80ms 49.5MB 2193ms 17ms odin 2024

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 102ms 0.9ms 11.1MB 90ms 0ms crystal 1.14.0
odin 1.odin 207ms 1.9ms 7.5MB 193ms 0ms odin 2024

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 1.2ms 0.1ms 1.6MB 0ms 0ms odin 2024
crystal 1.cr 2.0ms 0.1ms 3.0MB 0ms 0ms crystal 1.14.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 35ms 1.9ms 3.1MB 23ms 0ms crystal 1.14.0
crystal 1.cr 62ms 2.8ms 3.1MB 50ms 0ms crystal 1.14.0
odin 1.odin 140ms 1.6ms 1.6MB 130ms 0ms odin 2024

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 94ms 2.9ms 3.1MB 83ms 0ms crystal 1.14.0
crystal 1.cr 173ms 1.9ms 3.1MB 163ms 0ms crystal 1.14.0
odin 1.odin 408ms 6.4ms 1.6MB 397ms 0ms odin 2024

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 17ms 0.4ms 3.0MB 10ms 0ms crystal 1.14.0
crystal 1.cr 28ms 0.6ms 3.0MB 20ms 0ms crystal 1.14.0
odin 1.odin 64ms 1.7ms 1.6MB 53ms 0ms odin 2024

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 271ms 3.6ms 4.6MB 260ms 0ms odin 2024
crystal 1.cr 300ms 7.0ms 9.2MB 287ms 0ms crystal 1.14.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 14ms 1.2ms 1.6MB 10ms 0ms odin 2024
crystal 1.cr 16ms 0.1ms 6.3MB 10ms 0ms crystal 1.14.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 327ms 5.3ms 3.4MB 313ms 0ms crystal 1.14.0
crystal 2.cr 327ms 8.1ms 3.4MB 313ms 0ms crystal 1.14.0
odin 1.odin 332ms 2.6ms 1.5MB 323ms 0ms odin 2024
odin 1-i.odin 338ms 4.3ms 1.5MB 327ms 0ms odin 2024

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1-i.odin 36ms 0.1ms 1.5MB 30ms 0ms odin 2024
crystal 2.cr 36ms 0.6ms 3.4MB 23ms 0ms crystal 1.14.0
crystal 1.cr 36ms 0.8ms 3.4MB 30ms 0ms crystal 1.14.0
odin 1.odin 37ms 0.6ms 1.5MB 30ms 0ms odin 2024

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 259ms 6.1ms 40.6MB 243ms 0ms odin 2024
crystal 2.cr 327ms 5.2ms 8.4MB 313ms 0ms crystal 1.14.0
crystal 1.cr 348ms 6.2ms 43.1MB 337ms 0ms crystal 1.14.0
odin 2.odin 662ms 40ms 6.5MB 647ms 0ms odin 2024

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 51ms 4.9ms 11.3MB 40ms 0ms odin 2024
crystal 1.cr 74ms 2.1ms 13.3MB 60ms 0ms crystal 1.14.0
crystal 2.cr 82ms 1.0ms 4.6MB 70ms 0ms crystal 1.14.0
odin 2.odin 166ms 14ms 2.8MB 153ms 0ms odin 2024

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 3403ms 22ms 2.9MB 3390ms 0ms odin 2024
crystal 1.cr 3700ms 16ms 4.6MB 3683ms 3ms crystal 1.14.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 846ms 8.4ms 2.3MB 837ms 0ms odin 2024
crystal 1.cr 933ms 19ms 4.5MB 923ms 0ms crystal 1.14.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 216ms 3.1ms 1.9MB 207ms 0ms odin 2024
crystal 1.cr 237ms 1.8ms 4.0MB 223ms 0ms crystal 1.14.0