Odin VS Java benchmarks

Current benchmark data was generated on Thu May 01 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
java 2.java 458ms 2.1ms 574.1MB 557ms 83ms openjdk 21
java 2.java 472ms 4.2ms 620.6MB 573ms 107ms openjdk 23
java 2-m.java 478ms 13ms 644.0MB 667ms 127ms graal/jvm 17.0.8
java 2.java 1199ms 18ms 1054.6MB 590ms 770ms openjdk/zgc 21
odin 1.odin 2300ms 35ms 49.5MB 2267ms 17ms odin 2024

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 124ms 1.9ms 98.4MB 163ms 30ms openjdk 23
java 2-m.java 127ms 2.5ms 167.1MB 160ms 30ms openjdk 21
java 2-m.java 144ms 4.4ms 215.0MB 210ms 60ms graal/jvm 17.0.8
odin 1.odin 219ms 3.5ms 7.5MB 207ms 0ms odin 2024
java 2.java 305ms 0.9ms 241.8MB 150ms 207ms openjdk/zgc 21

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.6MB 0ms 0ms odin 2024
java 1.java 62ms 1.3ms 52.7MB 66ms 18ms graal/jvm 17.0.8
java 1.java 71ms 1.1ms 43.7MB 74ms 12ms openjdk 21
java 1.java 72ms 2.0ms 44.7MB 76ms 14ms openjdk 23
java 1.java 189ms 5.2ms 42.9MB 80ms 136ms openjdk/zgc 21

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 156ms 3.3ms 1.6MB 150ms 0ms odin 2024

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 458ms 2.9ms 1.6MB 450ms 0ms odin 2024

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 71ms 1.8ms 1.6MB 63ms 0ms odin 2024

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 288ms 4.5ms 4.6MB 277ms 0ms odin 2024
java 1b.java 1143ms 6.0ms 54.5MB 1230ms 27ms openjdk 23
java 1b.java 1166ms 5.0ms 54.4MB 1283ms 20ms openjdk 21
java 1b.java 1185ms 32ms 110.7MB 1397ms 40ms graal/jvm 17.0.8
java 1.java 1257ms 4.7ms 126.5MB 1383ms 47ms graal/jvm 17.0.8
java 1b.java 1288ms 8.7ms 51.3MB 1290ms 140ms openjdk/zgc 21
java 1a.java 1656ms 5.8ms 55.0MB 1757ms 23ms openjdk 21
java 1a.java 1660ms 5.5ms 56.7MB 1753ms 27ms openjdk 23
java 1a.java 1684ms 4.3ms 102.5MB 1790ms 40ms graal/jvm 17.0.8
java 1.java 1702ms 3.6ms 202.6MB 1780ms 37ms openjdk 21
java 1.java 1714ms 2.2ms 307.8MB 1770ms 57ms openjdk 23
java 1a.java 1779ms 6.2ms 52.0MB 1760ms 143ms openjdk/zgc 21
java 1.java 2363ms 9.5ms 848.7MB 1777ms 693ms openjdk/zgc 21
java 2.java timeout 0.0ms 752.2MB 5260ms 123ms openjdk 21
java 2.java timeout 0.0ms 762.3MB 5257ms 143ms openjdk 23
java 2.java timeout 0.0ms 3447.8MB 3350ms 1987ms openjdk/zgc 21

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 14ms 0.2ms 1.6MB 10ms 0ms odin 2024
java 1b-m.java 168ms 6.8ms 49.5MB 260ms 20ms openjdk 21
java 1b-m.java 177ms 12ms 51.3MB 273ms 23ms openjdk 23
java 1a-m.java 186ms 2.3ms 50.0MB 290ms 20ms openjdk 21
java 1a-m.java 191ms 1.6ms 52.5MB 297ms 20ms openjdk 23
java 1-m.java 192ms 2.7ms 87.1MB 267ms 33ms openjdk 23
java 1-m.java 192ms 2.2ms 81.5MB 267ms 30ms openjdk 21
java 1-m.java 196ms 8.5ms 111.8MB 303ms 40ms graal/jvm 17.0.8
java 1a-m.java 210ms 2.1ms 98.7MB 313ms 43ms graal/jvm 17.0.8
java 1b-m.java 229ms 10ms 101.9MB 393ms 37ms graal/jvm 17.0.8
java 1b.java 316ms 26ms 47.9MB 317ms 140ms openjdk/zgc 21
java 1a.java 321ms 3.6ms 48.8MB 293ms 143ms openjdk/zgc 21
java 1.java 338ms 8.4ms 114.4MB 263ms 160ms openjdk/zgc 21
java 2-m.java 558ms 6.3ms 636.9MB 840ms 93ms openjdk 21
java 2-m.java 575ms 4.2ms 811.9MB 837ms 120ms openjdk 23
java 2.java 1616ms 60ms 1396.0MB 843ms 1073ms openjdk/zgc 21

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 355ms 2.4ms 1.5MB 347ms 0ms odin 2024
odin 1-i.odin 358ms 2.1ms 1.5MB 350ms 0ms odin 2024
java 1.java 440ms 3.0ms 45.1MB 477ms 20ms openjdk 21
java 1.java 444ms 1.1ms 48.2MB 480ms 20ms openjdk 23
java 1.java 447ms 4.2ms 81.5MB 483ms 27ms graal/jvm 17.0.8
java 1.java 570ms 5.4ms 44.7MB 497ms 133ms openjdk/zgc 21
java 2.java 1230ms 3.1ms 579.3MB 1353ms 83ms openjdk 21
java 2.java 1248ms 1.3ms 759.3MB 1357ms 110ms openjdk 23
java 2.java 3219ms 18ms 2343.5MB 1627ms 1803ms openjdk/zgc 21

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 38ms 0.9ms 1.5MB 30ms 0ms odin 2024
odin 1-i.odin 38ms 1.6ms 1.5MB 30ms 0ms odin 2024
java 1.java 119ms 2.0ms 45.2MB 157ms 20ms openjdk 21
java 1.java 120ms 1.7ms 48.4MB 157ms 20ms openjdk 23
java 1.java 125ms 4.1ms 81.6MB 153ms 33ms graal/jvm 17.0.8
java 1.java 243ms 3.0ms 44.8MB 167ms 140ms openjdk/zgc 21
java 2-m.java 286ms 3.4ms 356.7MB 417ms 53ms openjdk 21
java 2-m.java 310ms 7.8ms 413.9MB 440ms 70ms openjdk 23
java 2.java 684ms 9.8ms 530.4MB 453ms 420ms openjdk/zgc 21

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 286ms 4.5ms 40.6MB 273ms 3ms odin 2024
java 1.java 402ms 2.3ms 118.6MB 447ms 23ms openjdk 23
java 1.java 410ms 1.4ms 114.9MB 463ms 20ms openjdk 21
java 1.java 580ms 9.2ms 112.8MB 480ms 170ms openjdk/zgc 21
java 1-m.java 624ms 34ms 271.5MB 903ms 70ms graal/jvm 17.0.8
odin 2.odin 695ms 43ms 6.5MB 683ms 0ms odin 2024
java 2.java 781ms 2.9ms 57.3MB 840ms 17ms openjdk 21
java 2.java 782ms 2.8ms 60.3MB 833ms 23ms openjdk 23
java 2.java 841ms 5.2ms 53.3MB 770ms 140ms openjdk/zgc 21
java 2-m.java 1350ms 36ms 197.1MB 2433ms 97ms graal/jvm 17.0.8

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 55ms 5.9ms 11.4MB 43ms 0ms odin 2024
java 1.java 154ms 0.3ms 68.1MB 200ms 20ms openjdk 23
java 1.java 162ms 5.3ms 65.0MB 217ms 20ms openjdk 21
odin 2.odin 183ms 3.1ms 2.8MB 173ms 0ms odin 2024
java 1-m.java 205ms 14ms 137.8MB 287ms 43ms graal/jvm 17.0.8
java 2.java 259ms 1.4ms 50.0MB 323ms 17ms openjdk 21
java 2.java 262ms 7.0ms 50.4MB 310ms 17ms openjdk 23
java 1.java 287ms 3.4ms 61.6MB 210ms 147ms openjdk/zgc 21
java 2.java 370ms 1.9ms 47.3MB 310ms 143ms openjdk/zgc 21
java 2-m.java 472ms 2.1ms 145.4MB 833ms 63ms graal/jvm 17.0.8

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 1991ms 5.9ms 47.8MB 7610ms 23ms openjdk 21
java 2-m.java 1993ms 9.7ms 48.4MB 7613ms 30ms openjdk 23
java 2-m.java 2124ms 14ms 45.4MB 7600ms 157ms openjdk/zgc 21
java 2-m.java 2505ms 22ms 93.6MB 9400ms 40ms graal/jvm 17.0.8
odin 1.odin 3599ms 3.9ms 2.9MB 3590ms 0ms odin 2024

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 600ms 7.0ms 47.8MB 2137ms 20ms openjdk 21
java 2-m.java 609ms 4.3ms 48.7MB 2157ms 23ms openjdk 23
java 2-m.java 729ms 2.4ms 45.4MB 2157ms 140ms openjdk/zgc 21
java 2-m.java 768ms 0.7ms 93.5MB 2703ms 37ms graal/jvm 17.0.8
odin 1.odin 903ms 2.9ms 2.3MB 893ms 0ms odin 2024

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
odin 1.odin 228ms 0.8ms 1.9MB 220ms 0ms odin 2024
java 2-m.java 251ms 5.6ms 47.5MB 753ms 17ms openjdk 21
java 2-m.java 258ms 5.3ms 48.9MB 763ms 20ms openjdk 23
java 2-m.java 311ms 24ms 94.6MB 957ms 37ms graal/jvm 17.0.8
java 2-m.java 372ms 10ms 45.2MB 733ms 140ms openjdk/zgc 21