Haxe VS Go benchmarks

Current benchmark data was generated on Fri Sep 30 2022, 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
haxe 1.hx 1986ms 38ms 146.0MB 2520ms 67ms haxe/cpp 4.2.5
go 1.go 3077ms 30ms 45.6MB 4420ms 73ms go 1.19.1
go 1.go 4620ms 32ms 38.6MB 4597ms 7ms tinygo 0.25.0
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.5
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.5
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.5
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 120ms 2.8ms 27.5MB 123ms 7ms haxe/cpp 4.2.5
go 1.go 259ms 1.6ms 8.0MB 343ms 3ms go 1.19.1
go 1.go 368ms 2.5ms 5.9MB 357ms 0ms tinygo 0.25.0
haxe 2.hx 533ms 4.3ms 60.2MB 650ms 27ms haxe/cpp 4.2.5
haxe 1.hx 868ms 1.6ms 7.8MB 833ms 17ms haxe/hl/c 4.2.5
haxe 1.hx 1025ms 4.8ms 11.3MB 977ms 33ms haxe/hl/jit 1.12.0
haxe 2.hx 1372ms 9.2ms 13.4MB 1260ms 97ms haxe/hl/c 4.2.5
haxe 2.hx 1694ms 20ms 24.6MB 1530ms 143ms haxe/hl/jit 1.12.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 207ms 4.9ms 2.9MB 370ms 0ms go 1.19.1
haxe 1.hx 3164ms 18ms 27.5MB 3210ms 243ms haxe/cpp 4.2.5
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.5
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 27ms 1.4ms 4.9MB 30ms 0ms go 1.19.1
haxe 1.hx 336ms 2.9ms 27.5MB 320ms 23ms haxe/cpp 4.2.5
haxe 1.hx 836ms 21ms 3.3MB 757ms 63ms haxe/hl/c 4.2.5
haxe 1.hx 859ms 3.8ms 3.8MB 803ms 37ms haxe/hl/jit 1.12.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 2.1ms 0.8ms 2.0MB 0ms 0ms tinygo 0.25.0
haxe 1.hx 3.2ms 0.8ms 3.0MB 0ms 0ms haxe/cpp 4.2.5
go 1.go 3.4ms 0.5ms 2.9MB 0ms 0ms go 1.19.1
haxe 1.hx 3.9ms 0.2ms 3.3MB 0ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx 4.1ms 2.2ms 2.6MB 0ms 0ms haxe/hl/c 4.2.5

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 160ms 0.5ms 0.3MB 150ms 0ms tinygo 0.25.0
go 3.go 170ms 0.3ms 2.8MB 157ms 0ms go 1.19.1
haxe 1.hx 189ms 1.4ms 22.2MB 177ms 0ms haxe/cpp 4.2.5
haxe 1.hx 211ms 1.2ms 2.9MB 200ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 241ms 0.4ms 3.8MB 223ms 0ms haxe/hl/jit 1.12.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 475ms 1.0ms 0.3MB 460ms 0ms tinygo 0.25.0
go 3.go 490ms 2.3ms 2.9MB 480ms 0ms go 1.19.1
haxe 1.hx 542ms 12ms 27.4MB 533ms 7ms haxe/cpp 4.2.5
haxe 1.hx 626ms 1.6ms 3.0MB 613ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 719ms 9.8ms 3.7MB 707ms 0ms haxe/hl/jit 1.12.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 79ms 0.2ms 2.0MB 70ms 0ms tinygo 0.25.0
haxe 1.hx 87ms 1.8ms 14.2MB 67ms 7ms haxe/cpp 4.2.5
go 3.go 90ms 0.3ms 3.6MB 80ms 0ms go 1.19.1
haxe 1.hx 105ms 2.4ms 2.9MB 93ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 119ms 0.9ms 3.8MB 110ms 0ms haxe/hl/jit 1.12.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 1381ms 4.3ms 97.0MB 1660ms 47ms haxe/cpp 4.2.5
go 1.go 2053ms 15ms 38.2MB 2917ms 47ms go 1.19.1
go 2.go 2357ms 19ms 41.1MB 3357ms 67ms go 1.19.1
go 1.go 3664ms 2.2ms 213.2MB 3600ms 47ms tinygo 0.25.0
go 2.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.5
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 248ms 4.7ms 28.6MB 253ms 10ms haxe/cpp 4.2.5
go 1.go 426ms 5.0ms 12.5MB 583ms 13ms go 1.19.1
go 2.go 492ms 3.3ms 14.1MB 680ms 10ms go 1.19.1
go 1.go 867ms 5.2ms 51.6MB 840ms 13ms tinygo 0.25.0
go 2.go 1183ms 11ms 39.3MB 1150ms 10ms tinygo 0.25.0
haxe 1.hx 1742ms 6.1ms 15.5MB 1663ms 60ms haxe/hl/c 4.2.5
haxe 1.hx 2026ms 52ms 20.4MB 1913ms 97ms haxe/hl/jit 1.12.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 505ms 1.8ms 2.9MB 490ms 0ms go 1.19.1
go 1.go 706ms 0.5ms 0.0MB 690ms 0ms tinygo 0.25.0
haxe 2.hx 1083ms 6.6ms 2.6MB 1070ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 1505ms 76ms 2.6MB 1493ms 0ms haxe/hl/c 4.2.5
haxe 3.hx 2176ms 1.2ms 25.6MB 2470ms 43ms haxe/cpp 4.2.5
haxe 2.hx 2441ms 1.5ms 3.4MB 2427ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx 2598ms 0.0ms 3.3MB 2587ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.5
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.5
haxe 3.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.5
haxe 3.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 56ms 3.1ms 2.9MB 47ms 0ms go 1.19.1
go 1.go 73ms 0.5ms 0.0MB 60ms 0ms tinygo 0.25.0
haxe 2.hx 113ms 3.3ms 2.6MB 100ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 149ms 1.1ms 2.6MB 140ms 0ms haxe/hl/c 4.2.5
haxe 3.hx 237ms 2.0ms 27.6MB 250ms 7ms haxe/cpp 4.2.5
haxe 2.hx 255ms 8.1ms 3.4MB 243ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx 268ms 6.6ms 3.3MB 253ms 0ms haxe/hl/jit 1.12.0
haxe 3.hx 762ms 4.4ms 3.2MB 683ms 60ms haxe/hl/c 4.2.5
haxe 2.hx 833ms 0.9ms 4.4MB 820ms 0ms haxe/cpp 4.2.5
haxe 3.hx 903ms 6.5ms 3.7MB 830ms 60ms haxe/hl/jit 1.12.0
haxe 1.hx 1072ms 1.7ms 3.1MB 1060ms 0ms haxe/cpp 4.2.5

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 2208ms 2.6ms 5.4MB 4297ms 0ms go 1.19.1
go 1.go 4328ms 2.9ms 5.4MB 4320ms 0ms go 1.19.1
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.5
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.5
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 562ms 0.5ms 2.9MB 1063ms 0ms go 1.19.1
go 1.go 1087ms 1.7ms 2.9MB 1080ms 0ms go 1.19.1
haxe 1.hx 1946ms 1.0ms 3.2MB 1930ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 1956ms 3.8ms 6.5MB 1943ms 0ms haxe/cpp 4.2.5
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/jit 1.12.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 151ms 0.3ms 2.9MB 267ms 3ms go 1.19.1
go 1.go 276ms 3.0ms 2.9MB 267ms 0ms go 1.19.1
haxe 1.hx 491ms 0.8ms 3.0MB 477ms 0ms haxe/hl/c 4.2.5
haxe 1.hx 493ms 1.5ms 5.2MB 480ms 0ms haxe/cpp 4.2.5
go 1.go 1639ms 1.0ms 0.0MB 1630ms 0ms tinygo 0.25.0
haxe 1.hx 2846ms 0.1ms 3.8MB 2840ms 0ms haxe/hl/jit 1.12.0