Hack VS Haxe 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.)

binarytrees

Input: 18

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 1746ms 39ms 146.0MB 2053ms 50ms haxe/cpp 4.2.4
hacklang 1.hack timeout 0.0ms 0.0MB 0ms 0ms hhvm 4.160.0
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.4
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.4
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.4
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 112ms 1.7ms 27.4MB 113ms 7ms haxe/cpp 4.2.4
haxe 2.hx 471ms 7.8ms 60.2MB 547ms 27ms haxe/cpp 4.2.4
haxe 1.hx 799ms 17ms 7.8MB 757ms 23ms haxe/hl/c 4.2.4
haxe 1.hx 1052ms 5.0ms 11.1MB 1000ms 37ms haxe/hl/jit 1.12.0
haxe 2.hx 1257ms 16ms 13.5MB 1083ms 160ms haxe/hl/c 4.2.4
hacklang 1.hack 1312ms 4.7ms 185.1MB 1253ms 43ms hhvm 4.160.0
haxe 2.hx 1595ms 8.6ms 24.5MB 1413ms 167ms haxe/hl/jit 1.12.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
hacklang 1.hack 1939ms 42ms 173.6MB 1887ms 40ms hhvm 4.160.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
hacklang 1.hack 945ms 2.0ms 173.4MB 903ms 27ms hhvm 4.160.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 2.2ms 0.7ms 2.6MB 0ms 0ms haxe/hl/c 4.2.4
haxe 1.hx 2.7ms 0.4ms 3.2MB 0ms 0ms haxe/cpp 4.2.4
haxe 1.hx 4.0ms 0.7ms 3.3MB 0ms 0ms haxe/hl/jit 1.12.0
hacklang 1.hack 752ms 2.1ms 169.3MB 706ms 34ms hhvm 4.160.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 1165ms 17ms 97.0MB 1357ms 37ms haxe/cpp 4.2.4
hacklang 1.hack 4692ms 18ms 237.9MB 4630ms 43ms hhvm 4.160.0
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.4
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 222ms 3.5ms 28.6MB 230ms 10ms haxe/cpp 4.2.4
haxe 1.hx 1591ms 10ms 15.3MB 1497ms 77ms haxe/hl/c 4.2.4
hacklang 1.hack 1628ms 8.5ms 188.1MB 1580ms 33ms hhvm 4.160.0
haxe 1.hx 1950ms 6.7ms 20.4MB 1800ms 133ms haxe/hl/jit 1.12.0