Kotlin VS Haxe benchmarks

Current benchmark data was generated on Wed May 25 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
kotlin 1.kt 712ms 0.5ms 307.9MB 740ms 87ms kotlin/jvm 17.0.2
haxe 1.hx 2041ms 26ms 145.9MB 2597ms 83ms haxe/cpp 4.2.4
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
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 136ms 1.9ms 27.5MB 143ms 13ms haxe/cpp 4.2.4
kotlin 1.kt 137ms 1.9ms 109.6MB 113ms 33ms kotlin/jvm 17.0.2
kotlin 1.kt 380ms 1.3ms 62.1MB 350ms 13ms kotlin/native 1.6.21
haxe 2.hx 558ms 7.7ms 60.3MB 723ms 27ms haxe/cpp 4.2.4
haxe 1.hx 882ms 3.1ms 7.8MB 847ms 20ms haxe/hl/c 4.2.4
haxe 1.hx 1145ms 6.0ms 11.1MB 1087ms 43ms haxe/hl/jit 1.12.0
haxe 2.hx 1473ms 23ms 13.5MB 1347ms 110ms haxe/hl/c 4.2.4
haxe 2.hx 1935ms 13ms 24.6MB 1740ms 177ms 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
kotlin 2-m.kt 3070ms 596ms 182.5MB 5807ms 87ms kotlin/jvm 17.0.2
kotlin 1.kt 3092ms 4.3ms 170.9MB 3890ms 70ms kotlin/jvm 17.0.2
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21
kotlin 2-m.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 706ms 27ms 93.2MB 1247ms 43ms kotlin/jvm 17.0.2
kotlin 2-m.kt 976ms 5.7ms 68.2MB 1703ms 33ms kotlin/native 1.6.21
kotlin 2-m.kt 1003ms 75ms 105.5MB 1820ms 40ms kotlin/jvm 17.0.2
kotlin 1.kt 1172ms 4.8ms 48.7MB 1147ms 10ms kotlin/native 1.6.21

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 2.6ms 0.9ms 1.2MB 0ms 0ms kotlin/native 1.6.21
haxe 1.hx 2.9ms 1.0ms 2.6MB 0ms 0ms haxe/hl/c 4.2.4
haxe 1.hx 3.4ms 0.6ms 3.2MB 0ms 0ms haxe/cpp 4.2.4
haxe 1.hx 4.9ms 0.5ms 3.3MB 0ms 0ms haxe/hl/jit 1.12.0
kotlin 1.kt 73ms 2.6ms 41.1MB 52ms 12ms kotlin/jvm 17.0.2

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/jvm 17.0.2
kotlin 2.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/jvm 17.0.2

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2-m.kt 2250ms 240ms 237.8MB 3337ms 303ms kotlin/jvm 17.0.2
kotlin 1-m.kt 2284ms 167ms 236.0MB 3647ms 287ms kotlin/jvm 17.0.2

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 1042ms 27ms 215.1MB 1737ms 83ms kotlin/jvm 17.0.2

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 4142ms 313ms 954.1MB 5743ms 387ms kotlin/jvm 17.0.2

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 191ms 0.8ms 22.2MB 173ms 7ms haxe/cpp 4.2.4
haxe 1.hx 212ms 1.2ms 2.9MB 197ms 0ms haxe/hl/c 4.2.4
kotlin 2-m.kt 243ms 1.3ms 112.3MB 323ms 47ms kotlin/jvm 17.0.2
haxe 1.hx 250ms 5.8ms 3.8MB 237ms 0ms haxe/hl/jit 1.12.0
kotlin 1.kt 256ms 2.6ms 109.7MB 307ms 33ms kotlin/jvm 17.0.2
kotlin 2.kt 395ms 25ms 92.1MB 363ms 13ms kotlin/native 1.6.21
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2.kt 417ms 7.8ms 127.4MB 510ms 47ms kotlin/jvm 17.0.2
kotlin 1.kt 484ms 10.0ms 138.4MB 517ms 53ms kotlin/jvm 17.0.2
haxe 1.hx 538ms 1.5ms 27.4MB 537ms 3ms haxe/cpp 4.2.4
haxe 1.hx 628ms 5.9ms 3.0MB 613ms 0ms haxe/hl/c 4.2.4
haxe 1.hx 735ms 13ms 3.6MB 717ms 3ms haxe/hl/jit 1.12.0
kotlin 2.kt 1335ms 16ms 150.2MB 1290ms 30ms kotlin/native 1.6.21
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 88ms 0.9ms 14.3MB 70ms 0ms haxe/cpp 4.2.4
haxe 1.hx 107ms 2.0ms 3.1MB 97ms 0ms haxe/hl/c 4.2.4
haxe 1.hx 121ms 0.5ms 3.7MB 107ms 0ms haxe/hl/jit 1.12.0
kotlin 1.kt 184ms 1.5ms 74.1MB 240ms 27ms kotlin/jvm 17.0.2
kotlin 2.kt 192ms 3.8ms 42.1MB 167ms 10ms kotlin/native 1.6.21
kotlin 2-m.kt 199ms 1.9ms 78.8MB 280ms 30ms kotlin/jvm 17.0.2
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 538ms 9.7ms 363.9MB 503ms 113ms kotlin/jvm 17.0.2
haxe 1.hx 1430ms 9.8ms 96.9MB 1727ms 50ms haxe/cpp 4.2.4
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
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 203ms 1.8ms 221.2MB 180ms 57ms kotlin/jvm 17.0.2
haxe 1.hx 278ms 1.5ms 28.6MB 293ms 20ms haxe/cpp 4.2.4
kotlin 1.kt 689ms 9.9ms 74.3MB 657ms 10ms kotlin/native 1.6.21
haxe 1.hx 1810ms 21ms 15.4MB 1697ms 97ms haxe/hl/c 4.2.4
haxe 1.hx 2241ms 26ms 20.3MB 2077ms 147ms haxe/hl/jit 1.12.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 633ms 16ms 43.1MB 647ms 10ms kotlin/jvm 17.0.2
kotlin 1n.kt 705ms 4.2ms 1.1MB 693ms 0ms kotlin/native 1.6.21
haxe 2.hx 1084ms 15ms 2.6MB 1070ms 0ms haxe/hl/c 4.2.4
haxe 1.hx 1466ms 63ms 2.6MB 1457ms 0ms haxe/hl/c 4.2.4
haxe 3.hx 2205ms 13ms 27.6MB 2720ms 47ms haxe/cpp 4.2.4
haxe 2.hx 2526ms 63ms 3.3MB 2510ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx 2756ms 36ms 3.3MB 2747ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.4
haxe 2.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/cpp 4.2.4
haxe 3.hx timeout 0.0ms 0.0MB 0ms 0ms haxe/hl/c 4.2.4
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
kotlin 1n.kt 73ms 1.5ms 1.1MB 67ms 0ms kotlin/native 1.6.21
haxe 2.hx 113ms 2.1ms 2.6MB 100ms 0ms haxe/hl/c 4.2.4
haxe 1.hx 147ms 0.3ms 2.6MB 140ms 0ms haxe/hl/c 4.2.4
kotlin 1.kt 149ms 1.4ms 43.2MB 160ms 17ms kotlin/jvm 17.0.2
haxe 3.hx 238ms 1.3ms 25.6MB 267ms 10ms haxe/cpp 4.2.4
haxe 2.hx 255ms 0.7ms 3.4MB 243ms 0ms haxe/hl/jit 1.12.0
haxe 1.hx 270ms 2.8ms 3.3MB 260ms 0ms haxe/hl/jit 1.12.0
haxe 3.hx 764ms 6.9ms 3.2MB 677ms 73ms haxe/hl/c 4.2.4
haxe 2.hx 832ms 0.4ms 4.4MB 820ms 0ms haxe/cpp 4.2.4
haxe 3.hx 909ms 4.6ms 3.9MB 833ms 53ms haxe/hl/jit 1.12.0
haxe 1.hx 1075ms 3.8ms 3.1MB 1063ms 0ms haxe/cpp 4.2.4

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/jvm 17.0.2
kotlin 1n.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21
kotlin 2n.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 1560ms 32ms 249.6MB 1917ms 100ms kotlin/jvm 17.0.2
kotlin 1n.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21
kotlin 2n.kt timeout 0.0ms 0.0MB 0ms 0ms kotlin/native 1.6.21

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 4437ms 132ms 187.6MB 5327ms 63ms kotlin/jvm 17.0.2

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 1370ms 11ms 193.2MB 2130ms 77ms kotlin/jvm 17.0.2