Codon VS Odin benchmarks

Current benchmark data was generated on Thu Feb 01 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.)

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 1.1ms 0.1ms 1.9MB 0ms 0ms odin 2024
codon 1.py 4.5ms 0.8ms 7.2MB 0ms 0ms codon 0.16.3

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1-i.odin 412ms 1.8ms 1.8MB 400ms 0ms odin 2024
codon 1.py 1295ms 1.9ms 7.7MB 1287ms 0ms codon 0.16.3
odin 1.odin 4417ms 16ms 1.6MB 4413ms 0ms odin 2024

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1-i.odin 44ms 0.8ms 1.6MB 37ms 0ms odin 2024
codon 1.py 140ms 2.4ms 5.8MB 127ms 0ms codon 0.16.3
odin 1.odin 442ms 0.7ms 1.6MB 430ms 0ms odin 2024

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 291ms 4.7ms 40.6MB 270ms 3ms odin 2024
codon 1.py 406ms 0.9ms 46.5MB 390ms 0ms codon 0.16.3
codon 2.py 482ms 8.3ms 107.0MB 463ms 13ms codon 0.16.3
odin 2.odin 811ms 3.6ms 6.5MB 797ms 3ms odin 2024

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 56ms 0.9ms 11.3MB 43ms 0ms odin 2024
codon 1.py 81ms 2.0ms 17.2MB 70ms 0ms codon 0.16.3
codon 2.py 110ms 3.4ms 26.0MB 97ms 3ms codon 0.16.3
odin 2.odin 200ms 0.3ms 2.8MB 190ms 0ms odin 2024