Odin VS Java 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
java 2.java 428ms 6.0ms 574.2MB 503ms 83ms openjdk 21
java 2-m.java 448ms 5.4ms 648.6MB 620ms 120ms graal/jvm 17.0.8
java 2.java 451ms 8.7ms 650.1MB 557ms 87ms openjdk 23
java 2.java 1140ms 6.2ms 1085.8MB 540ms 753ms openjdk/zgc 21
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
java 2-m.java 117ms 3.3ms 167.6MB 147ms 30ms openjdk 21
java 2.java 122ms 6.2ms 98.2MB 143ms 33ms openjdk 23
java 2-m.java 153ms 9.8ms 226.4MB 223ms 60ms graal/jvm 17.0.8
odin 1.odin 207ms 1.9ms 7.5MB 193ms 0ms odin 2024
java 2.java 289ms 1.8ms 241.5MB 147ms 187ms openjdk/zgc 21

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
java 1.java 61ms 1.3ms 58.6MB 60ms 20ms graal/jvm 17.0.8
java 1.java 69ms 2.9ms 44.7MB 66ms 14ms openjdk 23
java 1.java 69ms 1.0ms 43.8MB 72ms 10ms openjdk 21
java 1.java 174ms 5.3ms 44.5MB 80ms 116ms openjdk/zgc 21

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
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
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
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
java 1b.java 1088ms 25ms 55.9MB 1183ms 20ms openjdk 23
java 1b.java 1099ms 9.8ms 54.1MB 1203ms 10ms openjdk 21
java 1b.java 1140ms 3.0ms 114.0MB 1380ms 43ms graal/jvm 17.0.8
java 1.java 1186ms 11ms 134.8MB 1287ms 43ms graal/jvm 17.0.8
java 1b.java 1206ms 5.6ms 51.0MB 1187ms 130ms openjdk/zgc 21
java 1a.java 1561ms 13ms 54.8MB 1640ms 30ms openjdk 21
java 1a.java 1568ms 7.1ms 56.5MB 1640ms 33ms openjdk 23
java 1a.java 1588ms 7.8ms 104.9MB 1690ms 37ms graal/jvm 17.0.8
java 1.java 1614ms 17ms 299.9MB 1663ms 50ms openjdk 23
java 1.java 1619ms 19ms 202.2MB 1683ms 37ms openjdk 21
java 1a.java 1691ms 11ms 53.0MB 1660ms 133ms openjdk/zgc 21
java 1.java 2222ms 9.3ms 839.9MB 1657ms 657ms openjdk/zgc 21
java 2.java timeout 0.0ms 680.4MB 5250ms 110ms openjdk 21
java 2.java timeout 0.0ms 804.6MB 5267ms 103ms openjdk 23
java 2.java timeout 0.0ms 3394.0MB 3423ms 1930ms openjdk/zgc 21

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
java 1b-m.java 168ms 7.4ms 51.1MB 263ms 17ms openjdk 23
java 1b-m.java 170ms 15ms 49.4MB 277ms 13ms openjdk 21
java 1a-m.java 174ms 1.1ms 51.2MB 267ms 17ms openjdk 21
java 1-m.java 178ms 1.8ms 82.0MB 243ms 27ms openjdk 21
java 1-m.java 181ms 5.7ms 87.0MB 250ms 27ms openjdk 23
java 1a-m.java 183ms 9.6ms 53.2MB 283ms 17ms openjdk 23
java 1-m.java 188ms 1.2ms 117.5MB 273ms 50ms graal/jvm 17.0.8
java 1a-m.java 205ms 3.9ms 100.0MB 310ms 33ms graal/jvm 17.0.8
java 1b-m.java 215ms 23ms 105.6MB 353ms 43ms graal/jvm 17.0.8
java 1a.java 293ms 9.5ms 49.8MB 270ms 133ms openjdk/zgc 21
java 1b.java 303ms 9.4ms 49.6MB 287ms 133ms openjdk/zgc 21
java 1.java 319ms 10ms 114.2MB 250ms 153ms openjdk/zgc 21
java 2-m.java 516ms 21ms 556.8MB 793ms 73ms openjdk 21
java 2-m.java 532ms 10ms 751.9MB 800ms 93ms openjdk 23
java 2.java 1560ms 7.7ms 1436.9MB 800ms 1043ms openjdk/zgc 21

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
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
java 1.java 417ms 2.4ms 45.2MB 450ms 13ms openjdk 21
java 1.java 420ms 6.1ms 48.2MB 450ms 20ms openjdk 23
java 1.java 429ms 7.0ms 85.0MB 457ms 27ms graal/jvm 17.0.8
java 1.java 530ms 6.4ms 46.5MB 450ms 130ms openjdk/zgc 21
java 2.java 1166ms 4.4ms 571.8MB 1293ms 77ms openjdk 21
java 2.java 1187ms 9.7ms 717.8MB 1287ms 90ms openjdk 23
java 2.java 3101ms 57ms 2431.6MB 1560ms 1743ms openjdk/zgc 21

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
odin 1.odin 37ms 0.6ms 1.5MB 30ms 0ms odin 2024
java 1.java 111ms 2.5ms 45.2MB 137ms 20ms openjdk 21
java 1.java 112ms 0.7ms 87.3MB 130ms 30ms graal/jvm 17.0.8
java 1.java 114ms 1.2ms 48.5MB 140ms 20ms openjdk 23
java 1.java 230ms 5.1ms 46.5MB 150ms 133ms openjdk/zgc 21
java 2-m.java 289ms 6.3ms 348.4MB 407ms 70ms openjdk 23
java 2-m.java 293ms 18ms 355.0MB 440ms 30ms openjdk 21
java 2.java 658ms 2.3ms 536.9MB 437ms 403ms openjdk/zgc 21

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
java 1.java 367ms 5.0ms 118.1MB 397ms 27ms openjdk 23
java 1.java 367ms 3.8ms 114.6MB 413ms 27ms openjdk 21
java 1.java 535ms 4.6ms 114.6MB 440ms 157ms openjdk/zgc 21
java 1-m.java 654ms 9.2ms 208.3MB 983ms 70ms graal/jvm 17.0.8
odin 2.odin 662ms 40ms 6.5MB 647ms 0ms odin 2024
java 2.java 734ms 5.2ms 57.1MB 777ms 23ms openjdk 21
java 2.java 750ms 10ms 60.4MB 790ms 20ms openjdk 23
java 2.java 804ms 11ms 53.3MB 740ms 130ms openjdk/zgc 21
java 2-m.java 1277ms 30ms 265.2MB 2290ms 83ms graal/jvm 17.0.8

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
java 1.java 140ms 4.3ms 68.2MB 177ms 17ms openjdk 23
java 1.java 151ms 8.4ms 65.3MB 200ms 17ms openjdk 21
odin 2.odin 166ms 14ms 2.8MB 153ms 0ms odin 2024
java 1-m.java 210ms 26ms 127.6MB 297ms 50ms graal/jvm 17.0.8
java 2.java 244ms 4.8ms 50.3MB 297ms 20ms openjdk 21
java 2.java 249ms 5.7ms 50.9MB 290ms 20ms openjdk 23
java 1.java 264ms 1.7ms 63.3MB 193ms 133ms openjdk/zgc 21
java 2.java 348ms 11ms 49.4MB 273ms 137ms openjdk/zgc 21
java 2-m.java 489ms 42ms 151.7MB 883ms 47ms 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 1867ms 20ms 47.6MB 7143ms 20ms openjdk 21
java 2-m.java 1877ms 26ms 49.0MB 7130ms 20ms openjdk 23
java 2-m.java 1981ms 11ms 45.4MB 7137ms 137ms openjdk/zgc 21
java 2-m.java 2318ms 11ms 100.9MB 8233ms 47ms graal/jvm 17.0.8
odin 1.odin 3403ms 22ms 2.9MB 3390ms 0ms odin 2024

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 557ms 2.8ms 48.4MB 1953ms 27ms openjdk 23
java 2-m.java 558ms 2.6ms 47.5MB 1963ms 23ms openjdk 21
java 2-m.java 676ms 7.0ms 45.6MB 1957ms 140ms openjdk/zgc 21
java 2-m.java 688ms 5.7ms 98.9MB 2293ms 57ms graal/jvm 17.0.8
odin 1.odin 846ms 8.4ms 2.3MB 837ms 0ms odin 2024

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
java 2-m.java 229ms 5.7ms 48.4MB 670ms 23ms openjdk 23
java 2-m.java 238ms 14ms 47.6MB 693ms 20ms openjdk 21
java 2-m.java 281ms 23ms 101.8MB 823ms 40ms graal/jvm 17.0.8
java 2-m.java 346ms 3.4ms 47.1MB 667ms 133ms openjdk/zgc 21