Odin VS Java benchmarks

Current benchmark data was generated on Fri May 20 2022, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][2 cores] Intel(R) Xeon(R) Platinum 8370C CPU @ 2.80GHz (Model 106)

* -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 2.1ms 1.0ms 0.9MB 0ms 0ms odin 2022
java 1.java 71ms 3.3ms 59.7MB 64ms 14ms graal/jvm 17.0.3
java 1.java 75ms 4.6ms 38.7MB 76ms 6ms openjdk 18.0.1
java 1.java 78ms 3.9ms 38.4MB 76ms 6ms openjdk 19
java 1.java 115ms 2.8ms 38.3MB 76ms 52ms openjdk/zgc 18.0.1

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 176ms 1.5ms 1.8MB 160ms 0ms odin 2022

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 517ms 3.6ms 1.8MB 503ms 0ms odin 2022

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 82ms 0.2ms 0.8MB 70ms 0ms odin 2022

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 1615ms 0.8ms 4.7MB 1603ms 0ms odin 2022
java 1.java timeout 0.0ms 0.0MB 0ms 0ms graal/jvm 17.0.3
java 1.java timeout 0.0ms 0.0MB 0ms 0ms openjdk 18.0.1
java 2.java timeout 0.0ms 0.0MB 0ms 0ms openjdk 18.0.1
java 1.java timeout 0.0ms 0.0MB 0ms 0ms openjdk 19
java 2.java timeout 0.0ms 0.0MB 0ms 0ms openjdk 19
java 1.java timeout 0.0ms 0.0MB 0ms 0ms openjdk/zgc 18.0.1
java 2.java timeout 0.0ms 0.0MB 0ms 0ms openjdk/zgc 18.0.1

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 69ms 0.3ms 0.8MB 60ms 0ms odin 2022
java 2.java 764ms 19ms 539.3MB 980ms 110ms openjdk 19
java 1.java 780ms 7.5ms 436.8MB 893ms 83ms openjdk 19
java 1.java 802ms 12ms 404.2MB 913ms 93ms openjdk 18.0.1
java 2.java 871ms 13ms 565.4MB 993ms 170ms openjdk 18.0.1
java 1.java 1085ms 6.8ms 319.6MB 880ms 80ms graal/jvm 17.0.3
java 2.java 1416ms 25ms 1046.7MB 1007ms 677ms openjdk/zgc 18.0.1
java 1.java 1467ms 5.1ms 1058.4MB 983ms 703ms openjdk/zgc 18.0.1

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 551ms 5.5ms 40.5MB 567ms 13ms openjdk 18.0.1
java 1.java 554ms 3.0ms 39.8MB 567ms 10ms openjdk 19
java 1.java 602ms 0.9ms 40.9MB 573ms 53ms openjdk/zgc 18.0.1
java 1.java 856ms 5.8ms 83.0MB 570ms 23ms graal/jvm 17.0.3
java 2.java 1864ms 6.1ms 544.3MB 1893ms 117ms openjdk 19
java 2.java 1934ms 11ms 547.2MB 1927ms 157ms openjdk 18.0.1
odin 1.odin 2543ms 1.4ms 0.8MB 2530ms 0ms odin 2022
java 2.java 2548ms 12ms 1221.8MB 1943ms 790ms openjdk/zgc 18.0.1

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 135ms 3.2ms 40.6MB 147ms 17ms openjdk 18.0.1
java 1.java 136ms 2.9ms 41.5MB 147ms 17ms openjdk 19
java 1.java 188ms 6.9ms 38.4MB 160ms 53ms openjdk/zgc 18.0.1
odin 1.odin 256ms 0.3ms 0.8MB 250ms 0ms odin 2022
java 2.java 410ms 4.1ms 337.4MB 470ms 83ms openjdk 19
java 2.java 418ms 12ms 322.7MB 483ms 73ms openjdk 18.0.1
java 1.java 452ms 2.8ms 88.4MB 170ms 23ms graal/jvm 17.0.3
java 2.java 668ms 2.0ms 471.8MB 523ms 297ms openjdk/zgc 18.0.1

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 819ms 17ms 40.6MB 797ms 7ms odin 2022
java 2.java 927ms 2.1ms 48.9MB 960ms 23ms openjdk 18.0.1
java 2.java 928ms 5.3ms 50.1MB 963ms 17ms openjdk 19
java 2.java 945ms 3.6ms 47.6MB 930ms 57ms openjdk/zgc 18.0.1
java 1.java 1022ms 23ms 106.6MB 980ms 80ms openjdk/zgc 18.0.1
odin 2.odin 1251ms 15ms 6.4MB 1240ms 0ms odin 2022
java 1.java 1344ms 124ms 81.9MB 1363ms 27ms openjdk 19
java 1.java 1446ms 54ms 80.8MB 1473ms 17ms openjdk 18.0.1
java 1-m.java 1501ms 185ms 169.4MB 2260ms 57ms graal/jvm 17.0.3
java 2-m.java 1861ms 8.6ms 131.2MB 3433ms 53ms graal/jvm 17.0.3

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 122ms 0.2ms 11.4MB 110ms 0ms odin 2022
java 1.java 291ms 1.2ms 57.3MB 267ms 63ms openjdk/zgc 18.0.1
odin 2.odin 303ms 3.5ms 2.9MB 293ms 0ms odin 2022
java 1.java 303ms 5.3ms 57.6MB 337ms 7ms openjdk 19
java 1.java 305ms 8.1ms 59.0MB 327ms 20ms openjdk 18.0.1
java 2.java 308ms 1.8ms 43.1MB 343ms 13ms openjdk 18.0.1
java 2.java 311ms 1.2ms 46.3MB 357ms 7ms openjdk 19
java 2.java 335ms 1.3ms 43.4MB 330ms 50ms openjdk/zgc 18.0.1
java 1.java 645ms 7.3ms 138.8MB 467ms 47ms graal/jvm 17.0.3
java 2.java 927ms 5.2ms 131.1MB 1097ms 43ms graal/jvm 17.0.3

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 4196ms 119ms 114.4MB 8067ms 43ms graal/jvm 17.0.3
odin 1.odin 4493ms 1.5ms 2.9MB 4480ms 0ms odin 2022
java 2.java timeout 0.0ms 0.0MB 0ms 0ms openjdk 18.0.1
java 2.java timeout 0.0ms 0.0MB 0ms 0ms openjdk 19
java 2.java timeout 0.0ms 0.0MB 0ms 0ms openjdk/zgc 18.0.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 1128ms 0.4ms 2.4MB 1120ms 0ms odin 2022
java 2-m.java 1250ms 41ms 113.4MB 2290ms 43ms graal/jvm 17.0.3
java 2-m.java 1869ms 283ms 40.1MB 3540ms 17ms openjdk 19
java 2-m.java 2399ms 256ms 38.9MB 4587ms 13ms openjdk 18.0.1
java 2-m.java 2632ms 59ms 38.7MB 4990ms 53ms openjdk/zgc 18.0.1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 285ms 0.2ms 1.9MB 273ms 0ms odin 2022
java 2-m.java 550ms 46ms 39.9MB 977ms 10ms openjdk 19
java 2-m.java 719ms 15ms 40.3MB 1293ms 23ms openjdk 18.0.1
java 2.java 745ms 21ms 103.0MB 733ms 23ms graal/jvm 17.0.3
java 2-m.java 782ms 4.4ms 39.0MB 1343ms 57ms openjdk/zgc 18.0.1