Java VS Acton benchmarks

Current benchmark data was generated on Thu May 04 2023, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][2 cores] Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz (Model 85)

* -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 760ms 15ms 411.4MB 753ms 127ms openjdk 21
java 2.java 796ms 69ms 410.1MB 707ms 147ms openjdk 20
java 2.java 943ms 154ms 896.1MB 940ms 253ms graal/jvm 17.0.7
java 2.java 1387ms 14ms 1006.5MB 1000ms 623ms openjdk/zgc 20

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2.java 184ms 8.1ms 110.1MB 177ms 30ms openjdk 20
java 2.java 190ms 15ms 109.9MB 170ms 40ms openjdk 21
java 2.java 208ms 22ms 163.1MB 237ms 67ms graal/jvm 17.0.7
java 2.java 342ms 5.5ms 238.9MB 177ms 187ms openjdk/zgc 20

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
acton 1.act 399ms 21ms 9.9MB 380ms 10ms actonc 0.15.0
java 1-m.java 837ms 65ms 229.0MB 1427ms 103ms openjdk 20
java 1-m.java 873ms 26ms 322.0MB 1500ms 113ms graal/jvm 17.0.7
java 1-m.java 881ms 101ms 226.6MB 1523ms 90ms openjdk 21
java 1-m.java 1018ms 15ms 426.4MB 1433ms 323ms openjdk/zgc 20

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
acton 1.act 210ms 49ms 8.3MB 125ms 5ms actonc 0.15.0
java 1-m.java 396ms 11ms 167.7MB 623ms 60ms graal/jvm 17.0.7
java 1-m.java 424ms 42ms 115.3MB 697ms 33ms openjdk 20
java 1-m.java 458ms 30ms 118.7MB 733ms 47ms openjdk 21
java 1-m.java 557ms 36ms 206.4MB 753ms 177ms openjdk/zgc 20

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1-m.java 1508ms 127ms 91.9MB 2813ms 43ms graal/jvm 17.0.7
java 1-m.java 1523ms 27ms 40.7MB 2870ms 20ms openjdk 20
java 1-m.java 1561ms 54ms 40.6MB 2873ms 60ms openjdk/zgc 20
java 1-m.java 1592ms 97ms 43.3MB 3020ms 20ms openjdk 21

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1-m.java 263ms 8.1ms 42.9MB 417ms 20ms openjdk 21
java 1-m.java 270ms 1.9ms 40.7MB 410ms 20ms openjdk 20
java 1-m.java 294ms 7.3ms 91.6MB 460ms 37ms graal/jvm 17.0.7
java 1-m.java 320ms 10ms 42.1MB 417ms 63ms openjdk/zgc 20

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 4.java 470ms 7.5ms 42.9MB 543ms 20ms openjdk 21
java 4.java 472ms 5.3ms 40.4MB 543ms 17ms openjdk 20
java 4.java 515ms 15ms 42.0MB 537ms 63ms openjdk/zgc 20
java 4.java 546ms 2.3ms 97.6MB 750ms 30ms graal/jvm 17.0.7

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 4.java 149ms 9.4ms 39.8MB 170ms 10ms openjdk 20
java 4.java 156ms 2.6ms 42.3MB 177ms 10ms openjdk 21
java 4.java 176ms 14ms 87.9MB 203ms 23ms graal/jvm 17.0.7
java 4.java 199ms 6.4ms 38.8MB 160ms 70ms openjdk/zgc 20

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
acton 1.act 5.1ms 2.3ms 7.6MB 0ms 0ms actonc 0.15.0
java 1.java 84ms 7.3ms 60.1MB 66ms 20ms graal/jvm 17.0.7
java 1.java 90ms 7.4ms 41.4MB 80ms 18ms openjdk 21
java 1.java 92ms 6.2ms 39.2MB 80ms 20ms openjdk 20
java 1.java 136ms 5.9ms 38.5MB 72ms 72ms openjdk/zgc 20

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 3-m.java 1436ms 40ms 115.6MB 2610ms 47ms openjdk 20
java 3-m.java 1469ms 39ms 115.0MB 2647ms 57ms openjdk 21
java 3-m.java 1541ms 39ms 169.1MB 2777ms 57ms graal/jvm 17.0.7
java 3-m.java 1994ms 21ms 172.7MB 3493ms 147ms openjdk/zgc 20

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 3-m.java 455ms 21ms 85.4MB 717ms 43ms openjdk 20
java 3-m.java 471ms 33ms 93.3MB 757ms 47ms openjdk 21
java 3-m.java 480ms 6.5ms 132.7MB 787ms 53ms graal/jvm 17.0.7
java 3-m.java 491ms 11ms 94.3MB 713ms 90ms openjdk/zgc 20

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1b.java 1513ms 16ms 47.3MB 1603ms 17ms openjdk 20
java 1b.java 1541ms 16ms 49.7MB 1650ms 17ms openjdk 21
java 1b.java 1586ms 24ms 46.1MB 1633ms 73ms openjdk/zgc 20
java 1b.java 1601ms 72ms 103.8MB 1807ms 33ms graal/jvm 17.0.7
java 1a.java 1813ms 2.1ms 47.6MB 1887ms 20ms openjdk 20
java 1a.java 1824ms 2.3ms 49.6MB 1897ms 23ms openjdk 21
java 1a.java 1883ms 8.9ms 47.8MB 1883ms 63ms openjdk/zgc 20
java 1a.java 1991ms 115ms 118.0MB 2260ms 40ms graal/jvm 17.0.7
java 1.java 2084ms 28ms 244.5MB 2243ms 63ms graal/jvm 17.0.7
java 1.java 2164ms 5.1ms 210.6MB 2180ms 60ms openjdk 20
java 1.java 2177ms 8.0ms 205.1MB 2207ms 60ms openjdk 21
java 1.java 2595ms 30ms 561.1MB 2310ms 397ms openjdk/zgc 20
java 2.java timeout 0.0ms 581.3MB 5107ms 180ms openjdk 20
java 2.java timeout 0.0ms 541.0MB 5110ms 183ms openjdk 21
java 2.java timeout 0.0ms 1583.6MB 4517ms 870ms openjdk/zgc 20

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1b.java 232ms 12ms 42.7MB 297ms 17ms openjdk 20
java 1a.java 239ms 3.4ms 45.6MB 300ms 23ms openjdk 21
java 1b.java 245ms 8.9ms 45.2MB 320ms 23ms openjdk 21
java 1a.java 247ms 18ms 43.4MB 333ms 13ms openjdk 20
java 1.java 250ms 8.0ms 95.3MB 300ms 27ms openjdk 20
java 1a.java 250ms 14ms 92.4MB 317ms 30ms graal/jvm 17.0.7
java 1.java 258ms 11ms 98.8MB 293ms 30ms openjdk 21
java 1.java 264ms 3.9ms 104.6MB 333ms 40ms graal/jvm 17.0.7
java 1a.java 273ms 6.0ms 43.1MB 263ms 67ms openjdk/zgc 20
java 1b.java 283ms 12ms 43.0MB 277ms 70ms openjdk/zgc 20
java 1b-m.java 308ms 35ms 98.7MB 467ms 30ms graal/jvm 17.0.7
java 1.java 312ms 4.2ms 110.2MB 270ms 107ms openjdk/zgc 20
java 2.java 898ms 16ms 625.5MB 1023ms 190ms openjdk 21
java 2.java 919ms 35ms 577.3MB 1053ms 177ms openjdk 20
java 2.java 1641ms 67ms 1138.9MB 1160ms 747ms openjdk/zgc 20

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 598ms 6.9ms 289.1MB 613ms 87ms openjdk 21
java 1.java 601ms 11ms 286.7MB 593ms 100ms openjdk 20
java 1.java 680ms 69ms 380.0MB 887ms 117ms graal/jvm 17.0.7
java 1.java 1084ms 8.4ms 728.2MB 723ms 500ms openjdk/zgc 20

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 261ms 14ms 224.4MB 250ms 70ms openjdk 21
java 1.java 264ms 10ms 222.4MB 253ms 63ms openjdk 20
java 1-m.java 315ms 15ms 283.2MB 417ms 70ms graal/jvm 17.0.7
java 1.java 462ms 6.1ms 329.4MB 273ms 230ms openjdk/zgc 20

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 588ms 5.5ms 89.6MB 607ms 33ms graal/jvm 17.0.7
java 1.java 637ms 4.7ms 42.0MB 643ms 20ms openjdk 21
java 1.java 649ms 5.6ms 40.4MB 647ms 17ms openjdk 20
java 1.java 710ms 8.6ms 41.8MB 667ms 70ms openjdk/zgc 20
java 2.java 2285ms 14ms 489.1MB 2303ms 120ms openjdk 21
java 2.java 2295ms 14ms 516.0MB 2287ms 140ms openjdk 20
java 2.java 3392ms 24ms 1591.2MB 2457ms 1127ms openjdk/zgc 20

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 154ms 4.6ms 88.0MB 183ms 30ms graal/jvm 17.0.7
java 1.java 164ms 3.9ms 40.7MB 167ms 13ms openjdk 20
java 1.java 168ms 2.4ms 42.6MB 167ms 23ms openjdk 21
java 1.java 224ms 8.8ms 42.0MB 163ms 83ms openjdk/zgc 20
java 2.java 487ms 3.9ms 345.5MB 530ms 90ms openjdk 21
java 2.java 492ms 7.0ms 340.3MB 517ms 103ms openjdk 20
java 2.java 806ms 5.1ms 484.6MB 577ms 380ms openjdk/zgc 20

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2.java 1027ms 10ms 50.9MB 1057ms 17ms openjdk 20
java 2.java 1029ms 12ms 52.3MB 1063ms 20ms openjdk 21
java 2.java 1043ms 2.9ms 50.8MB 1007ms 83ms openjdk/zgc 20
java 1.java 1347ms 62ms 86.3MB 1370ms 23ms openjdk 21
java 1.java 1439ms 80ms 85.0MB 1457ms 37ms openjdk 20
java 1.java 1524ms 5.5ms 108.7MB 1457ms 110ms openjdk/zgc 20
java 1.java 1774ms 138ms 236.8MB 2413ms 107ms graal/jvm 17.0.7
java 2-m.java 1888ms 238ms 278.5MB 3250ms 110ms graal/jvm 17.0.7

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 246ms 8.7ms 60.2MB 273ms 17ms openjdk 21
java 1.java 247ms 6.3ms 58.8MB 270ms 23ms openjdk 20
java 1.java 318ms 8.6ms 57.5MB 270ms 93ms openjdk/zgc 20
java 2.java 330ms 4.0ms 45.0MB 360ms 13ms openjdk 20
java 2.java 333ms 4.9ms 46.6MB 350ms 20ms openjdk 21
java 1.java 351ms 12ms 121.8MB 483ms 33ms graal/jvm 17.0.7
java 2.java 374ms 3.0ms 42.1MB 340ms 70ms openjdk/zgc 20
java 2-m.java 665ms 4.4ms 163.4MB 1143ms 83ms graal/jvm 17.0.7

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
acton 1.act 4678ms 101ms 16.2MB 5003ms 950ms actonc 0.15.0
java 1.java timeout 0.0ms 315.5MB 5480ms 140ms graal/jvm 17.0.7
java 1.java timeout 0.0ms 329.4MB 5380ms 133ms openjdk 20
java 1.java timeout 0.0ms 334.5MB 5677ms 147ms openjdk 21
java 1.java timeout 0.0ms 1358.3MB 4887ms 877ms openjdk/zgc 20

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
acton 1.act 1325ms 199ms 18.5MB 1337ms 263ms actonc 0.15.0
java 1.java 1494ms 10ms 272.7MB 2073ms 107ms openjdk 21
java 1.java 1531ms 6.0ms 302.9MB 1913ms 97ms graal/jvm 17.0.7
java 1.java 1538ms 8.2ms 285.5MB 1813ms 90ms openjdk 20
java 1.java 2156ms 49ms 1042.1MB 1923ms 810ms openjdk/zgc 20

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 3.java timeout 0.0ms 252.3MB 5367ms 90ms graal/jvm 17.0.7
java 3.java timeout 0.0ms 202.3MB 5253ms 60ms openjdk 20
java 3.java timeout 0.0ms 241.0MB 5237ms 83ms openjdk 21
java 3.java timeout 0.0ms 337.3MB 4933ms 263ms openjdk/zgc 20

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 3.java 1003ms 11ms 102.7MB 1307ms 47ms openjdk 21
java 3.java 1035ms 19ms 169.4MB 1463ms 67ms graal/jvm 17.0.7
java 3.java 1037ms 24ms 112.3MB 1353ms 40ms openjdk 20
java 3.java 1156ms 14ms 156.1MB 1313ms 140ms openjdk/zgc 20

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 4343ms 20ms 90.0MB 8373ms 20ms graal/jvm 17.0.7
java 2.java timeout 0.0ms 40.5MB 9717ms 17ms openjdk 20
java 2.java timeout 0.0ms 41.8MB 9700ms 27ms openjdk 21
java 2.java timeout 0.0ms 42.2MB 9607ms 60ms openjdk/zgc 20

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 1240ms 3.4ms 88.9MB 2287ms 27ms graal/jvm 17.0.7
java 2-m.java 1862ms 90ms 42.5MB 3503ms 33ms openjdk 21
java 2-m.java 1993ms 62ms 40.8MB 3773ms 20ms openjdk 20
java 2-m.java 2007ms 19ms 40.3MB 3713ms 77ms openjdk/zgc 20

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2-m.java 433ms 5.1ms 91.3MB 710ms 33ms graal/jvm 17.0.7
java 2-m.java 604ms 20ms 42.4MB 1047ms 17ms openjdk 21
java 2-m.java 612ms 8.9ms 40.5MB 1067ms 23ms openjdk 20
java 2-m.java 675ms 22ms 42.2MB 1073ms 80ms openjdk/zgc 20

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1-m.java 1616ms 2799ms 141.4MB 9493ms 107ms openjdk 20
java 1.java timeout 0.0ms 145.1MB 9580ms 70ms openjdk 21
java 1.java timeout 0.0ms 927.6MB 8763ms 523ms openjdk/zgc 20

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1-m.java 733ms 65ms 114.3MB 1263ms 63ms openjdk 21
java 1-m.java 780ms 33ms 111.7MB 1370ms 57ms openjdk 20
java 1-m.java 980ms 106ms 304.2MB 1567ms 193ms openjdk/zgc 20